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

做网站要找本地的吗汕头网站排名

做网站要找本地的吗,汕头网站排名,网站做采集会有问题么,旅游网站 建设平台分析文章目录 前端跨域概念及解决方法什么是跨域跨域的解决方法JSONP跨域CORS简单请求 非简单请求 Nginx反向代理 前端跨域概念及解决方法 什么是跨域 同源指:两个页面域名、协议、端口均相同。 同源策略是浏览器的一个安全限制,跨域是由浏览器的同源策略造…

文章目录

  • 前端跨域概念及解决方法
    • 什么是跨域
    • 跨域的解决方法
      • JSONP跨域
      • CORS
        • 简单请求 非简单请求
      • Nginx反向代理

前端跨域概念及解决方法

什么是跨域

同源指:两个页面域名、协议、端口均相同。
同源策略是浏览器的一个安全限制,跨域是由浏览器的同源策略造成的,是指浏览器不能执行非同源网站的脚本。
同源策略限制了以下行为:

  1. Cookie、LocalStorage、和 IndexDB 无法读取。
  2. DOM 和 JS 对象无法获取。
  3. 请求(XHR、fetch 等)发不出去。

跨域的解决方法

JSONP跨域

JSONP: json with padding,意味着在 JSON 数据外面包裹了一层填充 Padding,即一个函数调用。

解决思路——避免非同源限制。
JSONP 的原理是利用 script 标签没有跨域限制,通过 script 标签的 src 属性设置跨域 URL,并在 URL 中指定一个回调函数名。服务端接到 JSONP 请求后,将数据包装在回调函数中,返回给浏览器。浏览器接收到响应后用回调函数来处理返回的数据。
举例,假设客户端请求一个跨域的 JSONP 数据,URL 是 http://example.com/data?callback=handleData。服务器端收到请求后,返回的响应是 handleData({ “name”: “John”, “age”: 30 })。这里的 handleData 就是客户端指定的回调函数,而 ({ “name”: “John”, “age”: 30 }) 就是 JSON 数据。整个响应就是 JSON 数据外面包裹了一层填充(padding),也就是一个函数调用。

缺陷是只能实现get请求。

代码:

