本文介绍了如何在angular js中从HTTP拦截器$ httpProvider读取URL和参数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
在这里我可以从HttpIntercepter获取URL字符串和POST请求的参数,并将该信息推送到IndexedDB.但是我不知道如何从httpintercepter获取URL和参数.
where i can get the URL string and the parameter of a POST request from the HttpIntercepter and push that information to IndexedDB. But i have no idea how to get the URL and Parameter from the httpintercepter.
angular.module("app").config(['$httpProvider', function ($httpProvider) {
if (!$httpProvider.defaults.headers.get) {
debugger;
$httpProvider.defaults.headers.get = {};
console.log('POST method triggered');
}
else {
}
$httpProvider.defaults.headers.get['If-Modified-Since'] = 'Mon, 26 Jul 1997 05:00:00 GMT';
$httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';
$httpProvider.defaults.headers.get['Pragma'] = 'no-cache';
}]);
发帖是针对托管在不同服务器中的API
Post call am making is to a API hosted in different server
var tfscapacity = 'https://server.com/folderName/Folder/folderService/folderService.svc/GetResourceCapacityPlan';
var params = {
teamsite: 'team',
project: 'pjt',
iterationId: 'Sprint-3',
team: 'team',
username: 'UserName',
password: 'PassWord'
};
$http.post(tfscapacity, params, null).then(function (response) {
});
推荐答案
经过几次搜索,我找到了答案.您必须编写一个过滤器并将其注入到http
After few searching i have found the answer. You have to write a filter and inject that to http
$httpProvider.interceptors.push('myHttpInterceptor');
请找到完整的代码
angular.module("app").config(['$httpProvider', function ($httpProvider) {
if (!$httpProvider.defaults.headers.get) {
$httpProvider.defaults.headers.get = {};
$httpProvider.interceptors.push('myHttpInterceptor');
}
else {
}
$httpProvider.defaults.headers.get['If-Modified-Since'] = 'Mon, 26 Jul 1997 05:00:00 GMT';
$httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';
$httpProvider.defaults.headers.get['Pragma'] = 'no-cache';
}
]);
angular.module('app').factory('myHttpInterceptor', function ($q) {
return {
// optional method
'request': function (config) {
debugger;
return config;
},
// optional method
'requestError': function (rejection) {
// do something on error
return $q.reject(rejection);
},
// optional method
'response': function (response) {
// do something on success
return response;
},
// optional method
'responseError': function (rejection) {
// do something on error
return $q.reject(rejection);
}
};
});
这篇关于如何在angular js中从HTTP拦截器$ httpProvider读取URL和参数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!