国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

巧用Nginx配置解決跨域問(wèn)題

這篇具有很好參考價(jià)值的文章主要介紹了巧用Nginx配置解決跨域問(wèn)題。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

頁(yè)面nginx配置

1,前端頁(yè)面放在域名根目錄,比如,http://www.xuecheng.com/ ,對(duì)應(yīng)的nginx配置:

#門(mén)戶
        location / {
            alias  D:/Z_lhy/SpringCloud/xuecheng_online/www/xc-ui-pc-static-portal/;
            index  index.html;
        }

頁(yè)面目錄:

巧用Nginx配置解決跨域問(wèn)題

接口nginx配置

2,前端請(qǐng)求接口路徑,在域名后面加一個(gè)目錄

url : "http://www.xuecheng.com/api/auth/oauth/token",//發(fā)送請(qǐng)求的地址 
function login(){
        var uname = $("#username").val();
        var pwd = $("#password").val();
        
         $.ajax({
            url : "http://www.xuecheng.com/api/auth/oauth/token",//發(fā)送請(qǐng)求的地址 
            type: "post",
            dataType: "json",
            data : "username="+uname+"&password="+pwd+"&grant_type=password",
            beforeSend:function (request) {
                 // 如果后臺(tái)沒(méi)有跨域處理,這個(gè)自定義
                 request.setRequestHeader("Authorization","Basic RG9jV2ViQXBwOjEyMzQ1Ng==");
                 // 禁用按鈕,防止重復(fù)提交
                 $("#submit").attr({ disabled: "disabled" });
            },
            error : function() {
                alert("error occured!!!");//請(qǐng)求失敗時(shí)彈出的信息
            },
            success : function(data) {//返回的信息展示出來(lái)
                alert(JSON.stringify(data))
            }
        });
    };

nginx 對(duì)api接口配置

location /api/ {
            add_header 'Access-Control-Allow-Origin' $http_origin;
            add_header 'Access-Control-Allow-Credentials' 'true';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'DNT,Authorization,Accept,Origin,Keep-Alive,User-Agent,X-Mx-ReqToken,X-Data-Type,X-Auth-Token,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range';
            add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';
            if ($request_method = 'OPTIONS') {
                add_header 'Access-Control-Max-Age' 1728000;
                add_header 'Content-Type' 'text/plain; charset=utf-8';
                add_header 'Content-Length' 0;
                return 204;
            }
           proxy_pass http://apiserver/; 
           proxy_set_header Host $host;
           proxy_set_header X-Real-IP $remote_addr;
           proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
           proxy_set_header X-Forwarded-Proto $scheme;
           proxy_connect_timeout 5;
        }
        

其中的

$http_origin

$http_origin并不是nginx的內(nèi)置參數(shù),nginx支持取自定義的參數(shù)值,$http_XXX這個(gè)格式是nginx取請(qǐng)求中header的XXX的值的。這里取的是origin,而一般跨域請(qǐng)求都會(huì)將請(qǐng)求的來(lái)源放在origin中(瀏覽器會(huì)往跨域請(qǐng)求的header上面加origin這個(gè)header)。

巧用Nginx配置解決跨域問(wèn)題

?文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-410307.html

?

這樣配置的話,前端頁(yè)面在域名下:www.xuecheng.com,而訪問(wèn)的接口則是www.xuecheng.com/api/xxx ,這樣就不存在跨域問(wèn)題了,

其實(shí)nginx不配置??Access-Control-Allow-Origin也沒(méi)事,因?yàn)榍昂蠖嗽谝粋€(gè)域下了。

注意事項(xiàng)

如果你前后端訪問(wèn)存在跨域問(wèn)題,而且你需要使用cookie,后端要想獲取到前端攜帶過(guò)來(lái)的cookie,前后端都要做配置:

前端:

var xhr = new XMLHttpRequest()
xhr.withCredentials = true
xhr.open('GET', 'http://localhost:8888/', true)
xhr.send(null)

后端:

Access-Control-Allow-Origin: http://www.abc.com(這里必須域名不能是*)
Access-Control-Allow-Credentials: true

完整nginx配置

