关于axios的post用法

axios.post('', {
    data: params
},{
    headers: {
        'Access-Control-Allow-Origin':'*',  //解决cors头问题
        'Access-Control-Allow-Credentials':'true', //解决session问题
        'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8' //将表单数据传递转化为form-data类型
    },
    withCredentials : true
})
    .then(function (response) {
        var res = response.data;
        if(res=="登录成功,3秒后跳转主页") {
            var noticeId= JSON.parse(window.sessionStorage.getItem('user'));
            alert(noticeId)
            alert(response.data);
            setTimeout(that.LoginSuccess, 3000)
        }else if(response.data=="用户名不存在,请注册后重新登录") {
            that.message = response.data
        }
    })
    .catch(function (error) {
        alert(error);
    });
### 使用 Axios 进行 POST 请求 当使用 Axios 发送 POST 请求时,确保正确配置请求体和头信息至关重要。如果后端接收到的 POST 数据为空,则可能是由于未设置 `Content-Type` 或者数据格式不匹配造成的[^1]。 对于 Vue 项目中的 Axios 配置,通常建议创建一个全局实例并添加拦截器来处理 token 认证等问题: ```javascript import axios from 'axios'; const instance = axios.create({ baseURL: '/api', timeout: 5000, }); instance.interceptors.request.use( config => { const token = localStorage.getItem('token'); if (token) { config.headers['Authorization'] = `Bearer ${token}`; } return config; }, error => Promise.reject(error) ); export default instance; ``` 发送 POST 请求时可以采用以下两种方式之一传递参数: #### 方法一:使用 data 属性作为 JSON 对象 这是最常用的方式,适用于大多数场景下的 API 调用: ```javascript axios.post('/submit', { key: value }) .then(response => console.log(response.data)) .catch(error => console.error(error)); ``` 注意这里直接将 JavaScript 对象赋给第二个参数,Axios 默认会将其序列化为 JSON 并自动设置合适的 Content-Type 头[^3]。 #### 方法二:通过 URLSearchParams 构造表单编码的数据 某些服务器可能期望接收 x-www-form-urlencoded 类型的内容,在这种情况下应该这样写: ```javascript const params = new URLSearchParams(); params.append('key', value); axios.post('/submit', params, { headers: { 'Content-Type': 'application/x-www-form-urlencoded' } }) .then(response => console.log(response.data)) .catch(error => console.error(error)); ``` 针对跨域问题,可以在 Express 中间件中适当调整 CORS 设置以允许来自特定源的请求[^4]: ```javascript var cors = require('cors'); app.use(cors()); // or more specifically: app.use(cors({ origin: 'http://example.com' })); ``` 此外还需要确认服务端确实能够解析客户端发出的数据格式,并且返回的结果也符合预期。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luolvzhou

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值