欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jQuery在header中设置请求信息的方法

程序员文章站 2023-11-27 08:40:04
 jquery是js的类库,js本身不能操作header,因为js是在浏览器加载页面过程中才开始执行的header需要服务器端执行操作 如果是ajax,是可以设...

 jquery是js的类库,js本身不能操作header,因为js是在浏览器加载页面过程中才开始执行的header需要服务器端执行操作

如果是ajax,是可以设置header

$.ajax({
  url: "",
  data: {},
  type: "get",
  beforesend: function(xhr){xhr.setrequestheader('x-test-header', 'test-value');},//这里设置header
  success: function() {}
});

也就是setrequestheader函数

如何在ajax请求中设置特殊的requestheader

现在ajax应用已经相当广泛了,有很多不错的ajax框架可供使用。ajax是一个异步请求,也主要是一种客户端的脚本行为。那么,如何在请求之前为请求添加特殊的一些头部信息呢?

下面是一个简单的例子,我用jquery编写,它的ajax函数中,有一个beforesend方法,这个方法接受一个参数,就代表了发起异步请求的xmlhttprequest对象,我们可以用该对象的setrequestheader方法实现我们的目的

为什么要setrequestheader?

比如,在及时通信系统中,每次获取消息或者发送消息,都需要去判断这个用户是否还在连线中,通过设置"accesstoken",就可以实现正常通信;

beforesend: function(request) {
   request.setrequestheader("accesstoken", accesstoken);
},
<%@ page language="c#" autoeventwireup="true" codefile="default2.aspx.cs" inherits="default2" %>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  <title></title>
  <script src="jquery-1.3.2-vsdoc.js" type="text/javascript"></script>
  <script type="text/javascript" language="javascript">
    $(function() {
      $("#test").click(function() {
        $.ajax({
          type: "get",
          url: "default.aspx",
          beforesend: function(request) {
            request.setrequestheader("test", "chenxizhang");
          },
          success: function(result) {
            alert(result);
          }
        });
      });
    });
  </script>
</head>
<body>
  <form id="form1" runat="server">
  <div id="v">
  </div>
  <input type="button" value="测试" id="test" />
  </form>
</body>
</html>

jquery.ajax() 如何设置 headers 中的 accept 内容

其实很简单,首先如果是常见类型,则请直接设置 datatype 属性

$.ajax({
  datatype: "json",
  type: "get",
  success: function (data) {
  }
});

设置 datatype 后,会去 accepts 属性(此属性会预置一些常用类型)中直接拿相应的类型添加到 accept 中。

)%x02m](8[bkgw21{ey{0gd

如果想自己自定义 jquery 中没有的 accept 内容,可以手动设置 accepts 属性,使用 键值对 存储,然后再设置 datatype 属性为刚刚自定义的键。

$.ajax({
  accepts: {
    xxx: "application/xxx"
  },
  datatype: "xxx",
  type: "get",
  success: function (data) {
  }
});

当然还可以直接设置 headers 属性,直接写 accept 的内容是什么。

$.ajax({
  headers: {
    accept: "application/json; charset=utf-8"
  },
  type: "get",
  success: function (data) {
  }
});

以上所述是小编给大家介绍的jquery在header中设置请求信息的方法,希望对大家有所帮助