当前位置: 首页 > news >正文

互联网营销 网站 推荐女孩子学广告设计好找工作吗

互联网营销 网站 推荐,女孩子学广告设计好找工作吗,有哪些免费的云服务器,如何做百度网站转载自 搞定所有的跨域请求问题 网上各种跨域教程#xff0c;各种实践#xff0c;各种问答#xff0c;除了简单的 jsonp 以外#xff0c;很多说 CORS 的都是行不通的#xff0c;老是缺那么一两个关键的配置。本文只想解决问题#xff0c;所有的代码经过亲自实践。 本文…转载自  搞定所有的跨域请求问题 网上各种跨域教程各种实践各种问答除了简单的 jsonp 以外很多说 CORS 的都是行不通的老是缺那么一两个关键的配置。本文只想解决问题所有的代码经过亲自实践。 本文解决跨域中的 get、post、data、cookie 等这些问题。 本文只会说 get 请求和 post 请求读者请把 post 请求理解成除 get 请求外的所有其他请求方式。 JSONP jsonp 的原理很简单利用了【前端请求静态资源的时候不存在跨域问题】这个思路。 但是 只支持 get只支持 get只支持 get。 注意一点既然这个方法叫 jsonp后端数据一定要使用 json 数据不能随便的搞个字符串什么的不然你会觉得结果莫名其妙的。 前端 jQuery 写法 $.ajax({type: get,url: baseUrl /jsonp/get,dataType: jsonp,success: function(response) {$(#response).val(JSON.stringify(response));} }); dataType: jsonp。除了这个其他配置和普通的请求是一样的。 后端 SpringMVC 配置 如果你也使用 SpringMVC那么配置一个 jsonp 的 Advice 就可以了这样我们写的每一个 Controller 方法就完全不需要考虑客户端到底是不是 jsonp 请求了Spring 会自动做相应的处理。 ControllerAdvice public class JsonpAdvice extends AbstractJsonpResponseBodyAdvice {public JsonpAdvice(){// 这样如果请求中带 callback 参数Spring 就知道这个是 jsonp 的请求了super(callback);} } 以上写法要求 SpringMVC 版本不低于 3.2低于 3.2 的我只能说你们该升级了。 后端非 SpringMVC 配置 以前刚工作的时候Struts2 还红遍天几年的光景SpringMVC 就基本统治下来了国内市场。 偷懒一下这里贴个伪代码吧在我们的方法返回前端之前调一下 wrap 方法 public Object wrap(HttpServletRequest request){String callback request.getParameter(callback);if(StringUtils.isBlank(callback)){return result;} else {return callback(JSON.toJSONString(result));} } CORS Cross-Origin Resource Sharing 毕竟 jsonp 只支持 get 请求肯定不能满足我们的所有的请求需要所以才需要搬出 CORS。 国内的 web 开发者还是比较苦逼的用户死不升级浏览器老板还死要开发者做兼容。 CORS 支持以下浏览器目前来看浏览器的问题已经越来越不重要了连淘宝都不支持 IE7 了~ Chrome 3Firefox 3.5Opera 12Safari 4Internet Explorer 8 前端 jQuery 写法 直接看代码吧 $.ajax({type: POST,url: baseUrl /jsonp/post,dataType: json,crossDomain: true,xhrFields: {withCredentials: true},data: {name: name_from_frontend},success: function (response) {console.log(response)// 返回的 json 数据$(#response).val(JSON.stringify(response));} }); dataType: json这里是 json不是 jsonp不是 jsonp不是 jsonp。 crossDomain: true这里代表使用跨域请求 xhrFields: {withCredentials: true}这样配置就可以把 cookie 带过去了不然我们连 session 都没法维护很多人都栽在这里。当然如果你没有这个需求也就不需要配置这个了。 后端 SpringMVC 配置 对于大部分的 web 项目一般都会有 mvc 相关的配置类此类继承自 WebMvcConfigurerAdapter。如果你也使用 SpringMVC 4.2 以上的版本的话直接像下面这样添加这个方法就可以了 Configuration public class WebConfig extends WebMvcConfigurerAdapter {Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping(/**/*).allowedOrigins(*);} } 如果很不幸你的项目中 SpringMVC 版本低于 4.2那么需要「曲线救国」一下 public class CrossDomainFilter extends OncePerRequestFilter {Overrideprotected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {response.addHeader(Access-Control-Allow-Origin, *);// 如果提示 * 不行请往下看response.addHeader(Access-Control-Allow-Credentials, true);response.addHeader(Access-Control-Allow-Methods, GET, POST, PUT, DELETE);response.addHeader(Access-Control-Allow-Headers, Content-Type);filterChain.doFilter(request, response);} } 在 web.xml 中配置下 filter filterfilter-nameCrossDomainFilter/filter-namefilter-classcom.javadoop.filters.CrossDomainFilter/filter-class /filter filter-mappingfilter-nameCrossDomainFilter/filter-nameurl-pattern/*/url-pattern /filter-mapping 有很多项目用 shiro 的也可以通过配置 shiro 过滤器的方式这里就不介绍了。 注意了我说的是很笼统的配置对于大部分项目是可以这么笼统地配置的。文中类似 “*” 这种配置读者应该都能知道怎么配。 如果读者发现浏览器提示不能用 ‘*’ 符号那读者可以在上面的 filter 中根据 request 对象拿到请求头中的 refererrequest.getHeader(referer)然后动态地设置 Access-Control-Allow-Origin String referer request.getHeader(referer); if (StringUtils.isNotBlank(referer)) {URL url new URL(referer);String origin url.getProtocol() :// url.getHost();response.addHeader(Access-Control-Allow-Origin, origin); } else {response.addHeader(Access-Control-Allow-Origin, *); } 2018-04-28今天终于知道为什么有时候会提示我们 * 不支持了原来是只要前端写了 withCredentials: true 那么浏览器就会提示这个一种办法就是这里说的使用动态构造 origin 的方式另一种办法就是跨域不传 cookie让前端把 cookie 要传的信息(如 sessionId/accessKey) 放到 header 中或者直接写在 request 的参数里。 前端非 jQuery 写法 jQuery 一招鲜吃遍天的日子是彻底不在了这里就说说如果不使用 jQuery 的话怎么解决 post 跨域的问题。大部分的 js 库都会提供相应的方案的大家直接找相应的文档看看就知道怎么用了。 来一段原生 js 介绍下 function createCORSRequest(method, url) {var xhr new XMLHttpRequest();if (withCredentials in xhr) {// 如果有 withCredentials 这个属性那么可以肯定是 XMLHTTPRequest2 对象。看第三个参数xhr.open(method, url, true);} else if (typeof XDomainRequest ! undefined) {// 此对象是 IE 用来跨域请求的xhr new XDomainRequest();xhr.open(method, url);} else {// 如果是这样很不幸浏览器不支持 CORSxhr null;}return xhr; }var xhr createCORSRequest(GET, url); if (!xhr) {throw new Error(CORS not supported); } 其中ChromeFirefoxOperaSafari 这些「程序员友好」的浏览器使用的是 XMLHTTPRequest2 对象。IE 使用的是 XDomainRequest。
http://www.zqtcl.cn/news/174730/

