报错:
前台控制台报一下错:
Access to XMLHttpRequest at 'http://127.0.0.1:8000/api/chouti/book/' from origin 'http://localhost:8
修改的地方有:
后端:
备注:这里采用的python django进行开发的(只适用这种环境 思路可以借鉴)
Django 报错,跨域请求出现问题。
在settings.py中添加
#设置可跨域范围(注意位置)
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_ALLOW_ALL = True
#定义跨域中间件(注意位置)
'corsheaders.middleware.CorsMiddleware',
前端:
备注:这里采用的是vue2进行开发,还需要特别说明的是我对axsio进行了封装
即大家常说的request.js 封装代码如下:
import Vue from 'vue' import axios from "axios"; Vue.config.productionTip=false; Vue.prototype.axios=axios; const http=axios.create({ baseURL:"http://127.0.0.1:8000/api", #这是对api所在的服务进行请求获得数据 timeout:10000, withCredentials: true, headers: { 'Content-Type': 'application/json; charset=utf-8' } }); http.interceptors.request.use(function (config) { return config; },function (error) { return Promise.reject(error) }); http.interceptors.response.use(function (response) { return response; },function (error) { return Promise.reject(error) }); export default http
对api也进行封装(如有多个按照这种模式往下写即可)
import http from "@/axsio/axsio"; export const getdata=()=>{ return http.get('/chouti/book/')#这是对我们要请求的接口的详细地址 }
在vue.config.js中加入了这些代码:
module.exports={ devServer:{ proxy:{ '/api':{ target:"http://127.0.0.1:8000/api", changeOrigin:true, pathRewrite:{ '/api':"" } } } } }
在main.js中引入这一行
axios.defaults.baseURL='/api'; //对与跨域问题 用vue.config.js解决 这是重要代码
转载:https://blog.csdn.net/testManger/article/details/128378680
查看评论