#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;
    
    #微服務(wù)網(wǎng)關(guān)
    upstream apiserver{
        server 127.0.0.1:50101;
    }

    server {
        listen       80;
        server_name  www.xuecheng.com;
        
        ssi on;
        ssi_silent_errors on;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;
        
        #門(mén)戶
        location / {
            alias  D:/Z_lhy/SpringCloud/xuecheng_online/www/xc-ui-pc-static-portal/;
            index  index.html;
        }
        #location  / {
        #   root /neworiental/www/jiaofu;
        #   index index.html;
        #   try_files $uri /index.html;
        #}

        # proxy_pass末尾有/,請(qǐng)求地址:http://localhost/api/test,轉(zhuǎn)發(fā)地址:http://127.0.0.1:8000/test
        location /api/ {
            add_header 'Access-Control-Allow-Origin' $http_origin;
            add_header 'Access-Control-Allow-Credentials' 'true';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'DNT,Authorization,Accept,Origin,Keep-Alive,User-Agent,X-Mx-ReqToken,X-Data-Type,X-Auth-Token,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range';
            add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';
            if ($request_method = 'OPTIONS') {
                add_header 'Access-Control-Max-Age' 1728000;
                add_header 'Content-Type' 'text/plain; charset=utf-8';
                add_header 'Content-Length' 0;
                return 204;
            }
           proxy_pass http://apiserver/; 
           proxy_set_header Host $host;
           proxy_set_header X-Real-IP $remote_addr;
           proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
           proxy_set_header X-Forwarded-Proto $scheme;
           proxy_connect_timeout 5;
        }
        
        location ^~ /openapi/auth/ {
             proxy_pass http://apiserver/auth/;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}


    # HTTPS server
    #
    #server {
    #    listen       443 ssl;
    #    server_name  localhost;

    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;
    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers  on;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}

}

參考:

正確的Nginx跨域配置:https://blog.csdn.net/envon123/article/details/83270277

跨域資源共享(CORS)安全性:https://blog.csdn.net/weixin_43964148/article/details/109352413

?