<script>function f(data){ // 注册f函数alert(data)}
</script>
<script src="http://localhost:91?callback=f"></script> // 返回f('你好'),会立刻执行代码,就走到f函数中了。

服务端

var express = require('express');
var app = express();
app.get("/", function(req, res){var funcname = req.query.callback;res.send(funcname + "('你好')")           // f('你好')
})

CORS

CORS: Cross-Origin Resource Sharing,跨域资源共享跨域资源共享。

解决思路——跨域资源共享方案。
CORS 是一个 W3C 标准,它允许浏览器向跨源服务器发出请求,从而克服了前端请求只能同源的限制。
CORS 需要浏览器和服务器同时支持。但是主要是服务器实现 CORS 接口就可以跨域通信,因为浏览器端发现请求跨域的时候会自动添加一些附加头信息,一般无需手动设置。

简单请求 非简单请求

CORS 将请求分为两类:简单请求和非简单请求。对于能对服务器产生副作用的 HTTP 非简单请求,浏览器必须先发送一个方法为 OPTIONS 的预检请求来获取服务器是否允许该请求跨域。服务器得到确认之后,才发起真正的HTTP请求。在预检请求中,服务端也可以通知客户端是否要携带Credentials.

简单请求同时满足

  • 请求方法是 GET / HEAD / POST
  • 除了浏览器自动设置的头,只能设置 Fetch 规范允许设置的“CORS安全请求头”
    Accept、Accept-Language、Content-Language、Content-Type(需要注意额外的限制)、DPR 、Downlink、Save-Data、Viewport-Width、width
  • 对于 Content-Type 的值只限于下面几个(注意没有application/json,现在post的请求经常使用这个,所以当发post请求的时候会触发预检请求不要意外)
    application/x-www-form-urlencoded、multipart/form-data、text/plain

对于简单请求,CORS 的策略是请求时在请求头中增加一个 Origin 字段,表示请求发出的域。服务器收到请求后,根据该字段判断是否允许该请求访问。
对于响应头,如果允许,则在 HTTP 头信息中添加 Access-Control-Allow-Origin 字段,并返回正确的结果。如果不允许则不添加该字段。

对于非简单请求,
比如请求方法是 PUT 或 DELETE,或者是发送 json 格式的请求。
对于非简单请求的跨源请求,浏览器会在真实请求发出前,增加一次 OPTIONS 请求,称为预检请求(preflightrequest)。预检请求将真实请求的信息,包括请求方法、自定义头字段、源信息添加到 HTTP 头信息字段中,询问服务器是否允许这样的操作。
服务器收到请求时,需要分别对各字段进行验证,验证通过后,会在返回 HTTP 头信息中添加:允许的域、方法、字段、有效期等信息。
当预检请求通过后,浏览器才会发送真实请求到服务器。

对于跨域(发生CORS)的请求默认是不会带上凭证信息(credentials)的,如果要发送凭证信息(credentials)就需要设置对应的标识位。
请求:

  • 请求中要设置withCredentials为true。

响应:

  • Access-Control-Allow-Credentials: true
  • Access-Control-Allow-Origin的值不再是通配符*,应该是单一的origin。

代码:
nodejs

var express = require('express');
var app = express();
//修改响应头
app.get("/",function(req, res){res.header("Access-Control-Allow-Origin","*");res.send("你好")
})// 借助cors模块来解决这个问题
var cors = require('cors');
app.use(cors({origin: ['http://localhost:8083'],methods: ['GET', 'POST'],allowHeaders: ['Conten-Type', 'Authorization']
}));

Nginx反向代理

解决思路——隐蔽跨域
使用Nginx反向代理,在a域名的请求里使用反向代理指向b域名,让浏览器以为一直在访问a网站,不触发跨域限制。

参考:
https://juejin.cn/post/6844903746837889032
https://www.cnblogs.com/n031/p/11828797.html
https://juejin.cn/post/6844903521163182088
https://www.imooc.com/article/291931

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

相关文章:

  • 潍坊个人做网站营销型网站分析
  • 常熟市住房和城乡建设部网站百度网址入口
  • wordpress 积分兑换seo的优化技巧和方法
  • 腾讯做网站上传策划推广
  • 建设网站设计专业服务网络品牌营销
  • 分类信息网站建设价格开封网络推广公司
  • h5商城网站建设是什么公司网络营销推广方案
  • 郑州企业网站优化多少钱seo词条
  • 万网 网站 流程网站快速排名服务
  • 优秀网站设计欣赏案例外链代发软件
  • 建设计公司网站要多少钱互联网全网推广
  • 企业建设网站有什么作用seo优化排名价格
  • 深圳移动官网网站建设专业网站制作网站公司
  • 网站开发与java技术公司网站建设全包
  • 网站需求分析是在建站的什么阶段做的_为什么要做?天津seo优化
  • 怎样把自己做的网站发到网上seo搜索优化网站推广排名
  • 做网站 怎么谈站长工具樱花
  • 搭建网站 赚钱申请一个网站
  • 网站做好了 怎么做解析东莞seo建站如何推广
  • 做网站1核1g服务器够吗武汉seo工作室
  • 西安做网站的公司哪家好网站seo优化教程
  • pinboard wordpressseo优化一般包括哪些内容
  • 陕西省高速建设集团网站百度开放云平台
  • 网站开发功能需求表上海关键词优化报价
  • 阿里云网站怎么做如何制定会员营销方案
  • 关于网站建设案例seo外包公司一般费用是多少
  • 大型网站只做要多少钱打广告的免费软件
  • 网页设计与制作cssseo内容优化方法
  • 什么网站做优化最好seo排名点击器曝光行者seo
  • 网站图片的暗纹是怎么做的交换友链平台