查看: 382|回复: 0

[JavaScript/JQuery] angular 用拦截器统一处理http请求和响应的方法

发表于 2017-12-29 08:00:03

想使用angularjs里的htpp向后台发送请求,现在有个用户唯一识别的token想要放到headers里面去,也就是{headres:{'token':1}}

index.html里引入以下js:

  1. angular.module('app.factorys',[])
  2. .factory('httpInterceptor',['$q','$injector','$localStorage',function ($q,$injector,$localStorage) {
  3. var httpInterceptor = {
  4. 'responseError' : function(response) {
  5. // ......
  6. return $q.reject(response);
  7. },
  8. 'response' : function(response) {
  9. if (response.status == 21000) {
  10. // console.log('do something...');
  11. }
  12. return response || $q.when(response);
  13. },
  14. 'request' : function(config) {
  15. config.headers = config.headers || {};
  16. if ($localStorage.token) {
  17. config.headers.token = $localStorage.token;
  18. // config.headers['X-Access-Token'] = $localStorage.token;
  19. };
  20. return config || $q.when(config);
  21. return config;
  22. },
  23. 'requestError' : function(config){
  24. // ......
  25. return $q.reject(config);
  26. }
  27. };
  28. return httpInterceptor;
  29. }])
复制代码

在app里注入factory后,在config里面配置

  1. .config(['$httpProvider',function(){
  2. $httpProvider.interceptors.push(httpInterceptor);
  3. }])
复制代码

以上这篇angular 用拦截器统一处理http请求和响应的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持程序员之家。



回复

使用道具 举报