到了這里,關(guān)于巧用Nginx配置解決跨域問(wèn)題的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • nginx處理cros跨域遇到的各種問(wèn)題及解決方案,以及https配置和瀏覽器https不安全問(wèn)題處理

    nginx處理cros跨域遇到的各種問(wèn)題及解決方案,以及https配置和瀏覽器https不安全問(wèn)題處理

    提示:本人在生產(chǎn)部署服務(wù)時(shí)遇到一系列跨域問(wèn)題和https配置問(wèn)題,特此做以下記錄: 跨域是指a頁(yè)面想獲取b頁(yè)面資源,如果a、b頁(yè)面的協(xié)議、域名、端口、子域名不同,或是a頁(yè)面為ip地址,b頁(yè)面為域名地址,所進(jìn)行的訪問(wèn)行動(dòng)都是跨域的,而瀏覽器為了安全問(wèn)題一般都限制了

    2024年02月02日
    瀏覽(80)
  • 記:vite3+vue3+axios前端項(xiàng)目跨域問(wèn)題解決【前端和服務(wù)器nginx配置】

    前言:什么是跨域,網(wǎng)上一搜一大把,所以這里直接跳過(guò),直入主題。 處理方式:不通過(guò)后端處理跨域,通過(guò)前端+服務(wù)器nginx處理。 1.前端涉及處理跨域的必要配置(開(kāi)發(fā)環(huán)境、生產(chǎn)環(huán)境):vite3、vue3、axios 2.服務(wù)器涉及處理跨域的配置(生產(chǎn)環(huán)境):nginx【主要用到其配置

    2024年02月01日
    瀏覽(101)
  • Nginx解決跨域問(wèn)題

    Nginx解決跨域問(wèn)題

    目錄 前言 一、跨域問(wèn)題 1.什么是跨域 ?2.CORS 二、Nginx跨域處理 三.補(bǔ)充 這幾天出現(xiàn)了一個(gè)問(wèn)題,我們中的一個(gè)A系統(tǒng)需要給B系統(tǒng)調(diào)用,造成了跨域問(wèn)題。 1.什么是跨域 當(dāng)一個(gè)請(qǐng)求url的協(xié)議、域名、端口三者之間任意一個(gè)與當(dāng)前頁(yè)面url不同即為跨域。 ?2.CORS CORS是一個(gè)W3C標(biāo)準(zhǔn),

    2024年02月16日
    瀏覽(20)
  • 使用Nginx解決跨域問(wèn)題

    使用Nginx解決跨域問(wèn)題

    目錄 使用Nginx解決跨域問(wèn)題 1、修改瀏覽器、客戶端訪問(wèn)地址 2、在nginx.conf配置文件需配置server 3、在Nginx中配置客戶端訪問(wèn)的接口(按照規(guī)則或通配),并設(shè)置被代理的服務(wù)器 4、在Nginx中統(tǒng)一配置客戶端訪問(wèn)的頭部信息(解決跨域問(wèn)題) 5、在服務(wù)器端設(shè)置相應(yīng)的頭部信息(

    2024年02月13日
    瀏覽(20)
  • Nginx跨域問(wèn)題的解決方法

    Nginx跨域問(wèn)題的解決方法

    Web前端開(kāi)發(fā)經(jīng)常會(huì)遇到跨域訪問(wèn),如果沒(méi)有辦法讓后臺(tái)開(kāi)放訪問(wèn)域,調(diào)用接口就會(huì)被瀏覽器攔截。解決跨域問(wèn)題的方案,可以搭建一個(gè)后臺(tái)服務(wù)做中間轉(zhuǎn)發(fā),也可以用 nginx https://so.csdn.net/so/search?q=nginx 轉(zhuǎn)發(fā)。 問(wèn)題發(fā)生在nginx 反向代理 https://so.csdn.net/so/search?q=%E5%8F%8D%E5%90%91%E

    2024年02月11日
    瀏覽(22)
  • 使用nginx解決跨域問(wèn)題(前端解決)

    使用nginx解決跨域問(wèn)題(前端解決)

    情況是這樣的:編寫(xiě)好的前端頁(yè)面本地打開(kāi)是沒(méi)有問(wèn)題的,請(qǐng)求都能發(fā)出去,接收到正確的響應(yīng)結(jié)果。但是,使用nginx來(lái)部署這個(gè)頁(yè)面就會(huì)出現(xiàn)跨域問(wèn)題。 跨域 :由于瀏覽器的同源策略,即屬于不同域的頁(yè)面之間不能相互訪問(wèn)各自的頁(yè)面內(nèi)容 注 :同源策略,單說(shuō)來(lái)就是同協(xié)

    2024年02月11日
    瀏覽(24)
  • Nginx 代理解決跨域問(wèn)題分析

    Nginx 代理解決跨域問(wèn)題分析

    當(dāng)你遇到跨域問(wèn)題,不要立刻就選擇復(fù)制去嘗試。請(qǐng)?jiān)敿?xì)看完這篇文章再處理 。我相信它能幫到你。 分析前準(zhǔn)備: 前端網(wǎng)站地址:http://localhost:8080 服務(wù)端網(wǎng)址:http://localhost:59200? 首先保證服務(wù)端是沒(méi)有處理跨域的,其次,先用postman測(cè)試服務(wù)端接口是正常的。 當(dāng)網(wǎng)站8080去

    2024年02月09日
    瀏覽(25)
  • nginx如何解決前后端跨域問(wèn)題

    Nginx 可以通過(guò)以下兩種方式來(lái)解決前后端跨域問(wèn)題: 添加 CORS 頭部 Nginx 可以通過(guò)添加 CORS 頭部來(lái)解決跨域問(wèn)題。CORS(Cross-Origin Resource Sharing)是一種機(jī)制,它允許 Web 應(yīng)用程序從不同的域訪問(wèn)其資源。要在 Nginx 中添加 CORS 頭部,可以在 Nginx 配置文件中的特定位置添加以下代

    2024年02月05日
    瀏覽(17)
  • 解決你的 Nginx 代理跨域問(wèn)題詳細(xì)完整版

    解決你的 Nginx 代理跨域問(wèn)題詳細(xì)完整版

    當(dāng)你遇到跨域問(wèn)題,不要立刻就選擇復(fù)制去嘗試。請(qǐng)?jiān)敿?xì)看完這篇文章再處理 。我相信它能幫到你。 分析前準(zhǔn)備: 前端網(wǎng)站地址:http://localhost:8080 服務(wù)端網(wǎng)址:http://localhost:59200? 首先保證服務(wù)端是沒(méi)有處理跨域的,其次,先用postman測(cè)試服務(wù)端接口是正常的 當(dāng)網(wǎng)站8080去訪

    2024年02月21日
    瀏覽(26)
  • 開(kāi)發(fā)環(huán)境中解決跨域問(wèn)題,nginx和tomcat

    有兩種方式,一種是在前端配置,一種是在后端配置 需要在前后端都配置 在前端新建axios的時(shí)候添加withCredentials: true 在后端添加

    2024年02月08日
    瀏覽(19)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包