Nginx配置cros跨域以及遇到401响应的问题

本文讲述了在Nginx配置CORS跨域时遇到401响应的问题,分析了原因并提供了解决办法。问题在于非200、300状态码时,响应头缺失Access-Control,通过在add_header中添加always参数,确保所有状态码下都能正确添加响应头。
摘要由CSDN通过智能技术生成

nginx配置cros跨域以及遇到401、500响应的问题

这是我Nginx的server配置:

server {
    listen      80;
    server_name DataAnalysis;

    location / {
        if ($request_method = 'OPTIONS'){
                add_header 'Access-Control-Allow-Origin' '*';
                add_header 'Access-Control-Allow-Methods' 'GET,POST,OPTIONS';
                add_header 'Access-Control-Allow-Headers' 'Authorization,DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Content-Range,Range';
                return 204;
            }
        if ($request_method = 'POST') {
                add_header 'Access-Control-Allow-Origin' '*' always;
                add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS' always;
                add_header 'Acce
  • 5
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
好的,让我来介绍一下如何在Nginx配置前端跨域访问以及压缩文件。 1. 配置前端跨域访问。在Nginx配置文件中加入以下内容: ``` location /api { add_header 'Access-Control-Allow-Origin' '*'; add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, DELETE, PUT'; add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept, Authorization'; if ($request_method = 'OPTIONS') { add_header 'Access-Control-Allow-Origin' '*'; add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, DELETE, PUT'; add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept, Authorization'; return 204; } } ``` 这里的`/api`是你的后端接口路径,`Access-Control-Allow-Origin`表示允许的跨域来源,`Access-Control-Allow-Methods`表示允许的跨域请求方法,`Access-Control-Allow-Headers`表示允许的跨域请求头信息。 2. 配置文件压缩。在Nginx配置文件中加入以下内容: ``` gzip on; gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; ``` 这里的`gzip on`表示开启压缩,`gzip_types`表示需要压缩的文件类型。 配置完成后,Nginx会自动对需要压缩的文件进行压缩,然后发送给客户端浏览器。 3. 保存并退出配置文件,然后重启Nginx服务器: ``` sudo systemctl restart nginx ``` 现在,你已经成功在Nginx配置了前端跨域访问和文件压缩。如果你的前端项目和后端项目在不同的域名或者端口下,可以通过配置跨域访问来实现数据交互。同时,压缩文件可以减小文件大小,提高网页加载速度,优化用户体验。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值