国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > Nginx > 正文

nginx解決跨域問題的實例方法

2024-08-30 12:24:22
字體:
來源:轉載
供稿:網友

前后端分離,使用nginx解決跨域問題

前端:vue.js+nodejs+webpack

后臺:SpringBoot

反向代理服務器:nginx

思想:將前端代碼打包,讓nginx指向靜態資源,nginx對后臺請求進行轉發。

1、將前端代碼打包:

npm run build

會生成一個dist文件夾。包含一個index.html文件和一個static文件夾,路徑以我本地為例:

/Users/xxx/ideaProjects/webtest/dist

2、打開

/usr/local/etc/nginx目錄下的nginx.conf,在server中添加如下:

listen  80; #原為8080,避免沖突,更改為80  server_name localhost;   #charset koi8-r;   #access_log logs/host.access.log main;    location / {   root /Users/xxx/ideaProjects/webtest/dist;   index index.html;       # 此處用于處理 Vue、Angular、React 使用H5 的 History時 重寫的問題   if (!-e $request_filename) {    rewrite ^(.*) /index.html last;    break;   }  }    # 代理服務端接口  location /api/ {   proxy_pass http://localhost:8080/;# 代理接口地址  }

測試

前端發送請求:http://localhost/test ,vue-router將其重定向為http://localhost/api/demo/1,實際訪問是http://localhost:8080/demo/1。

直接向后臺發送請求:訪問http://localhost/api/demo/1,實際訪問是:http://localhost:8080/demo/1

內容擴展思考:

1).
# 代理服務端接口

location /api/ {proxy_pass http://localhost:8080/;# 代理接口地址}

代理接口地址只到8080,那么他會自動將后臺項目的名稱加上??? 比如接口是http://148.70.110.87:8080/項目名稱/方法名稱 。。。

2).js 中是這樣請求的 ,nginx是按照您上面的配置,但是請求出錯http://148.70.110.87/api/index2 404 (Not Found)

axios.post('/api/index2').then( (response) =>{console.log(response);}).catch( (error)=> {console.log(error);});

3).您的第三個步驟,測試,實在看不懂要是能有相關的代碼就好了

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阆中市| 通海县| 九龙城区| 金阳县| 洛南县| 青川县| 太保市| 临海市| 巴林左旗| 邵东县| 天柱县| 黔南| 泸州市| 南宁市| 濮阳市| 江西省| 西藏| 荆州市| 武威市| 成都市| 庄浪县| 景东| 馆陶县| 宜春市| 黄石市| 孝感市| 响水县| 嘉定区| 克什克腾旗| 长治县| 无极县| 环江| 北海市| 荣成市| 吕梁市| 兴文县| 衡南县| 湖口县| 临沭县| 通河县| 阿拉善左旗|