前端页面开发时,经常需要异步校验登录态,每次都重新copy之前写的方法,比较繁琐不好维护,固将登录态校验封装成一个js。

(function(){
//登录状态 1 登录态有效 2 登录态无效 3 请求超时
var status;
//状态到期时间戳
var status_exprie_timestamp;
//默认超时时间(秒数)
var default_exprie_time = 60;
//限定协议名只能为https 或 http
var lp = "https:" == document.location.protocol ? 'https:' : 'http:'; //检测是否登录
//login_user_id 用户id | session_id 会话id | callback 成功失败超时后的回调函数
//超时时间5秒
function check_login(login_user_id,session_id,callback){
//有状态 且 未过期 且 状态不为3(请求超时) 直接调用callback不更新过期时间戳
if(status && !status_is_expire() && status != 3){
callback(status);
return ;
} //格式判断
if(!check_login_user_id(login_user_id) || !check_session_id(session_id)){
exec(2,callback);
return ;
} //构建请求相关的变量
var ajax_url = lp+'//host/xxx';
var data = {
'login_user_id':login_user_id,
'session_id':session_id,
'onlyjson':0,
't':new Date().getTime()
}; //请求
$.ajax({
type : "get",
url : ajax_url,
data : data,
timeout : 5000,
dataType : "jsonp",
success : function(data){
if(data.rtn==0){
exec(1,callback);
}else{
exec(2,callback);
}
},
error:function(data, error_type, xhr){
if(error_type=='timeout'){
exec(3,callback);
}else{
exec(2,callback);
}
}
});
} // 同check_login 但不需要传login_user_id 和 session_id
function esay_check_login(callback){
var login_user_id = get_login_user_id();
var session_id = get_session_id();
check_login(login_user_id,session_id,callback);
} //判断用户id格式
function check_login_user_id(login_user_id){
return /^[0-9]{4,}$/.test(login_user_id);
} //判断会话id格式
function check_session_id(session_id){
return /^[0-9a-fA-F]{20,40}$/.test(session_id);
} //获取用户id
function get_login_user_id(){
return _get('login_user_id') ? _get('login_user_id') : getCookie('login_user_id');
} //获取会话id
function get_session_id(){
return _get('session_id') ? _get('session_id') : getCookie('session_id');
} //获取当前的时间戳(秒)
//add_sec 可选 为当前时间戳(秒)加上相应的秒数
function get_now_timestamp(add_sec){
var timestamp = Date.parse(new Date())/1000;
if(add_sec && !isNaN(add_sec)){
timestamp += parseInt(add_sec);
}
return timestamp;
} //判断状态是否超时
function status_is_expire(){
var now_timestamp = get_now_timestamp();
return status_exprie_timestamp && now_timestamp>=status_exprie_timestamp ? true : false;
} //获取query参数方法
function _get(name){
var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if(r!=null)return unescape(r[2]); return null;
} //设置状态、超时时间 且 调用回调函数
function exec(_status,callback){
status = _status;
status_exprie_timestamp = get_now_timestamp(default_exprie_time);
callback(status);
} //获取指定名称的cookie
function getCookie(name){
var arr=document.cookie.split('; ');
if(!arr)return false;
for(var i=0;i<arr.length;i++){
var one=arr[i].split('=');
if(one[0]==name)return one[1];
}
return false;
} //抛出变量、方法
window.check_login = check_login;
window.esay_check_login = esay_check_login;
window.LOGIN_SUCC = 1;
window.LOGIN_FAIL = 2;
window.LOGIN_TIMEOUT = 3;
})();

调用方法

check_login(login_user_id,session_id,function(status){

if(status == LOGIN_SUCC){
//xxx
}else if(status == LOGIN_FAIL){
//xxx
}else if(status == LOGIN_TIMEOUT){
//xxx
} });

