vue中怎么解决跨域问题_vue本地访问服务器跨域

vue中怎么解决跨域问题_vue本地访问服务器跨域vue项目中如何解决跨域问题跨域的含义​ 跨域的本质就是浏览器基于同源策略的一种安全手段。所谓同源就是必须有以下三个相同点:协议相同、主机相同、端口相同。如果其中有一项不同,即出现非同源请求,就会产生跨域。​ 跨域实际上是浏览器的限制,开发中使用postman请求接口能够获得数据就印证了跨域是浏览器的限制这个问题。解决方法​ 一般前端中解决跨域问题的方法有JSONP,CROS,Proxy等,这里我们主要讲解一下在vue中常用的CROS和Proxy方法。CROS​ CROS是Cros

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

vue项目中如何解决跨域问题

跨域的含义

​ 跨域的本质就是浏览器基于同源策略的一种安全手段。所谓同源就是必须有以下三个相同点:协议相同、主机相同、端口相同。如果其中有一项不同,即出现非同源请求,就会产生跨域。

​ 跨域实际上是浏览器的限制,开发中使用 postman请求接口能够获得数据就印证了跨域是浏览器的限制这个问题。

解决方法

​ 一般前端中解决跨域问题的方法有 JSONP,CROS,Proxy等,这里我们主要讲解一下在 vue中常用的 CROS和 Proxy方法。

CROS

​ CROS是 Cross-Origin Resource Sharing的缩写,翻译过来就是跨域资源共享的意思。它由一系列传输的HTTP头组成,这些HTTP头会决定浏览器是否阻止前端 JavaScript代码获取跨域请求的响应。

​ CORS的实现比较简单方便,只需要增加一些 HTTP头,让服务器能声明允许的访问来源。只要后端实现了 CROS就实现了跨域。

Proxy

​ Proxy也称为网络代理,是一种特殊的网络服务,允许一个客户端通过这个服务与另一个网络终端(一般为服务器)进行非直接的连接,一些网关、路由器等网络设备就具有网络代理功能。一般认为代理服务有利于保障网络终端的隐私或安全,防止服务器被攻击。

​ 在 vue项目中实现该功能,有以下几种方法:

  1. 方法一:如果是通过 vue-cli脚手架搭建项目,可以通过 webpack设立一个本地服务器作为请求的代理对象,通过该服务器转发请求至目标服务器,得到结果后再转发给前端。但是在最终项目发布上线时,如果 web应用和接口服务器不在一起仍会产生跨域问题。解决方法是,可以在vue.config.js文件中新增以下代码:
module.exprots = { 
   
    devServer: { 
   
        host: '127.0.0.1', // 本地地址
        port: 8084, // 端口号
        open: true, // 配置项目在启动时自动在浏览器打开
        proxy: { 
   
            '/api' : { 
    // '/api'是代理标识,一般是每个接口前的相同部分
                target: "http://xxx.xxx.xx.xx:8080", // 请求地址,一般是服务器地址
                changeOrigin: true, // 是否进行跨域
                pathRewrite: { 
    // pathRewrite的作用是把请求接口中的 '/api'替换掉,一般是替换为空""
                    '^/api':""
                }
            }
        }
    }
}
  1. 方法二:通过服务端实现代理请求转发。以 express框架为例:
var express = require('express');
const proxy = require('http-proxy-middleware')
const app = express()
app.use(express.static(_dirname+'/'))
app.use('/api',proxy({ 
   
    traget:'http://localhost:8080',
    changeOrigin: false
}));
module.exprots = app
  1. 方法三:通过配置 nginx实现代理(nginx是一个web服务器,需要到相应的官网进行下载,且进行相应的配置):
server { 
   
    listen 80; #监听的端口号
    server_name xxx.xxx.com; #当前服务器的域名
    location / { 
   
        root /var/www/html;
        index index.html index.html;
        try_files $uri $uri/ /index.html;
    }
    location /api { 
    #请求头中带有 '/api'便会进行代理
        proxy_pass htpp://127.0.0.1:3000;
        proxy_redirect off;
        proxy_set_header Host  $host;
        proxy_set_header X-Real-IP  $remote_addr;
        proxy_set_header X-Forwarded-For  $proxy_add_x_forwarded_for;
    }
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/193645.html原文链接:https://javaforall.net

(0)
上一篇 2025年11月21日 下午1:43
下一篇 2025年11月21日 下午2:15


相关推荐

  • 周末日记

    周末日记书上说人要长大三次第一次是在发现自己不是世界中心的时候第二次是在发现即使再怎么努力终究还是有些事令人无能为力的时候第三次是在明知道有些事可能会无能为力但还是会尽力争取的时候

    2022年6月4日
    51
  • java读取数据库_jsp怎么显示数据库数据

    java读取数据库_jsp怎么显示数据库数据importlmdbimportos,sysdefinitialize():env=lmdb.open(“lmdb_dir”)#如果没有就创建lmdb_dir目录returnenvdefinsert(env,sid,name):txn=env.begin(write=True)txn.put(str(sid).encode(),name.encode())txn.commit()defdelete(env…

    2026年4月15日
    6
  • 快乐12下载安装_四川快乐12APP下载

    快乐12下载安装_四川快乐12APP下载安装步骤双击setup.exe以运行此程序点击Next选中同意协议,然后点击Next直接点击Next选中64-bitSE点击Next点击Browse可以将C改成D以将此软件安装在D盘,点击Ok8.点击Next9.点击Next10.点击Next此步忘记截图了点击Finish此步不用输入任何内容,直接点击Cancel,然后点击确定。1…

    2022年10月21日
    2
  • sql镶嵌查询_SQL 嵌套查询

    sql镶嵌查询_SQL 嵌套查询说到嵌套查询 首先得理解嵌套查询是什么意思 简单来说就是 一个查询语句可以嵌套在另外一个查询语句的 where 子句中 外层的查询称为父查询 主查询 内层的查询称为子查询 从查询 嵌套查询的工作方式是由内向外的 即先进行内层查询 外层查询则利用内层查询的结果集作为条件进行查询 当然 嵌套查询不仅仅是 select 语句的专属 它还可以用在 update insert delete 语句中 如 update

    2026年3月26日
    1
  • sfm点云代码_SfM实现过程分析

    sfm点云代码_SfM实现过程分析昨天立了flag,今天要学SfM过程,大概看了看SfM的各个文件目录,build&make出来的linux-release-x86大概叫这个名字的文件夹里面有很多可执行文件,直接根据文档里给的参数跑就可以,要搞源码的话实在是搞不起,太复杂,太庞大了。下面的代码是从他给出的easytouse的python脚本中截取的核心代码,注释的也很赞,清晰明确。SfMglobalpipeline…

    2022年6月20日
    44
  • 数组长度计算_c语言计算数组长度的函数

    数组长度计算_c语言计算数组长度的函数(1)sizeof方法:sizeof(数组名)/sizeof(数组类型名)说明:数组占用字节除以数组类型所占字节,结果为数组元素个数(2)strlen说明:strlen,求字符串有效长度方法

    2022年8月5日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号