首頁 > 運維 > Nginx > 主體

nginx如何解決請求跨域問題

王林
發布: 2020-11-10 16:18:17
轉載
3516 人瀏覽過

nginx如何解決請求跨域問題

一般前端的请求是 网址都是 域名(端口 访问的是80 或者 443),而后端的服务是 8080 端口,这个时候你请求http://106.520.156.210:8080/vic-indoor-pc/selectAllUser就会报跨域问题了(端口不同)。所以我在每个请求加了统一的前缀 /api ,请求变成了 http://106.520.156.210/api/vic-indoor-pc/selectAllUse (端口必须和前端一样)。

前端发送请求:

http://106.520.156.210/api/vic-indoor-pc/selectAllUse
登入後複製

Nginx转发变成了:

http://106.520.156.210:8080/vic-indoor-pc/selectAllUse
登入後複製

经过Nginx 这样转发,对于浏览器来说,访问的就是 80 ,但是请求的其实是 8080。rewrite "^/api/(.*)$" /$1 break; 这句就是把 /api 给删除掉了然后 转发到了 http://106.520.156.210:8080/

                location /api/vic-indoor-pc {

                        proxy_set_header Client-IP      $Remote_addr;
                        proxy_pass http://106.520.156.210:8080/;
                        rewrite "^/api/(.*)$" /$1 break; 

                }
登入後複製

我还碰到了下载阿里OSS 存储跨域的问题,也是这么解决的。(加上统一前缀)

                location /img/report {

                        proxy_set_header Client-IP      $Remote_addr;
                        proxy_pass https://bilibili.oss-cn-shenzhen.aliyuncs.com/;
                        rewrite "^/img/(.*)$" /$1 break;
                }
登入後複製

相关推荐:nginx教程

以上是nginx如何解決請求跨域問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!