angular中service封装$http做权限时拦截403等状态及获取验证码倒计时、跨域问题解决
封装$http、做权限时拦截403等状态及获取验证码倒计时:
- 拦截接口返回状态
var app = angular.module('app'); app.factory('UserInterceptor', ["$q","$rootScope", "$location", function ($q, $rootScope, $location,$localStorage) {
return {
request:function(config){
config.headers["Authorization"] = 'Bearer ' + localStorage['token'];
var urlArray = config.url.split("/")
if(urlArray.indexOf("api") > -1 && config.method == "GET"){
if(config.url.indexOf("?") > -1){
config.url = config.url+"&time="+new Date().getTime();
}else{
config.url = config.url+"?time="+new Date().getTime();
}
}
return config;
},
responseError: function (response) {
switch(response.status)
{
case 401:
localStorage.clear();
$location.path("/login");
break;
case 403:
$location.path("/login");
break;
}
}
};
}]);response.status为返回状态码
- 封装$http
app.factory('ResourceGet',function($http,$q){
var service = {}
service.callBack = function(action,params){
var url = ' http://10.0.10.201:8080/';
var deferred = $q.defer();
$http({
method: 'GET',
url: url+action,
params: params
}).success(function(data){
deferred.resolve(data);
})
return deferred.promise;
}
return service
}); app.factory('ResourcePut', function ($http, $q) {
var service = {}
service.callBack = function ( action, params ) {
var url = 'http://10.0.10.201:8080/'
var deferred = $q.defer()
$http({
method: 'PUT',
url: url + action,
data: params,
headers : {'Content-Type': 'application/json; charset=utf-8'}
}).success(function (data) {
deferred.resolve(data)
})
return deferred.promise
}
return service
}) app.factory('ResourcePost', function ($http, $q) {
var service = {}
service.callBack = function ( action, params ) {
var url = 'http://10.0.10.201:8080/'
var deferred = $q.defer()
$http({
method: 'POST',
url: url + action,
data: params,
headers : {'Content-Type': 'application/json; charset=utf-8'}
}).success(function (data) {
deferred.resolve(data)
})
return deferred.promise
}
return service
}) app.factory('ResourceDelete', function ($http, $q) {
var service = {}
service.callBack = function (action, params) {
var url = 'http://10.0.10.201:8080/'
var deferred = $q.defer()
$http({
method: 'DELETE',
// headers : {'Content-Type': 'application/x-www-form-urlencoded'},
url: url + action
}).success(function (data) {
deferred.resolve(data)
})
return deferred.promise
}
return service
}) - 修改跨域问题
app.config(['$httpProvider', function($httpProvider) {
$httpProvider.defaults.withCredentials = true;
}]); - 获取验证码倒计时
app.service('WaitSecond',function(){
var wait = 60;
var t = this;
this.waitTime = function(code){
if(wait == 0){
$("#"+code).html('获取验证码');
$("#"+code).removeAttr("disabled");
wait = 60
}else{
console.log(code);
$("#"+code).html(function(){
return wait + '秒'
}).attr('disabled','true');
wait--;
setTimeout(function () {
t.waitTime(code);
}, 1000);
}
}
})html:
<button id="code" ng-click="register.getCode('code')" class="ng-binding">获取验证码</button>controller:
WaitSecond.waitTime(id);
5.统一接口定义全局变量
app.constant('apiImg','http://10.0.10.200:8080/SeeMeInterface/img/uploadImg')
angular中service封装$http做权限时拦截403等状态及获取验证码倒计时、跨域问题解决的更多相关文章
- 前端vue开发中的跨域问题解决,以及nginx上线部署。(vue devServer与nginx)
前言 最近做的一个项目中使用了vue+springboot的前后端分离模式 在前端开发的的时候,使用vue cli3的devServer来解决跨域问题 上线部署则是用的nginx反向代理至后台服务所开 ...
- web项目中的跨域问题解决方法
一种是JSONP 一种是 CORS. 在客户端Javascript调用服务端接口的时候,如果需要支持跨域的话,需要服务端支持. JSONP的方式就是服务端对返回的值进行回调函数包装,他的优点是支持众多 ...
- Spring Boot + Spring Cloud 实现权限管理系统 后端篇(十二):解决跨域问题
什么是跨域? 同源策略是浏览器的一个安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源. 同源策略是浏览器安全的基石. 如果一个请求地址里面的协议.域名和端口号都相同,就属于同源. ...
- iOS项目中获取验证码倒计时及闪烁问题解决方案
-(void)startTime{ __block int timeout= 59; //倒计时时间 dispatch_queue_t queue = dispatch_get_global_queu ...
- vue中axios访问Java后端跨域问题解决
问题背景: 前后端分离,前端选用Vue,后端选用Java,vue编译出的静态页面采用ngix发布,在前端访问后端时出现跨域问题. 解决方法: 跨域的问题解决方法有好多种,这里是通过服务端解决,以下是代 ...
- tp中session用来做权限方法 (缓解mysql压力)
http://www.thinkphp.cn/code/2617.html
- angular中使用canvas画布做验证码
//填充画布,五位随机数 drawNumber(): void { this.clearCanvas(); let ctx: CanvasRenderingContext2D = this.myGra ...
- Android中注册获取验证码倒计时按钮
public class CountDownTimerUtils extends CountDownTimer { private TextView mTextView; /** * @param t ...
- 用angular中的ng-repeat和ng-show来实现tab选项卡
虽然我们可以用angular中的路由来做tab选项卡,但是那会让我们建立很多的页面来引入,或者建立 <script type="text/ng-template" id=&q ...
随机推荐
- Day040--HTML&CSS
内容回顾: 标签分类: (1)行内标签 span 小跨度的标签 i em a 特点: (1)在一行内显示 (2)不能设置宽高,如果不设置宽高,默认是内容的宽高 (2)块级标签 h1~h6 h1页面中尽 ...
- goroutine 和 线程的区别
我们在使用Go语言进行开发时,一般会使用goroutine来处理并发任务.那么大家有没有考虑过goroutine的实现机制是什么样的?很多同学会把goroutine与线程等同起来,但是实际上并不是这样 ...
- go 数组 切片 字典 结构体
数组 ##数组的定义与赋值: 1. var num [3]int num = [3]int{1,2,3} 2. var num [3]int = [3]int {1,2,3} 3. num := [3 ...
- day18 集合框架(JCF)
集合框架(JCF)java collections framework 框架:为了实现某一目的/功能而预先提供的一系列封装好的具有继承或实现关系的类与接口. 1.这种框架是高性能的,对基本类集(动态数 ...
- django - 总结 - 跨域请求
script ->jsonp跨域 浏览器的同源策略:不能跨越网站请求信息: XMLHttpRequests遵循这个规定. 因此ajax等基于XML的都不能进行跨站请求 而我们知道img,ifra ...
- 第一章 Java程序设计概述
1.1 Java程序设计平台 Java是一门设计优秀的语言,更是一个完整的平台.Java平台包括了一个庞大可重用的类库以及提供了安全性,跨系统,自动垃圾收集等优秀特性的执行环境. 这也使其成为自发布以 ...
- k64 datasheet学习笔记22---Direct Memory Access Controller (eDMA)
0.前言 本文主要介绍DMA相关内容 1.简介 DMA模块包含: 1.一个DMA引擎 源和目的地址的计算 数据搬移 2.本地存储的传输控制描述TCD,对于16个传输通道中的每一个各对应一个TCD 1. ...
- JS禁用浏览器退格键、禁止右键、禁止全选、复制、粘贴
一.禁用浏览器退格键 摘抄自:https://www.cnblogs.com/wanggd/p/3164536.html 我们在真实的项目开发中经常会使用JS 对键盘上的一些按键进行禁用,常见的比如说 ...
- C++设计模式——备忘录模式
备忘录模式 在GOF的<设计模式:可复用面向对象软件的基础>一书中对备忘录模式是这样说的:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢 ...
- Lua中的模块与包
[前言] 从Lua5.1版本开始,就对模块和包添加了新的支持,可是使用require和module来定义和使用模块和包.require用于使用模块,module用于创建模块.简单的说,一个模块就是一个 ...