JavaScript中如何设置请求头?

来源:AI教程网作者:卡拉米头衔:草根站长
导读:本期聚焦于小伙伴创作的《JavaScript中如何设置请求头?》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《JavaScript中如何设置请求头?》有用,将其分享出去将是对创作者最好的鼓励。

在JavaScript中设置请求头需要根据使用的请求方式选择对应的配置方法,不同的请求工具设置逻辑存在差异,下面分别介绍几种常见场景的实现方式。

JavaScript中如何设置请求头?

一、使用XMLHttpRequest设置请求头

XMLHttpRequest是原生提供的网络请求对象,设置请求头需要在调用open方法之后、send方法之前,通过setRequestHeader方法完成。

// 创建XMLHttpRequest实例
const xhr = new XMLHttpRequest();
// 初始化请求方法和地址
xhr.open('POST', 'https://ipipp.com/api/test');
// 设置请求头,指定内容类型为JSON
xhr.setRequestHeader('Content-Type', 'application/json');
// 设置自定义请求头,传递身份令牌
xhr.setRequestHeader('Authorization', 'Bearer token_123456');
// 监听请求完成事件
xhr.onload = function() {
  if (xhr.status === 200) {
    console.log('请求成功,返回数据:', xhr.responseText);
  }
};
// 发送请求,携带JSON格式的参数
xhr.send(JSON.stringify({ name: '测试数据', age: 20 }));

二、使用Fetch API设置请求头

Fetch API是现代浏览器原生支持的网络请求接口,请求头通过配置对象的headers属性设置,该属性可以传入普通对象或者Headers实例。

// 方式1:直接传入普通对象作为headers
fetch('https://ipipp.com/api/test', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'Authorization': 'Bearer token_123456',
    'X-Custom-Header': '自定义参数'
  },
  body: JSON.stringify({ name: '测试数据', age: 20 })
})
.then(response => {
  if (response.ok) {
    return response.json();
  }
  throw new Error('请求失败');
})
.then(data => {
  console.log('请求成功,返回数据:', data);
})
.catch(error => {
  console.error('请求出错:', error);
});

// 方式2:使用Headers实例设置请求头
const headers = new Headers();
headers.append('Content-Type', 'application/json');
headers.append('Authorization', 'Bearer token_123456');
fetch('https://ipipp.com/api/test', {
  method: 'POST',
  headers: headers,
  body: JSON.stringify({ name: '测试数据', age: 20 })
});

三、使用axios设置请求头

axios是常用的第三方请求库,设置请求头可以通过全局配置、实例配置或者单次请求配置三种方式实现,优先级从低到高依次为全局配置、实例配置、单次请求配置。

// 引入axios,假设通过script标签引入
// 1. 全局配置请求头,所有请求都会携带
axios.defaults.headers.common['Authorization'] = 'Bearer token_123456';
axios.defaults.headers.post['Content-Type'] = 'application/json';

// 2. 创建axios实例,单独配置该实例的请求头
const instance = axios.create({
  baseURL: 'https://ipipp.com/api',
  headers: {
    'Content-Type': 'application/json',
    'X-Instance-Header': '实例自定义参数'
  }
});

// 3. 单次请求设置请求头,仅当前请求生效
instance.post('/test', 
  { name: '测试数据', age: 20 },
  {
    headers: {
      'X-Request-Header': '单次请求参数',
      'Authorization': 'Bearer new_token_654321' // 会覆盖全局和实例的同名配置
    }
  }
)
.then(response => {
  console.log('请求成功,返回数据:', response.data);
})
.catch(error => {
  console.error('请求出错:', error);
});

四、设置请求头的注意事项

  • 部分请求头属于禁止修改的禁止头,比如HostReferer等,设置这些头会直接失效或者报错。
  • 如果设置自定义请求头,服务端需要配置CORS允许对应的头,否则会出现跨域错误,比如服务端需要设置Access-Control-Allow-Headers包含自定义的请求头名称。
  • 设置Content-Type时需要根据请求体的数据格式选择对应的值,比如表单数据使用application/x-www-form-urlencoded,文件上传使用multipart/form-data
  • 使用XMLHttpRequest时,setRequestHeader必须放在open之后send之前,否则设置不会生效。
请求方式设置请求头的核心方法适用场景
XMLHttpRequestsetRequestHeader方法兼容低版本浏览器,需要精细控制请求过程的场景
Fetch API配置对象的headers属性现代浏览器环境,不需要额外引入依赖的场景
axiosdefaults配置、实例配置、请求配置复杂项目,需要统一请求处理、拦截器的场景

JavaScript请求头XMLHttpRequestFetch_APIaxios修改时间:2026-06-05 01:53:05

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。