zoukankan      html  css  js  c++  java
  • vue*解决跨域

    问题描述
     在项目开发的时候,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行接口联调,但是当我们现在使用vue-cli进行项目打包的时候,我们在本地启动服务器后,比如本地开发服务下是 http://localhost:8080 这样的访问页面,但是我们的接口地址是 http://xxxx.com/save/index 这样的接口地址,我们这样直接使用会存在跨域的请求,导致接口请求不成功,因此我们需要在打包的时候配置一下,我们进入 config/index.js 代码下如下配置即可:
    
    dev: {
    
        // 静态资源文件夹
        assetsSubDirectory: ‘static‘,
    
        // 发布路径
        assetsPublicPath: ‘/‘,
    
        // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
        // 例如将‘localhost:8080/api/xxx‘代理到‘www.example.com/api/xxx‘
        // 使用方法:https://vuejs-templates.github.io/webpack/proxy.html
        proxyTable: {
          ‘/api‘: {
            target: ‘http://xxxxxx.com‘, // 接口的域名
            // secure: false,  // 如果是https接口,需要配置这个参数
            changeOrigin: true, // 如果接口跨域,需要进行这个参数配置
            pathRewrite: {
              ‘^/api‘: ‘‘
            }
          }
        },
    
        // 本地访问 http://localhost:8080
        host: ‘localhost‘, // can be overwritten by process.env.HOST
    
    解释
     接口地址原本是 /save/index,但是为了匹配代理地址,在前面加一个 /api,  因此接口地址需要写成这样的即可生效 /api/save/index。
    
     注意: ‘/api‘ 为匹配项,target 为被请求的地址,因为在 ajax 的 url 中加了前缀 ‘/api‘,而原本的接口是没有这个前缀的,所以需要通过 pathRewrite 来重写地址,将前缀 ‘/api‘ 转为 ‘/‘。如果本身的接口地址就有 ‘/api‘ 这种通用前缀,就可以把 pathRewrite 删掉。
  • 相关阅读:
    使用手机游戏的新闻推送
    win8.1 64位环境建设android开发环境
    LeetCode: Multiply Strings. Java
    Thread.join()分析方法
    字幕效果的幻灯片出现在网站上的图片
    JAVA技术交流群
    Android使得手机拍照功能的发展(源共享)
    领导基础课程
    Mysql开启远程连接方法
    mysql远程连接命令
  • 原文地址:https://www.cnblogs.com/lml-lml/p/9441354.html
Copyright © 2011-2022 走看看