常用发送ajax请求的方法
//server1.js
const express = require('express')
const app = express()
app.use((request,response,next)=>{
console.log('有人请求服务器1了');
// console.log('请求来自于',request.get('Host'));
// console.log('请求的地址',request.url);
next()
app.get('/students',(request,response)=>{
const students = [
{id:'001',name:'tom',age:18},
{id:'002',name:'jerry',age:19},
{id:'003',name:'tony',age:120},
response.send(students)
app.listen(5000,(err)=>{
if(!err) console.log('服务器1启动成功了,请求学生信息地址为:http://localhost:5000/students');
//server2.js
const express = require('express')
const app = express()
app.use((request,response,next)=>{
console.log('有人请求服务器2了');
next()
app.get('/cars',(request,response)=>{
const cars = [
{id:'001',name:'奔驰',price:199},
{id:'002',name:'马自达',price:109},
{id:'003',name:'捷达',price:120},
response.send(cars)
app.listen(5001,(err)=>{
if(!err) console.log('服务器2启动成功了,请求汽车信息地址为:http://localhost:5001/cars');
服务器1为:http://localhost:5000/students
服务器2地址为:http://localhost:5001/cars
//App.vue
<template>
<button @click="getStudents">获取学生信息</button>
</div>
</template>
<script>
import axios from 'axios'
export default {
name:'App',
methods:{
getStudents:function(){
axios.get('http://localhost:5000/students').then(
response=>{
console.log('请求成功',response.data)
error=>{
console.log('请求失败',error.message)
</script>
这样子,会有跨域问题,当前处于http://localhost:8080,请求服务器1为:http://localhost:5000/students
什么是跨域?
浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域
主域名不同
http://www.baidu.com/index.html
http://www.sina.com/test.js
子域名不同
http://www.666.baidu.com/index.html
http://www.555.baidu.com/test.js
域名和域名ip
http://www.baidu.com/index.html
http://180.149.132.47/test.js
http://www.baidu.com:8080/index.html
http://www.baidu.com:8081/test.js
http://www.baidu.com:8080/index.html
https://www.baidu.com:8080/test.js
1、端口和协议的不同,只能通过后台来解决
2、localhost和127.0.0.1虽然都指向本机,但也属于跨域
cors 写服务器的人在写服务器时给响应信息加上特殊的响应头
jsonp
代理服务器 代理服务器在中间出现,代理服务器所处位置和请求数据端位置一样,请求方向代理服务器要数据,代理服务器向服务器要数据,然后原路返回。代理服务器和服务器之间没有跨域问题,是通过http请求(ngnix、vue-cli)
vue配置代理
//vue.config.js
module.exports = {
pages: {
index: {
entry: 'src/main.js',
lintOnSave:false,//关闭语法检查,
//配置代理服务器
devServer:{
proxy:'http://localhost:5000'//只写到端口号就行
//App.vue
<template>
<button @click="getStudents">获取学生信息</button>
</div>
</template>
<script>
import axios from 'axios'
export default {
name:'App',
methods:{
getStudents:function(){
axios.get('http://localhost:8080/students').then(
response=>{
console.log('请求成功',response.data)
error=>{
console.log('请求失败',error.message)
</script>
优点:配置简单,请求资源时直接发给前端(8080)即可。
缺点:不能配置多个代理,不能灵活的控制请求是否走代理。
工作方式:若按照上述配置代理,当请求了前端不存在的资源时,那么该请求会转发给服务器 (优先匹配前端资源),如果前端有的话,代理服务器不会转发请求给服务器
协议名、主机名、端口号后面加前缀api,灵活控制走不走本地,有就让代理服务器转发,但是给服务器的地址不能带前缀
//vue.config.js
module.exports = {
pages: {
index: {
entry: 'src/main.js',
lintOnSave:false,//关闭语法检查,
devServer:{
proxy:{
'/api':{
//target:'<url>',
target:'http://localhost:5000',
pathRewrite:{'^/api':''},//正则,重写路径,匹配所有有/api的字符串替换成空
ws:true,//用于支持websocket
changeOrigin:true //如果为true,告诉服务器来自和服务器同一位置(http://localhost:5000),其实就是请求头中的host信息。
'/api2':{
//target:'<url>',
target:'http://localhost:5000',
pathRewrite:{'^/api2':''},
ws:true,//用于支持websocket
changeOrigin:true //用于控制请求中的host值
//App.vue
<template>
<button @click="getStudents">获取学生信息</button>
</div>
</template>
<script>
import axios from 'axios'
export default {
name:'App',
methods:{
getStudents:function(){
axios.get('http://localhost:8080/api/students').then(
response=>{
console.log('请求成功',response.data)
error=>{
console.log('请求失败',error.message)
</script>
优点:可以配置多个代理,且可以灵活的控制请求是否走代理。
缺点:配置略微繁琐,请求资源时必须加前缀。
vue-resource
和axios的使用相同,在vue1.0时较多使用
//main.js
//引入Vue
import Vue from 'vue'
//引入App
import App from './App.vue'
//引入插件
import vueResource from 'vue-resource'
//关闭Vue的生产提示
Vue.config.productionTip = false
//使用插件
Vue.use(vueResource)
//创建vm
new Vue({
el:'#app',
render: h => h(App),
beforeCreate() {
Vue.prototype.$bus = this
this.$http.get(`https://api.github.com/search/users?q=${this.keyWord}`).then(
response => {
console.log('请求成功了')
//请求成功后更新List的数据
this.$bus.$emit('updateListData',{isLoading:false,errMsg:'',users:response.data.items})
error => {
//请求后更新List的数据
this.$bus.$emit('updateListData',{isLoading:false,errMsg:error.message,users:[]})