libin1991 / libin_Blog

爬虫-博客大全
https://libin.netlify.com/
124 stars 17 forks source link

axios跨域设置 #492

Open libin1991 opened 6 years ago

libin1991 commented 6 years ago

背景

我们都知道浏览器有一个既核心也最基本的安全功能,即同源策略。同源分别是:协议,域名,端口。如果浏览器访问服务器不同源的话,就会访问不到数据。那开发中常常访问的服务器不同源,那么可以借助一个服务器当做中介来访问需要访问的服务器从而获得数据。因为同源策略是浏览器的安全机制,而服务器之间是不受此限制的。
之前vue-cli模板build文件夹下有dev-serve.js文件,可以在此文件中配置本地node服务器实现跨域,现在的模板下没有此文件,那我们该如何使用node跨域呢?不逼逼,上方法。

具体操作

  1. 在build文件夹下面新建一个dev-serve.js文件,其中添加代码如下:
'use strict'
const express = require('express')
const axios = require('axios')

module.exports = function () {
    let app = express()
    app.get('/api/getDiscList', (req, res) => {
        let url = '请求地址'
        axios.get(url, {
            headers: {
            //这里请求的是QQ音乐的接口,带上下面参数是为了骗服务器是自己人
                referer: 'https://c.y.qq.com/',
                host: 'c.y.qq.com'
            },
            params: req.query
        }).then((response) => {
            res.json(response.data)
        }).catch((e) => {
            console.log(e)
        })
    })

    app.listen(3000)
}
  1. 在build.js中引入并且运行
    只需要在最上面添加 require('./dev-serve.js')()
    当我们npm run dev运行项目的时候,node服务器就会启动自动监听3000端口

3.本地发送ajax请求,就可以通过node服务器访问到数据,请求我使用的是axios。请求如下:

import axios from 'axios'
function getDiscList() {

    const data = {
        //...请求参数
    }
    return axios.get('/api/getDiscList', {
        params: data
    }).then(res => {
        return Promise.resolve(res.data)
    })
}

请求到数据如下:

结语

如此就简单实现了本地node服务器跨域,在开发环境下是可以请求到数据,但是npm run build 打包成静态文件后就失效了。路还很长,还请各位不吝赐教。