首页
登录 | 注册

java实现二维码扫码授权登陆

假设现在有2个设备,A设备需要扫码授权登陆,B设备是已经登陆了的设备。然后实现如下:

一、A设备生成生成二维码:

A设备向服务器请求getLoginCode接口,这个接口根据请求的sessionId进行base64或其他加密方式进行加密,然后以此作为二维码的值,并将这个loginCode写到redis里,设置5分钟过期。然后将这个loginCode返回给A设备,A设备以此值来生成登陆的二维码。

二、B设备扫码授权

B设备来扫A设备的二维码的时候,携带二维码的值,请求授权登陆的接口scanConfirmLogin,此接口里先校验二维码是否过期,没过期的话进行后面的业务逻辑处理,将用户的基本信息和token写到redis里。

三、A设备轮询获取授权状态

B设备以每秒一次的频率来刷 获取用户授权状态接口,若状态为已授权,拿到用户信息去做后面的逻辑处理。

 /**
 * 获取扫描登陆的二维码
 * @param noncestr随机字符串
 * @throws Exception 
 */ 
 @RequestMapping(value = "user/getLoginCode.json")
 public void getLoginCode(String noncestr,HttpServletRequest request,HttpServletResponse response) throws Exception {
 if(StringUtil.isBlank(noncestr)){
 apiData(request, response,ReqJson.error(CommonError.PARAMS_IMPERFECT));
 return;
 }
 //参数的有效性校验在拦截器里实现
 int expirationTime=300; //时效5分钟
 final String sessionId=request.getSession().getId();
 String loginCode=ToolUtils.getBase64(sessionId);
 JedisUtil.set(loginCode, loginCode, expirationTime);
 Map<String,Object> map=new HashMap<>();
 map.put("loginCode", loginCode);
 map.put("expirationTime", expirationTime);
 apiData(request, response, ReqJson.ok(map));
 }
 /**
 * 扫码确认登陆
 * @param loginCode
 * @param request
 * @param response
 * @throws Exception
 */
 @RequestMapping(value = "user/scanConfirmLogin.json")
 @AuthorizationApi
 public void scanConfirmLogin(@CurrentToken final Token token,String loginCode,HttpServletRequest request,HttpServletResponse response) throws Exception {
 if(StringUtil.isBlank(loginCode)){
 apiData(request, response,ReqJson.error(CommonError.PARAMS_IMPERFECT));
 return;
 }
 String userId=token.getUserId();
 Map<String,String> map=new HashMap<>();
 String loginTicket=JedisUtil.get(loginCode);
 if(StringUtil.isBlank(loginTicket)){
 //二维码过期
 apiData(request, response,ReqJson.error(CommonError.TWO_DIMENSIONAL_CODE_HAS_EXPIRED));
 return;
 }
 UserInfo userInfo = userInfoBiz.getUser(new UserInfo(userId)); 
 if(userInfo==null){
 apiData(request, response,ReqJson.error(UserError.USER_NOT_FOUND));
 return;
 }
 //将用户信息放在缓存中
 map.put(BaseConfig.ACCESS_TOKEN, token.getAccessToken());
 map.put("userId", userInfo.getUserId());
 map.put("rongCloudToken", userInfo.getRongCloudToken());
 map.put("identity", userInfo.getIdentity());
 JedisUtil.setMap(loginCode+"scanConfirmLogin", map, 300);
 apiData(request, response, ReqJson.ok(new Object()));
 }
 /**
 * 获取登陆状态
 * @param loginCode
 * @param request
 * @param response
 * @throws Exception
 */
 @RequestMapping(value = "user/getScanConfirmLoginStatus.json")
 public void getLoginStatus(final String loginCode,HttpServletRequest request,HttpServletResponse response) throws Exception {
 if(StringUtil.isBlank(loginCode)){
 apiData(request, response,ReqJson.error(CommonError.PARAMS_IMPERFECT));
 return;
 }
 Map<String,String> map= JedisUtil.getMap(loginCode+"scanConfirmLogin");
 if(map==null){
 apiData(request, response,ReqJson.error(CommonError.AUTHORIZATION_HAS_EXPIRED));
 return;
 }
 apiData(request, response, ReqJson.ok(map));
 }
相关内容

相关文章

  • 详解java实现简单扫码登录功能&lpar;模仿微信网页版扫码&rpar;
    java实现简单扫码登录功能 模仿微信pc网页版扫码登录 使用js代码生成qrcode二维码减轻服务器压力 js循环请求服务端,判断是否qrcode被扫 二维码超时失效功能 二维码被扫成功登录,服务端产生sessionId,传到页面使用js ...
  • python实现二维码扫码自动登录淘宝
    一个小项目自动登录淘宝联盟抓取数据,由于之前在Github上看过类似用Python写的代码因此选择用Python来写,第一次用Python正式写程序还是被其"简单"所震撼,当然用的时候还是对其(2.7版)编码.迁移环境等 ...
  • 详解基于Koa2开发微信二维码扫码支付相关流程
    前段时间在开发一个功能,要求是通过微信二维码进行扫码支付.这个情景我们屡见不鲜了,各种电子商城.线下的自动贩卖机等等都会有这个功能.平时只是使用者,如今变为开发者,也是有不小的坑.所以特此写一篇博客记录一下. 注: 要开发微信二维码支付,你 ...
  • 1.maven项目的pom.xml中添加如下jar包: <dependency> <groupId>com.github.wxpay</groupId> <artifactId>wxpay-s ...
  • PHP微信公众号扫码模拟登录功能 功能只是将:https://github.com/huanz/wechat-mp-hack 改成PHP实现罢了. 之前有个休闲豆每日晨报订阅号每天定时群发消息,去年微信突然要求一定要扫码授权才能登录,FK, ...

2019 xools.net webmaster#xools.net
12 q. 0.035 s.
湘ICP备19005923号