AngularJs用户登录问题处理(交互及验证、阻止FQ处理)


Posted in Javascript onOctober 26, 2017

本文介绍了AngularJs用户登录的交互及验证、阻止FQ处理,具体如下

1. 静态页面搭建及ng的form表单验证实现:

<div class="register-frame-all">
  <div class="register-frame">
   <div class="register-msg">
    <i></i>
    <form name="loginForm" ng-submit="loginAction()">
     <div class="form-group">
      <div class="input-group">
       <span class="input-group-addon register-user"></span>
       <input autocomplete="off" type="number" class="form-control" placeholder="请输入手机号" required ng-model="loginData.loginName" name="loginName">
      </div>
      <div class="input-group">
       <span class="input-group-addon register-pwd"></span>
       <input type="password" class="form-control" placeholder="请输入密码" required ng-model="loginData.pwd" name="pwd">
      </div>
      <button type="submit" class="btn btn-block btn-danger"
        ng-disabled="!( (loginForm.loginName.$valid) && (loginForm.pwd.$valid) )">登录</button>
      <em></em>
     </div>
    </form>
   </div>
   <div class="register-pic" ng-style="registerRnum"></div>
  </div>
 </div>

2. 定义用户登录的控制器,在控制器中使用http服务处理登录接口:

$http({
    url:G.apiUrl_dl+'loginByPhone',
    method:'post',
    data:{
     'phone':loginName,
     'pwd':pwd
    },
    headers:{'Content-Type':'application/x-www-form-urlencoded'},
    transformRequest: function(obj) {
     var str = [];
     for(var p in obj){
      str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p]));
     }
     return str.join("&");
    }
   }).success(function(data){
    // 登录成功后的操作...18     19    });

3. 如果登录成功后将用户的数据保存到cookie或session中 用$state服务进行跳转到指定的页面中:

// 登录成功
    if($scope.loginActionData.token){
     sessionStorage.setItem("token", $scope.loginActionData.token);
     sessionStorage.setItem("tsname", $scope.loginActionData.name);
     sessionStorage.setItem("rights", $scope.loginActionData.rights);
     sessionStorage.setItem("userId", $scope.loginActionData.userId);
     sessionStorage.setItem("departmentsId", $scope.loginActionData.departmentsId);
     sessionStorage.setItem("departmentsName", $scope.loginActionData.departmentsName);
     $state.go('index');
    }else{
     // 登录失败的弹框提示
     $('#loginAction').modal('show');
    }

4. 接下来就是防止用户跳过登录页面通过其他方法(如在地址栏直接输出地址进入页面)  的防FQ操作:

这个方法的操作我放在之前曾经说过得控制器最先执行的run方法中执行,每次进到一个页面之前都会进行检查该用户是否合法登录,如果不是合法登录我们将会让他跳转到登录页面

angular.module.run(['$rootScope','$state',function($rootScope,$state){
  $rootScope.$on('$stateChangeStart',function(event,toState){
   // 防止FQ
   if(!(sessionStorage.getItem("token")))$state.go('register');
  });
 }]);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
B/S开发中常用javaScript技术与代码
Mar 09 Javascript
[原创]提供复制本站内容时出现,该文章转自脚本之家等字样的js代码
Mar 27 Javascript
JQuery中getJSON的使用方法
Dec 13 Javascript
js substring从右边获取指定长度字符串(示例代码)
Dec 23 Javascript
微信小程序 教程之WXML
Oct 18 Javascript
vue.js中引入vuex储存接口数据及调用的详细流程
Dec 14 Javascript
在vue中使用css modules替代scroped的方法
Mar 10 Javascript
Vue中v-show添加表达式的问题(判断是否显示)
Mar 26 Javascript
小程序视频或音频自定义可拖拽进度条的示例代码
Sep 30 Javascript
jQuery事件绑定和解绑、事件冒泡与阻止事件冒泡及弹出应用示例
May 13 jQuery
JavaScript 斐波那契数列 倒序输出 输出100以内的质数代码实例
Sep 11 Javascript
vue路由 遍历生成复数router-link的例子
Oct 30 Javascript
node文字生成图片的示例代码
Oct 26 #Javascript
vue-cli中打包图片路径错误的解决方法
Oct 26 #Javascript
javascript+html5+css3自定义弹出窗口效果
Oct 26 #Javascript
Vue 兄弟组件通信的方法(不使用Vuex)
Oct 26 #Javascript
JS手机端touch事件计算滑动距离的方法示例
Oct 26 #Javascript
JavaScript实现二叉树的先序、中序及后序遍历方法详解
Oct 26 #Javascript
JavaScript实现树的遍历算法示例【广度优先与深度优先】
Oct 26 #Javascript
You might like
业余方法DIY电子管FM收音机
2021/03/02 无线电
PHP警告Cannot use a scalar value as an array的解决方法
2012/01/11 PHP
利用PHP+JS实现搜索自动提示(实例)
2013/06/09 PHP
PHP实现HTML生成PDF文件的方法
2014/11/07 PHP
php项目开发中用到的快速排序算法分析
2016/06/25 PHP
解决laravel 出现ajax请求419(unknown status)的问题
2019/09/03 PHP
php高性能日志系统 seaslog 的安装与使用方法分析
2020/02/29 PHP
JQuery优缺点分析说明
2010/06/09 Javascript
基于jquery的修改当前TAB显示标题的代码
2010/12/11 Javascript
javascript 内存回收机制理解
2011/01/17 Javascript
JavaScript的Date()方法使用详解
2015/06/09 Javascript
jQuery三级下拉列表导航菜单代码分享
2020/04/15 Javascript
js检测用户输入密码强度
2015/10/22 Javascript
jquery.serialize() 函数语法及简单实例
2016/07/08 Javascript
JS导出PDF插件的方法(支持中文、图片使用路径)
2016/07/12 Javascript
JQuery学习总结【二】
2016/12/01 Javascript
基于javascript实现的快速排序
2016/12/02 Javascript
JS中闭包的经典用法小结(2则示例)
2016/12/28 Javascript
jQuery操作css样式
2017/05/15 jQuery
Jquery把获取到的input值转换成json
2017/05/15 jQuery
vue使用exif获取图片旋转,压缩的示例代码
2020/12/11 Vue.js
vue 使用 sortable 实现 el-table 拖拽排序功能
2020/12/26 Vue.js
[03:08]Ti4观战指南上
2014/07/07 DOTA
常见的在Python中实现单例模式的三种方法
2015/04/08 Python
python使用epoll实现服务端的方法
2018/10/16 Python
在Python中画图(基于Jupyter notebook的魔法函数)
2019/10/28 Python
VSCode中自动为Python文件添加头部注释
2019/11/14 Python
使用placeholder属性设置input文本框的提示信息
2020/02/19 HTML / CSS
Booking.com英国官网:全球酒店在线预订网站
2018/04/21 全球购物
利达恒信公司.NET笔试题面试题
2016/03/05 面试题
音乐系毕业生自荐信
2013/10/27 职场文书
最新结婚典礼主持词
2014/03/14 职场文书
学校出纳员岗位职责
2014/03/18 职场文书
2014领导班子四风问题查摆思想汇报
2014/09/13 职场文书
2014年学生会部门工作总结
2014/11/07 职场文书
2015年大学辅导员工作总结
2015/05/12 职场文书