vue+axios post请求

vue+axios post请求

axios 全局默认配置

axios.defaults.baseURL = 'https://api.example.com';
axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';

默认情况下,axios将JavaScript对象序列化为JSON。 要以应用程序/ x-www-form-urlencoded格式发送数据,您可以使用以下选项之一。

axios 发送post请求

1. 浏览器

在浏览器中,您可以使用URLSearchParams API,如下所示:

var params = new URLSearchParams();
params.append('param1', 'value1');
params.append('param2', 'value2');
axios.post('/foo', params);

注意: 所有浏览器都不支持URLSearchParams,但是有一个polyfill可用(确保polyfill全局环境)。

polyfill就是一个用在浏览器API上的shim(是一个库,它将一个新的API引入到一个旧的环境中,而且仅靠旧环境中已有的手段实现).我们通常的做法是先检查当前浏览器是否支持某个API,如果不支持的话就加载对应的polyfill.然后新旧浏览器就都可以使用这个API了。

axios 依赖本机要支持ES6 Promise实现。 如果您的环境不支持ES6 Promises,您可以使用polyfill。

或者,您可以使用qs插件地址库对数据进行编码(将axios发送的数据格式转换为form-data格式):

//npm install axios的时候默认会安装qs
// qs相关的问题请搜索"nodejs qs"或者看这里https://www.npmjs.com/package/qs
import qs from 'qs';

// 将请求数据转换为form-data格式
// 这里不用qs,用FormData也可以,不赘述
var data = qs.stringify({
  currentPage: "0",
  pageSize: "10",
  type: "1",
});

axios.post('/url', data)
.then(function (response) {
})
.catch(function (error) {
});
2. Node.js

在node.js中,可以使用querystring模块(也可以使用qs库。),如下所示:

var querystring = require('querystring');
axios.post('http://something.com/', querystring.stringify({ foo: 'bar' });

用axios发送post请求去登录,能成功返回数据,但是用作权限验证的cookie就是没有保存,经查阅,axios 默认不发送cookie,跨域也是一个原因,需要全局设置:文档地址

axios.defaults.withCredentials = true 

axios跨域问题

Vue-cli proxyTable 解决开发环境的跨域问题
在vue-cli的config文件index.js里有一个参数叫proxyTable

proxyTable: {
  '/list': {
    target: 'http://api.xxxxxxxx.com',
    changeOrigin: true,
    pathRewrite: {
      '^/list': '/list'
    }
  }
}

changeOrigin参数接收一个布尔值,如果设置为true,那么本地会虚拟一个服务端接收你的请求并代你发送该请求,这样就不会有跨域问题了,当然这只适用于开发环境。
相关资料:
API proxy
http-proxy-middleware
package

### 回答1: 为了在Vue中使用axios发送请求,并在请求头中添加Cookie,可以按照以下步骤操作: 1. 首先,需要在Vue项目中安装axios。使用以下命令安装axios: ``` npm install axios ``` 2. 在Vue项目的入口文件(一般是main.js)中,引入axios,并将其挂载到Vue实例上: ```javascript import axios from 'axios'; Vue.prototype.$http = axios; ``` 3. 在发送请求的组件中,可以使用`this.$http`来调用axios发送请求。在发送请求时,可以通过设置请求头来添加Cookie。例如,可以使用axios的`defaults`属性来设置全局的请求头,如下所示: ```javascript this.$http.defaults.headers.common['Cookie'] = 'your_cookie_value'; ``` 4. 在具体的请求中,可以使用axios的`get`、`post`等方法发送请求。例如,发送一个GET请求并带有Cookie: ```javascript this.$http.get('/api/your_url').then(response => { // 处理响应 }).catch(error => { // 错误处理 }); ``` 以上就是在Vue中使用axios发送请求,并在请求头中添加Cookie的方法。通过设置请求头,可以在服务器端获取到Cookie并进行相应的处理。 ### 回答2: 在Vue中使用Axios发送请求时,在请求头上添加cookie可以通过在Axios配置中设置headers属性的方式来实现。 首先,在Vue项目中安装并引入Axios库,并创建一个Axios的实例: ``` import axios from 'axios' const instance = axios.create() ``` 然后,在发送请求前,通过Axios的拦截器设置请求头: ``` instance.interceptors.request.use((config) => { // 在请求头中添加cookie config.headers.Cookie = 'your cookie value' return config }) ``` 在上述代码中,通过`config.headers.Cookie`属性来设置请求头的cookie值,将'your cookie value'替换为你实际需要携带的cookie值。 最后,在需要发送请求的地方使用这个实例进行请求: ``` instance.get('your request url') .then(response => { console.log(response.data) }) .catch(error => { console.log(error) }) ``` 在这个例子中,使用Axios的`get`方法发送一个GET请求,并在成功或失败时打印出相应的结果。 这样,当发送请求时,Axios会在请求头中添加我们设置的cookie,完成请求的发送。 ### 回答3: 在Vue中使用axios发送请求并在请求头上添加cookie,你可以按照以下步骤进行操作: 1. 首先,确保你已经安装了axiosvue-cookie插件。你可以通过以下命令来安装它们: ``` npm install axios npm install vue-cookie ``` 2. 在你的Vue项目中,你需要在main.js文件中导入和配置axiosvue-cookie。打开main.js文件,并添加以下代码: ```javascript import axios from 'axios'; import Vue from 'vue'; import VueCookie from 'vue-cookie'; Vue.use(VueCookie); axios.defaults.withCredentials = true; // 配置axios请求拦截器,添加请求axios.interceptors.request.use(config => { const token = VueCookie.get('your_cookie_name'); if (token) { config.headers.Cookie = `your_cookie_name=${token}`; } return config; }); Vue.prototype.$axios = axios; ``` 3. 在需要发送请求的组件中,你可以使用以下代码: ```javascript this.$axios.get('your_url') .then(response => { // 处理响应数据 }) .catch(error => { // 处理请求错误 }); ``` 请注意,以上代码默认使用了名为"your_cookie_name"的cookie,你需要将其替换为你自己的cookie名称。同时,请确保你的服务器在响应中包含了相应的Access-Control-Allow-Origin头信息,以允许跨域请求和带cookie请求。 通过以上步骤,你就可以在Vue中使用axios发送请求,并在请求头上添加cookie了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值