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

网站建设教程书籍如何制作企业网站

网站建设教程书籍,如何制作企业网站,广州正规网站建设企业,网站套模板什么意思什么是跨域? 跨域是指从一个域名的网页去请求另一个域名的资源。比如从www.baidu.com页面去请求www.google.com的资源。但是一般情况下不能这么做,他是由浏览器的同源策略造成的,是浏览器对JavaScript施加的安全限制。 跨域的严格定义是&…

什么是跨域?

       跨域是指从一个域名的网页去请求另一个域名的资源。比如从www.baidu.com页面去请求www.google.com的资源。但是一般情况下不能这么做,他是由浏览器的同源策略造成的,是浏览器对JavaScript施加的安全限制。

       跨域的严格定义是:只要协议、端口、域名有任何一个的不同,就被当做是跨域。

       所谓同源是指:域名、协议、端口有任何一个不同,就是跨域。

URL

说明

是否允许通信

http://www.a.com:80/a.js
http://www.a.com:80/b.js

同一域名下

允许

http://www.a.com:80/lab/a.js
http://www.a.com:80/script/b.js

同一域名下不同文件夹

允许

http://www.a.com:8000/a.js
http://www.a.com/b.js

同一域名,不同端口

不允许

http://www.a.com:80/a.js
https://www.a.com:443/b.js  ssl

同一域名,不同协议

不允许

http://www.a.com/a.js
http://script.a.com/b.js

主域相同,子域不同

不允许

http://www.a.com/a.js
http://a.com/b.js

同一域名,不同二级域名(同上)

不允许(cookie这种情况下也不允许访问)

http://www.cnblogs.com/a.js
http://www.a.com/b.js

不同域名

不允许

为什么浏览器要限制跨域访问呢?

原因就是安全问题:
        如果一个网页可以随意地访问另外一个网站的资源,那么久有可能在客户完全不知情的情况下出现安全问题。比如以下安全问题:

  1. 用户访问www.mabank.com,登录并进行网银操作,这时cookie都生成并存放在浏览器。
  2. 用户突然想起件事,并迷迷糊糊地访问了一个邪恶的网站 www.xiee.com这时该网站就可以在它的页面中,拿到银行的cookie,比如用户名,登陆token等,然后发起www.mybank.com 的操作。
  3. 如果这时浏览器不予限制,并且银行也没有做响应的安全处理的话,那么用户的信息有可能就这么泄露了。

为什么要跨域?

既然有安全问题,那么为什么又要跨域呢?

有时公司内部有多个不同的子域,比如一个是location.company.com,而应用是放在app.company.com,这时想从app.company.com去访问location.company.com的资源就属于跨域。

解决跨域问题的方法:

  1. 前端解决
  2. 后端解决

跨域资源共享(CORS)

       W3C 的 Web 工作组推荐了一种新的机制,即跨域资源共享(Cross-origin Resource Sharing),简称CORS。其实这个机制就是实现了跨站访问控制,使得安全地进行跨站数据传输成为可能。

       服务器端对于CORS的支持,主要就是通过设置Access-Control-Allow-Origin来进行的。如果浏览器检测到相应的设置,就可以允许ajax进行跨域的访问。

       只需要在后台中加上响应头来允许域请求!在被请求的Response header中加入设置,就可以实现跨域访问了!

       创建过滤器实现后端设置允许跨域访问:

@WebFilter(urlPatterns = "/*")
public class CorsFilter implements Filter {public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)throws IOException, ServletException {System.out.println("跨域过滤器");HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;HttpServletRequest httpRequest = (HttpServletRequest) servletRequest;//允许携带Cookie时不能设置为* 否则前端报错httpResponse.setHeader("Access-Control-Allow-Origin", httpRequest.getHeader("origin"));//允许所有请求跨域httpResponse.setHeader("Access-Control-Allow-Methods", "*");//允许跨域的请求方法GET, POST, HEAD 等httpResponse.setHeader("Access-Control-Allow-Headers", "*");//允许跨域的请求头httpResponse.setHeader("Access-Control-Allow-Credentials", "true");//是否携带cookiefilterChain.doFilter(servletRequest, servletResponse);}
} 

 

http://www.ds6.com.cn/news/8010.html

相关文章:

  • 徐汇网站建设姓名查询
  • 政府网站图解怎么做网站规划与设计
  • 免费做金融网站经典软文案例标题加内容
  • 深圳企业网站seowindows优化大师官网
  • 黑龙江省道路建设网站站长工具在线
  • 徐州建设工程交易网浙江公正关键词seo报价
  • 西安哪家公司做网站seo黑帽教学网
  • html静态网站开发青岛seo推广专员
  • php做网站半成品手游推广加盟
  • 做平台和独立建网站电商培训有用吗
  • 微信小程序模板样式seo前线
  • 无锡做网站seo的清远seo
  • 怎么给网站做404界面木卢seo教程
  • 做cg的网站高端网站定制公司
  • 铁岭建设银行网站网店推广常用的方法
  • 大兴网站开发网站建设小红书seo优化
  • bl做的视频网站深圳百度seo优化
  • 网站加栏目chatgpt中文在线
  • 南京做网站优化哪家好北京排名seo
  • html做的网站怎么发布十大免费最亏的免费app
  • 温州专业微网站制作网络公司百度搜索引擎优化案例
  • 网站备案 条例百度精准推广
  • 可信网站认证 技术支持单位百度信息流广告代理
  • 重庆手机网站制作费用教你如何建立网站
  • 哪个网站做简历免费杭州seo网站建设
  • 怎样做网站banner一般开车用什么导航最好
  • 图文广告加盟哪家好郑州网站排名优化外包
  • 山西省建设厅入晋备案网站营销推广外包公司
  • 疫情在8月彻底结束seo关键词推广
  • 购物网站怎么经营推广引流吸引人的标题