亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解決vue項(xiàng)目中前后端交互的跨域問(wèn)題、nginx代理配置方式

 更新時(shí)間:2022年09月09日 10:29:52   作者:芝士焗紅薯  
這篇文章主要介紹了解決vue項(xiàng)目中前后端交互的跨域問(wèn)題、nginx代理配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue前后端交互的跨域問(wèn)題、nginx代理配置

最近新接了一個(gè)項(xiàng)目,需要自己寫一個(gè)小demo和后端聯(lián)調(diào),第一次用自己寫的demo和后端聯(lián)調(diào),出現(xiàn)了問(wèn)題。

問(wè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ā)送請(qǐng)求時(shí)時(shí),被瀏覽器CORS阻止。

跨域指瀏覽器不允許當(dāng)前頁(yè)面的所在的源去請(qǐng)求另一個(gè)源的數(shù)據(jù)。源指協(xié)議,端口,域名。只要這個(gè)3個(gè)中有一個(gè)不同就是跨域。

我們使用axios解決跨域問(wèn)題。

1.安裝axios

在控制臺(tái)npm install axios

在main.js中加入這兩行代碼

import axios from 'axios'
Vue.prototype.$axios = axios

大功告成,接下來(lái)就可以使用axios了。

2.解決跨域問(wèn)題

首先在config下的index.js文件中添加代碼:

?proxyTable: {
? ? ? '/api': {
? ? ? ? target: 'http://192.168.0.79:2022',
? ? ? ? changeOrigin: true,
? ? ? ? pathRewrite: {
? ? ? ? ? '^/api': ''
? ? ? ? },
? ? ? ? onProxyReq: function (proxyReq, req, res) {
? ? ? ? ? // 實(shí)在不知道代理后的路徑,可以在這里打印出出來(lái)看看2
? ? ? ? ? console.log('原路徑1:' + req.originalUrl, '代理路徑1:' + req.path)
? ? ? ? }
? ? ? }
? ? },

在vue-cli3的版本中,webpack的配置文件會(huì)被隱藏,所以我們找不到config文件夾,就只需要把地址配置到vue.config.js文件,配置內(nèi)容如下:

module.exports = {
? devServer: {
? ? // 端口號(hào)
? ? port: 3000,
? ? // 配置不同的后臺(tái)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;
? ? ? ? #請(qǐng)求頭信息
? ? ? ? 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;
?? ??? ?}

然后問(wèn)題就成功解決啦 

前后端分離項(xiàng)目的跨域問(wèn)題及解決

跨域簡(jiǎn)述

1.問(wèn)題描述

這里前端vue項(xiàng)目的端口號(hào)為9000,后端springboot項(xiàng)目的端口號(hào)為8080

2.什么是跨域

當(dāng)一個(gè)請(qǐng)求url的協(xié)議、域名、端口三者之間任意一個(gè)與當(dāng)前頁(yè)面url不同即為跨域

當(dāng)前頁(yè)面url被請(qǐng)求頁(yè)面url是否跨域原因
http://www.demo.com/http://www.demo.com/index.html同源(協(xié)議、域名、端口號(hào)相同)
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/端口號(hào)不同(8080/8081)

3.出現(xiàn)跨域問(wèn)題的原因

跨域問(wèn)題是出于瀏覽器的同源策略限制。同源策略(Sameoriginpolicy)是一種約定,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,則瀏覽器的正常功能可能都會(huì)受到影響。

可以說(shuō)Web是構(gòu)建在同源策略基礎(chǔ)之上的,瀏覽器只是針對(duì)同源策略的一種實(shí)現(xiàn)。

同源策略會(huì)阻止一個(gè)域的javascript腳本和另外一個(gè)域的內(nèi)容進(jìn)行交互。所謂同源(即指在同一個(gè)域)就是兩個(gè)頁(yè)面具有相同的協(xié)議(protocol),主機(jī)(host)和端口號(hào)(port)。

解決辦法

1.第一種解決辦法:后端配置跨域(spring boot設(shè)置方式)

第一步:在后端的WebMvcConfig配置類中進(jìn)行配置

@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
    /**
     * 跨域配置
     *       前后端分離必須配置,出現(xiàn)跨域之后前端無(wú)法訪問(wèn)后端接口
     * @param registry
     */
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        // 允許跨域訪問(wèn)資源定義: /rest/ 所有資源
        registry.addMapping(GlobalConstant.REST_URL_PREFIX +"/**")
                // 只允許本地的指定端口訪問(wèn)
//                .allowedOrigins("http://localhost:8080");
//                // 允許發(fā)送Cookie
                .allowCredentials(true);
//                // 允許所有方法
//                .allowedMethods("GET", "POST", "PUT", "DELETE", "HEAD");
    }
}

第二步:在vue項(xiàng)目src目錄下的http包中的config.js進(jìn)行配置攜帶憑證(cookie)

注意:這里是因?yàn)槲倚枰岸税l(fā)送憑證(cookie)所以要配兩步;如果不需要攜帶cookie,可以將第二步忽略,并且將第一步中的allowCredentials(true);注釋掉。

2.第二種解決辦法:前端配置代理(vue項(xiàng)目)

第一步:在config/index.js 文件,配置proxyTable

proxyTable: {
      '/api': {
        target: 'http://127.0.0.1:8080', //  請(qǐng)求后臺(tái)的真實(shí)路徑,這里是我本地啟動(dòng)的一個(gè)后臺(tái)項(xiàng)目
        changeOrigin: true, //
        pathRewrite: {
          '^/api': '' // 重寫路徑
        }
      },
    },

第二步:在config/dev.env.js文件中加上一句

module.exports = merge(prodEnv, {
  NODE_ENV: '"development"',
  API: '"/api"' // 加入這一句
})

因?yàn)檫@里我配的是全局路徑,所以還要在global.js里配置全局路徑

export const baseUrl = process.env.API

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

最新評(píng)論