本文为大家分享了javaweb实现app扫码登录的具体代码,供大家参考,具体内容如下
1.web页面主动向服务器索要一张由服务器生成包含维一标识的二维码图片,也可以直接向后台索要一个维一标识,拿到标识后通过js生成二维码。这里本人采用的是第二种方式,至于为什么吗?个人感觉这样方便,后台也不要导入架包,最后将该标识存入list集合中,接下来会用到该标识
2.app扫码后解析二维码内的维一标识,然后再携带该标识跟用户名发回给服务器,服务器接到请求后,遍历list集合,验证该标识是否为本系统生成的,若是再去验证用户名是否存在,若存在这时需将标识与用户名绑定在一起,绑定的方式有好多种。我这里采用一种较为简单的方法map的方式,将标识做为key 用户名做为value存在一个全局map中,表示该用户已经扫过码,只等接下来的验证了
3.web页面从向服务器索取二维码或标识后(第一步操作之后)就开始通过ajax每隔2秒或几秒钟带上维一标识向服务器发起检查请求,通过该标识查看map是否有对应的用户已经扫过码而未登录,有的话直接登录,没有的话继续轮寻,当然你也可以采用建立长连接的方式
4.以下为后台代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
package com.*; @controller @requestmapping (value = "/login" ) public class logincontroller{ @autowired private userinfobaseservice userinfobaseservice; //存储二维码维一标识 public static set<string> tokes = new hashset<>(); //存储toke绑定的用户 public static map<string,string> users = new hashmap<>(); /** * 生成二维码维一标识toke * @return */ @responsebody @requestmapping ( "/generationqrcode" ) public string generationtoken(){ string uid = uuid.randomuuid().tostring(); tokes.add(uid); return uid; } /** * app扫码后将token与用户绑定 * @param loginname * @param token * @return */ @responsebody @requestmapping ( "/determine" ) public responseentity determine(string loginname, string token){ for (string t:tokes) { if (t.equals(token)){ users.put(token,loginname); userinfo userinfo = userinfobaseservice.getuserbyloginname(loginname); if ( null ==userinfo){ return new responsefailure( "用户不存在" );} return new responseentity( "正在登录请稍后..." ); } } return new responseentity( "请求无效" ); } /** * axaj定时请求是否有用户扫描了二维码 * @param token */ @responsebody @requestmapping ( "/scanlogin" ) public string scanlogin(string token){ if (stringkit.isblank(token)){ return "token is null" ;} string loginname = users.get(token); if (stringkit.isblank(loginname)){ return "error" ;} //subject subject = securityutils.getsubject(); //注释的这三行换成你自已的登录代码就行了 //subject.logout(); //usernamepasswordtokentype tokentype = new usernamepasswordtokentype(loginname, "123456",2); try { subject.login(tokentype); } catch (exception e){ e.printstacktrace(); } users.remove(token); tokes.remove(token); return "success" ; } } |
5.以下为前台代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
//获取维一标识token生成二维码 $.post( '${ctx}/login/generationqrcode' , function (token) { new qrcode(document.getelementbyid( 'qrcode' ), {text:token,height: 125 ,width: 125 }); $( '#qrcode' ).removeattr( 'title' ); $( '#qrcode' ).attr( 'token' ,token); }); //ajax定时查看是否有用户扫码后未登入 var time = window.setinterval(function () { var token = $( '#qrcode' ).attr( 'token' ); if (token){ $.post( '${ctx}/login/scanlogin' ,{ 'token' :token},function (data) { if (data == 'success' ){ clearinterval(time); window.location.href = '${ctx}/login/' ; } }) } }, 1000 ); |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/u014598014/article/details/78533596?utm_source=blogxgwz5