js 检查登录态方法封装(闭包、状态缓存)的更多相关文章

  1. iOS OC和JS的交互 javaScriptCore方法封装

    一.javaScriptCore javaScriptCore是一种JavaScript引擎,主要为webKit提供脚本处理能力,javaScriptCore是开源webkit的一部分,他提供了强大的 ...

  2. 前端js重组树形结构数据方法封装

    不知道大家平时工作中,有没有遇到这样一种情况:后端接口返回的数据,全都是一维的数组,都是平铺直叙式的数据,业务需求却要你实现树形结构的功能.那么,针对这种情况该怎么办呢?是跟后台好好沟通一下呢,还是沟 ...

  3. js浮点数保留位数方法封装

    大家在平时业务中应该经常跟小数打交道吧,有没有被小数点的保留位数问题搞得头疼啊.比如,保留一位小数,保留俩位小数,保留三位小数,向上取整.四舍五入等等. 而我最近在项目中正好遇到类似的问题:有的地方要 ...

  4. 封装getByClass(JS获取class的方法封装为一个函数)

    获取方法一(普通版) 获取单一的class: function getByClass(oParent, sClass) {//两个形参,第一个对象oParent 第二个样式名class var aEl ...

  5. 完整且易读的最新版小程序登录态和检验注册过没的app.js写法

    目录 0.可参考的官方页面 1.流程 2.app.js代码 3.java后台怎么通过code获取openId 0.可参考的官方页面 获取登录凭证:https://developers.weixin.q ...

  6. 微信小程序API~检查登录状态

    wx.checkSession(Object object) 检查登录态是否过期. 通过 wx.login 接口获得的用户登录态拥有一定的时效性.用户越久未使用小程序,用户登录态越有可能失效.反之如果 ...

  7. 微信小程序之登录态维护(十一)

    [未经作者本人同意,请勿以任何形式转载] >什么是登录态? 所谓登录态,就是程序在运行时,能够识别当前用户,能够证明自己的唯一性且合法. 我们知道,WEB服务器通过浏览器携带的cookie获取s ...

  8. flask 实现登录 登出 检查登录状态 的两种方法的总结

    这里我是根据两个项目的实际情况做的总结,方法一(来自项目一)的登录用的是用户名(字符串)和密码,前后端不分离,用form表单传递数据:方法二用的是手机号和密码登录,前后端分离,以json格式传递数据, ...

  9. SpringBoot开发十三-检查登录状态

    需求介绍-检查登录状态 防止用户知道我们的一些功能的链接,直接就进到了该页面,就像有些功能是管理员访问才能进的,就需要进行登录状态的判断. 我们知道这个功能点很多其他的功能点都需要使用,所以我们需要使 ...

随机推荐

  1. 20175204 张湲祯 2018-2019-2《Java程序设计》第二周学习总结

    20175204 张湲祯 2018-2019-2<Java程序设计>第二周学习总结 教材学习内容总结 -第二章基本数据类型与数组要点: -标识符与关键字:标识符的第一个字符不能是数字字符: ...

  2. Dilated Convolution

    各种各样的卷积方式, 详细见 各种卷积的 gif 图 Convolution animations  Padding, strides Transposed convolution animatio ...

  3. RequireJS - 个人小入门

    quirejs : http://www.requirejs.cn/ 叶小钗  : http://www.cnblogs.com/yexiaochai/p/3214926.html app.js 展示 ...

  4. .Net Core---- 通过EPPlus批量导出

    前台代码: 前台代码是在.net core bootstrap集成框架上的(这是效果浏览地址:http://core.jucheap.com[效果地址来自:http://blog.csdn.net/a ...

  5. 【原创】大叔经验分享(16)Context namespace element 'component-scan' and its parser class [org.springframework.context.annotation.ComponentScanBeanDefinitionParser] are only available on JDK 1.5 and higher

    今天尝试运行一个古老的工程,配置好之后编译通过,结果运行时报错: org.springframework.beans.factory.BeanDefinitionStoreException: Une ...

  6. Vue 增删改查 demo

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  7. tensorflow激励函数-【老鱼学tensorflow】

    当我们回到家,如果家里有异样,我们能够很快就会发现家中的异样,那是因为这些异常的摆设在我们的大脑中会产生较强的脑电波. 当我们听到某个单词,我们大脑中跟这个单词相关的神经元会异常兴奋,而同这个单词无关 ...

  8. .NET 简单多线程

    取消跨线程访问 Control.CheckForIllegalCrossThreadCalls = false; 1.开启新线程 无参数 Thread thread = new Thread(方法名) ...

  9. Python——Redis相关知识

    一.连接 Redis import redis 连接方式:redis提供了2个方法 1:StrictRedis:实现大部分官方的命令 2:Redis:是StrictRedis的子类,用于向后兼容旧版的 ...

  10. c++中一个多态的实例

    #include <iostream> #include <fstream> #include <vector> #include <algorithm> ...