• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

lua+nginx做代理请求时,返回非200状态码内容时会提示跨域

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

今天解决错误主要是跨域的问题,这个跨域在nginx上配置add_header什么的都不够,遇到非200的请求就会出现跨域问题,这个是因为在nginx官方文档写了, add_header只有在 200, 201 (1.3.10), 204, 206, 301, 302, 303, 304, 307 (1.1.16, 1.0.13), or 308 (1.13.0). 才会生效,其他的状态码要生效的话,就得添加 always这个参数,官网文档是:http://nginx.org/en/docs/http/ngx_http_headers_module.html , ,如果在nginx上添加了这个,就不需要在lua上做操作了。

add_header name value [always];

如果就想在lua做操作,在lua上对后端服务器返回非200的请求添加跨域配置。 跨域问题详情可以参考这篇 https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Access_control_CORS

前端产生的现象是:

No 'Access-Control-Allow-Origin' header is present on the requested resource.

lua日志打印的如下:

2020/12/04 20:30:06 [error] 8643#0: *39 [lua] front_proxy.lua:119: do_request(): 开始请求,url:http://pisces.xxx.com.cn/403 , method:GET, body: headers:accept:*/*,Host:pisces.xxx.com.cn,content-type:application/x-www-form-urlencoded,user-agent:Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.88 Mobile Safari/537.36,, client: 172.18.3.101, server: ljf-daili.xxx.com, request: "GET /?url=http://pisces.xxx.com.cn/403 HTTP/1.1", host: "ljf-daili.xxx.com", referrer: "http://pisces.xxx.com.cn/"
2020/12/04 20:30:06 [error] 8643#0: *39 [lua] front_proxy.lua:121: do_request(): no body, client: 172.18.3.101, server: ljf-daili.xxx.com, request: "GET /?url=http://pisces.xxx.com.cn/403 HTTP/1.1", host: "ljf-daili.xxx.com", referrer: "http://pisces.xxx.com.cn/"
2020/12/04 20:30:06 [error] 8643#0: *39 [lua] front_proxy.lua:144: do_request(): type of res.body:string, client: 172.18.3.101, server: ljf-daili.xxx.com, request: "GET /?url=http://pisces.xxx.com.cn/403 HTTP/1.1", host: "ljf-daili.xxx.com", referrer: "http://pisces.xxx.com.cn/"
2020/12/04 20:30:06 [error] 8643#0: *39 [lua] front_proxy.lua:160: do_request(): 响应状态码,ngx.status:403, client: 172.18.3.101, server: ljf-daili.xxx.com, request: "GET /?url=http://pisces.xxx.com.cn/403 HTTP/1.1", host: "ljf-daili.xxx.com", referrer: "http://pisces.xxx.com.cn/"
2020/12/04 20:30:06 [error] 8643#0: *39 [lua] front_proxy.lua:161: do_request(): 响应结果 , ngx.print:<!doctype html>
......

解决办法

在lua代码里面添加以下代码,这样在返回非200状态码请求的时候,就不会再显示跨域问题了。

....省去代理的代码,以下为收到代理结果后的代码
ngx.status = res.status
if ngx.status ~= 200 then
    ngx.header["Access-Control-Allow-Origin"] = "*"  --  添加头信息,允许跨域
end

ngx.print(result)
return ngx.exit(ngx.status)

这样浏览器就不会再说跨域问题了


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
wireshark插件开发 - Lua插件解析发布时间:2022-07-22
下一篇:
C++嵌入Lua脚本发布时间:2022-07-22
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap