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

石家庄建行网站网页设计欣赏及评析

石家庄建行网站,网页设计欣赏及评析,电脑公司网站模板下载,打不开wordpress今天做前端页面渲染的时候遇到一个问题, 因为我使用的wsl开发,windows直接访问不了wsl中的文件,还要改其他配置没成功,索性就不改了,粘贴在桌面上用浏览器打开调试 然后所有使用apifox通过测试的路径全部报错 Ensure CORS response header values are validA cross-origin reso…

今天做前端页面渲染的时候遇到一个问题,

因为我使用的wsl开发,windows直接访问不了wsl中的文件,还要改其他配置没成功,索性就不改了,粘贴在桌面上用浏览器打开调试

然后所有使用apifox通过测试的路径全部报错

Ensure CORS response header values are valid
A cross-origin resource sharing (CORS) request was blocked because of invalid or missing response headers of the request or the associated preflight request .
To fix this issue, ensure the response to the CORS request and/or the associated preflight request are not missing headers and use valid header values.
Note that if an opaque response is sufficient, the request's mode can be set to no-cors to fetch the resource with CORS disabled; that way CORS headers are not required but the response content is inaccessible (opaque

这个错误主要是因为跨域访问导致的

什么是跨域访问

跨域访问报错的原理是浏览器的同源策略(Same-Origin Policy)。同源策略是一种安全策略,指浏览器允许在同一域名下的页面间相互访问,但禁止跨域名访问。

跨域访问的问题通常出现在客户端的 JavaScript 代码中,当 JavaScript 代码向另一个域名的服务器发起请求时,如果该域名与当前域名不同,则会触发跨域访问错误。因为浏览器出于安全考虑,不允许通过 XMLHttpRequest 或 Fetch API 发送跨域请求,除非响应中包含正确的跨域头信息(CORS)。

在服务器上的 HTML 文件也可能遇到跨域问题。比如,如果 HTML 文件中包含了从不同域名加载的资源,比如图片、CSS 或 JavaScript 文件,如果服务器未正确设置跨域头信息,那么这些资源的请求也可能会被浏览器拦截。

通常情况下,在服务器端设置正确的跨域头信息(CORS)可以解决跨域问题。同时,也可以使用 JSONP、代理、WebSocket 等技术绕过浏览器的同源策略。

简单来说就是我在我的桌面的html文件中有访问wsl的域名,然后两个域名不一样,就会触发保护机制,如果这时你的服务端没有添加跨域的许可(对我来说就是添加桌面的html可以访问路径的许可),就会找不到路径返回404

问题解决,

  1. 第一就是不要跨域,两个域名相同(localhost或者127.0.0.1什么的),安全一点

  2. 第二个方法就是,添加许可,对头部信息进行设置(请求与相应都要进行设置,不然要么请求不了,要么收不到相应)

  • 请求:

我们可以使用一个中间件函数来处理跨域的验证,因为如果跨域,浏览器要先发送一个请求方法为: OPTIONS的请求来判断,需要返回一个200才会发送剩下的请求,使用我们定义跨域访问许可中间件函数

// 允许跨域访问中间件
func Dfot() gee7.HandlerFunc {
 return func(ctx *gee7.Context) {
  // 处理预检请求
  if ctx.Req.Method == "OPTIONS" {
   // 验证预检请求的来源、头部字段和请求方法是否符合预期
   // ...

   // 设置响应头部字段
   ctx.Writer.Header().Set("Access-Control-Allow-Origin""*")
   ctx.Writer.Header().Set("Access-Control-Allow-Methods""POST, GET, OPTIONS")
   ctx.Writer.Header().Set("Access-Control-Allow-Headers""Content-Type")

   // 返回状态码 200 和空响应体
   ctx.Writer.WriteHeader(http.StatusOK)
   return
  }
 }
}

我这里ctx.Writer.Header().Set("Access-Control-Allow-Origin"使用的"*"表示所有跨域路径都可以访问,为了安全起见生产环境不建议这样用

  • 相应:

在相应的时候在setheader函数中添加允许跨域访问的路径(我这里嫌麻烦还是用的*)

func (c *Context) SetHeader(key string, value string) {
 c.Writer.Header().Set("Access-Control-Allow-Origin""*")
 c.Writer.Header().Set(key, value)
}

这样就解决跨域访问的的错误了

本文由 mdnice 多平台发布

http://www.yayakq.cn/news/689097/

相关文章:

  • asp网站查看器微信小程序开发接口
  • wap网站 教程怎么看网站被惩罚
  • 企业只有建立自己的网站平台深圳网站制作济南
  • 东莞住建局网站提高销售的10种方法
  • 珠海网站建设科技公司wordpress做账号登录
  • dedecms妇科医院wap网站模板 v1.0做视频解析网站违法不
  • 北京装修公司电话名单建湖网站优化公司
  • 做电影网站电脑网页版
  • 卫浴建材网站建设错误标签 wordpress
  • 广东省网站备案任家房网站建设
  • 洛阳做网站哪家专业群晖安装wordpress
  • 苏州自助建站平台可以申请域名的网站
  • seo外链网站源码网站小图标素材下载
  • 阀门网站设计南昌企业建设网站开发
  • 电信服务器做网站高端响应式网站建设
  • 一个好的网站应该具有什么重庆建设工程信息网信息网
  • 做网站咋做微信公众号平台登录入口
  • 杭州临平网站建设母婴产品网站模板
  • 一个公司可以有两个网站吗个人怎么做推广
  • 网站建设 设计方案 百度文库网站制作销售术语
  • 江门网站制作公司网站后台登入不了出现验证码错误
  • 移动网站建设公司网站进入沙盒的表现
  • 上海嘉定建设局官方网站电商素材网站
  • 网站建设技术进行开发免费推广
  • 苏州建设招投标网站网站开发网站开发设计
  • 青海建设网站多少钱wordpress mysql8.0
  • 广州网站优化排名哪家好做室内设计特别好的网站
  • 济南学习网站制作网站微信分享链接怎么做的
  • 合肥html5网站建设百度推广技巧方法
  • 能不能模仿百度一样做搜索引擎网站wordpress如何调用标签