前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >解决Vue跨域的问题

解决Vue跨域的问题

原创
作者头像
子润先生
修改2021-06-23 09:58:50
9910
修改2021-06-23 09:58:50
举报

如果你的前端应用和后端 API 服务器没有运行在同一个主机上,你需要在开发环境下将 API 请求代理到 API 服务器。这个问题可以通过 vue.config.js 中的 devServer.proxy 选项来配置。

vue 请求后端,涉及到跨域问题,我后端用的是 swoft 框架,监听18306端口,前端 vue 监听8080端口。

swoft 中新增一个跨域中间件:

代码语言:javascript
复制
<?php declare(strict_types=1);

namespace App\Http\Middleware;

use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\RequestHandlerInterface;
use Swoft\Bean\Annotation\Mapping\Bean;
use Swoft\Context\Context;
use Swoft\Http\Server\Contract\MiddlewareInterface;

/**
 * @Bean()
 */
class CorsMiddleware implements MiddlewareInterface
{
    /**
     * Process an incoming server request.
     * @param ServerRequestInterface $request
     * @param RequestHandlerInterface $handler
     * @return ResponseInterface
     * @inheritdoc
     */
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
    {
        if ('OPTIONS' === $request->getMethod()) {
            $response = Context::mustGet()->getResponse();
            return $this->configResponse($response);
        }
        $response = $handler->handle($request);
        return $this->configResponse($response);
    }

    private function configResponse(ResponseInterface $response)
    {
        return $response
            ->withHeader('Access-Control-Allow-Origin', '*')
            ->withHeader('Access-Control-Allow-Headers', 'X-Requested-With, Content-Type, Accept, Origin, Authorization')
            ->withHeader('Access-Control-Allow-Credentials', true)
            ->withHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, PATCH, OPTIONS');
    }
}

注册全局中间件,配置文件: app/bean.php

代码语言:javascript
复制
'httpDispatcher'    => [
        // Add global http middleware
        'middlewares'      => [
            \App\Http\Middleware\CorsMiddleware::class
        ],
],

vue 设置代理,配置文件: vue.config.js

代码语言:javascript
复制
module.exports = {
  devServer: {
    proxy: {
      '/api': {
        target: 'http://127.0.0.1:18306',
        // ws: true,
        changeOrigin: true
      }
    }
  }
}

axios 请求:

代码语言:javascript
复制
this.$axios.post('api/user/login', values).then(res => {
        console.log(res)
})

结果报了一个跨域错误:

代码语言:javascript
复制
Proxy error: Could not proxy request

查询了官方文档,也在网上查询了很久,始终没有答案,最后发现,这是犯了一个低级的错误,我的环境是在 docker 下,docker 下容器之间通信,需要使用容器分配的虚拟ip地址,然后修改 vue.config.js 配置文件:

代码语言:javascript
复制
module.exports = {
  devServer: {
    proxy: {
      '/api': {
        target: 'http://172.17.0.3:18306',
        // ws: true,
        changeOrigin: true
      }
    }
  }
}

最后成功了:

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档