相关文章:

  • 江苏住房城乡建设厅网站一千块钱能注册公司吗
  • 山东兴华建设集团有限公司网站分类信息网站怎么做
  • 怎么用手机网站做软件西安网站建设开发熊掌号
  • asp.net做网站的流程杭州vi设计广告公司
  • 微信网站主题网络建设解决方案
  • 济南自助建站系统网站的外链建设计划
  • 中山低价网站建设一学一做教育视频网站有哪些内容
  • 网上最好的网站模块模板建站小程序
  • 安平县哪家做网站html动漫网站模板下载
  • 网站关于 模板wordpress adsence
  • 杭州公司网站建设如何选择五屏网站建设
  • 天津商城网站建设平面设计师网站
  • 上海的网站设计公司苏州网站建设渠道
  • 做美食没有广告的网站o2o网站建设
  • 网站程序调试模式怎么做做汽车特卖会的网站
  • 怎么有自己的网站政务公开网站建设方案
  • 济南装饰行业网站建设成都地区网站开发成本
  • 宁波产品网站设计模板网站建设需要通过哪些审批
  • 了解网站建设管理网站开发的可行性研究报告
  • 淄博网站设计策划方案公司中文域名.网站
  • 综合网站系统电脑怎么做软件开发
  • 网站虚拟主持人制作国内网站建设排名
  • 上海房地产网站建设报价wordpress.备份
  • 网站建设运营维护合同专用车网站建设价格
  • 建设部咨询资质网站平台类网站建设公司
  • wap 网站 源码网站建立
  • 辽阳专业建设网站公司山东省工程建设招标信息网站
  • 下载专门做初中数学题的网站佛山网站制作在线
  • 永康物流网站蒙牛企业网站建设规划书
  • 网站开发发和后台开发有什么区别马鞍山网站建设价格