解決vue項目中前后端交互的跨域問題、nginx代理配置方式
vue前后端交互的跨域問題、nginx代理配置
最近新接了一個項目,需要自己寫一個小demo和后端聯(lián)調(diào),第一次用自己寫的demo和后端聯(lián)調(diào),出現(xiàn)了問題。
問題:
Access to XMLHttpRequest at ‘http://192.168.0.78:8080’ from origin ‘http://192.168.0.79:2022’ has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.
vue向后端發(fā)送請求時時,被瀏覽器CORS阻止。
跨域指瀏覽器不允許當前頁面的所在的源去請求另一個源的數(shù)據(jù)。源指協(xié)議,端口,域名。只要這個3個中有一個不同就是跨域。
我們使用axios解決跨域問題。
1.安裝axios
在控制臺npm install axios
在main.js中加入這兩行代碼
import axios from 'axios' Vue.prototype.$axios = axios
大功告成,接下來就可以使用axios了。
2.解決跨域問題
首先在config下的index.js文件中添加代碼:
?proxyTable: {
? ? ? '/api': {
? ? ? ? target: 'http://192.168.0.79:2022',
? ? ? ? changeOrigin: true,
? ? ? ? pathRewrite: {
? ? ? ? ? '^/api': ''
? ? ? ? },
? ? ? ? onProxyReq: function (proxyReq, req, res) {
? ? ? ? ? // 實在不知道代理后的路徑,可以在這里打印出出來看看2
? ? ? ? ? console.log('原路徑1:' + req.originalUrl, '代理路徑1:' + req.path)
? ? ? ? }
? ? ? }
? ? },在vue-cli3的版本中,webpack的配置文件會被隱藏,所以我們找不到config文件夾,就只需要把地址配置到vue.config.js文件,配置內(nèi)容如下:
module.exports = {
? devServer: {
? ? // 端口號
? ? port: 3000,
? ? // 配置不同的后臺API地址
? ? proxy: {
? ? ? '/api': {
? ? ? ? target: 'http://192.168.0.84:2022',
? ? ? ? // ws: false,
? ? ? ? changeOrigin: true,
? ? ? ? pathRewrite: {
? ? ? ? ? '^/api': ''
? ? ? ? }
? ? ? }
? ? }
? }
}然后需要在main.js中添加:
axios.defaults.baseURL = '/api'?
接著配置nginx代理(conf/nginx.conf):
? ? server {
? ? ? ? # 監(jiān)聽端口
? ? ? ? listen ? ? ? 8080;
? ? ? ? # 監(jiān)聽域名
? ? ? ? server_name ?localhost;
?
? ? ? ? #charset koi8-r;
?
? ? ? ? #access_log ?logs/host.access.log ?main;
? ? ? ? #請求頭信息
? ? ? ? proxy_set_header X-Forwarded-Host $host;
? ? ? ? proxy_set_header X-Forwarded-Server $host;
? ? ? ? proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
? ? ? ? proxy_set_header Host $host;
?
location /api ?{
?? ?# 代理的地址
?? ?proxy_pass http://192.168.0.79:2022/api;
?? ?proxy_connect_timeout 600;
?? ?proxy_read_timeout 600;
?? ??? ?}然后問題就成功解決啦
前后端分離項目的跨域問題及解決
跨域簡述
1.問題描述
這里前端vue項目的端口號為9000,后端springboot項目的端口號為8080

2.什么是跨域
當一個請求url的協(xié)議、域名、端口三者之間任意一個與當前頁面url不同即為跨域
| 當前頁面url | 被請求頁面url | 是否跨域 | 原因 |
|---|---|---|---|
| http://www.demo.com/ | http://www.demo.com/index.html | 否 | 同源(協(xié)議、域名、端口號相同) |
| http://www.demo.com/ | https://www.demo.com/ | 是 | 協(xié)議不同(http/https) |
| http://www.demo.com/ | http://www.study.com/ | 是 | 主域名不同(demo/study) |
| http://www.demo.com/ | http://test.demo.com/ | 是 | 子域名不同(www/test) |
| http://www.demo.com:8080/ | http://www.demo.com:8081/ | 是 | 端口號不同(8080/8081) |
3.出現(xiàn)跨域問題的原因
跨域問題是出于瀏覽器的同源策略限制。同源策略(Sameoriginpolicy)是一種約定,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,則瀏覽器的正常功能可能都會受到影響。
可以說Web是構(gòu)建在同源策略基礎之上的,瀏覽器只是針對同源策略的一種實現(xiàn)。
同源策略會阻止一個域的javascript腳本和另外一個域的內(nèi)容進行交互。所謂同源(即指在同一個域)就是兩個頁面具有相同的協(xié)議(protocol),主機(host)和端口號(port)。
解決辦法
1.第一種解決辦法:后端配置跨域(spring boot設置方式)
第一步:在后端的WebMvcConfig配置類中進行配置
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
/**
* 跨域配置
* 前后端分離必須配置,出現(xiàn)跨域之后前端無法訪問后端接口
* @param registry
*/
@Override
public void addCorsMappings(CorsRegistry registry) {
// 允許跨域訪問資源定義: /rest/ 所有資源
registry.addMapping(GlobalConstant.REST_URL_PREFIX +"/**")
// 只允許本地的指定端口訪問
// .allowedOrigins("http://localhost:8080");
// // 允許發(fā)送Cookie
.allowCredentials(true);
// // 允許所有方法
// .allowedMethods("GET", "POST", "PUT", "DELETE", "HEAD");
}
}
第二步:在vue項目src目錄下的http包中的config.js進行配置攜帶憑證(cookie)

注意:這里是因為我需要前端發(fā)送憑證(cookie)所以要配兩步;如果不需要攜帶cookie,可以將第二步忽略,并且將第一步中的allowCredentials(true);注釋掉。
2.第二種解決辦法:前端配置代理(vue項目)
第一步:在config/index.js 文件,配置proxyTable

proxyTable: {
'/api': {
target: 'http://127.0.0.1:8080', // 請求后臺的真實路徑,這里是我本地啟動的一個后臺項目
changeOrigin: true, //
pathRewrite: {
'^/api': '' // 重寫路徑
}
},
},
第二步:在config/dev.env.js文件中加上一句

module.exports = merge(prodEnv, {
NODE_ENV: '"development"',
API: '"/api"' // 加入這一句
})
因為這里我配的是全局路徑,所以還要在global.js里配置全局路徑

export const baseUrl = process.env.API
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Vue自定義過濾器格式化數(shù)字三位加一逗號實現(xiàn)代碼
這篇文章主要介紹了Vue自定義過濾器格式化數(shù)字三位加一逗號的實現(xiàn)代碼,需要的朋友可以參考下2018-03-03
vue項目開發(fā)中setTimeout等定時器的管理問題
這篇文章主要介紹了vue項目開發(fā)中setTimeout等定時器的管理問題,需要的朋友可以參考下2018-09-09
vue實現(xiàn)表格動態(tài)嵌入折線圖的繪制代碼
這篇文章給大家介紹了vue實現(xiàn)表格動態(tài)嵌入折線圖的繪制方法,文中有詳細完整的代碼示例攻大家參考,對大家的學習或工作有一定的參考價值,需要的朋友可以參考下2023-10-10
解決Vue2.0 watch對象屬性變化監(jiān)聽不到的問題
今天小編就為大家分享一篇解決Vue2.0 watch對象屬性變化監(jiān)聽不到的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09

