开发环境可运行,发包后报错(nginx代理出现了问题)

在Vue项目首次发包过程中,遇到前端登录后其他接口报错,问题源于后端自定义的Asset_token在请求头中未正确转发。原因是Nginx默认不支持下划线命名的请求头字段,需通过设置underscores_in_headerson来启用。解决方案是避免使用带下划线的字段名,或者在Nginx配置中开启对此的支持。
摘要由CSDN通过智能技术生成

    场景:

        vue项目首次发包...

        后端服务发包完毕,apifox测试接口没问题、前端开发环境连服务也没问题...

        前端项目打包,提前配置nginx,前端发包...

        打开网页,登录接口正常,登录后其他接口报错...

       

查看报错信息:

        后端自定义的报错信息,总体而言就是没有拿到 'token'。

        诡异的是,在浏览器中可以查看到header中确实携带了所谓的 'token'。

        

询问公司大佬:

        你这个后台报错是因为header信息通过nginx没有转发过去。你们的 ‘token’是用的什么单词?

 找到病因:

        项目是新项目,'token' 用的是 'Asset_token'。

解决方案:

        由于nginx默认不支持这个下换线的写法。所以如果想支持,需要添加一条配置。

underscores_in_headers on;

 

 

官方解释:

Syntax: underscores_in_headers on | off;
Default: underscores_in_headers off;
Context: http, server

Enables or disables the use of underscores in client request header fields. When
the use of underscores is disabled, request header fields whose names contain underscores
are marked as invalid and become subject to the ignore_invalid_headers directive.

由官方解释可以看出,默认情况下,underscores_in_headers为off,表示当客户端请求头中带有下划线的字段默认将会被标识为无效字段。

因此,如下两个建议:

尽量不要在请求头中添加带下划线的字段;
使用NGINX代理的时候,添加underscores_in_headers on的配置。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值