如何在用户登陆之后给每个页面往后台的ajax请求header都带上

发布于 2022-09-11 17:49:52 字数 1770 浏览 15 评论 0

用户登陆之后进入主页,在主页有多个ajax请求,现在要求每个ajax请求前header里面都要带上Authorization验证信息

我是用的jquery ajax的beforeSend方法,但是发现这样操作得在每个当前页面涉及到的每个ajax请求里都要有一个beforeSend方法,然后network几乎每一个接口api都要有两次请求,虽然能请求成功,但是每个接口都请求两次的做法感觉不是很好

相关代码

// 请把代码文本粘贴到下方(请勿用图片代替代码)
1、第一个ajax

       jQuery.ajax({
                url:'http://10.11.2.61:8091/api/user/add',
      contentType:'application/json;charset=utf-8',
                type:'POST',
                datatype:'JSON',
                beforeSend:function(request){
                  request.setRequestHeader('Authorization','Bearer 2ae53f0f-845a-4e8b-9f33-cf35a81d9ea9');
              },
                data:JSON.stringify(obj),
                success:function(res){
                    //新建成功
                    //插入表格
                _this.userdata.push(_this.newPeople);
                _this.newPeople = {};
                },
                error:function(err){
                    //新建失败
                    console.log(err);
                }
            });

2、第二个ajax

         jQuery.ajax({
                url:'http://10.11.2.61:8091/api/user/delete/'+m,
                type:'GET',
                datatype:'JSON',
                beforeSend:function(request){
                  request.setRequestHeader('access_token','2ae53f0f-845a-4e8b-9f33-cf35a81d9ea9');
             },
                success:function(res){
                    //删除成功
                    //删除一行数据
               _this.userdata.splice(n,1);
                },
                error:function(err){
                    //删除失败
                    console.log(err);
                }
            });
            

有没有什么方法能让一个页面头部验证只验证一次,后续所有ajax请求都在头部自带Authorization验证

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

合久必婚 2022-09-18 17:49:52

jQuery.ajaxSetup([options])

你又不是我 2022-09-18 17:49:52

也可以自己封装一个方法

var access_token = "2ae53f0f"
function post(options) {
    if (access_token) {
        options.headers = {
            access_token : access_token
        }
    }
    jquery.ajax(options)
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文