java实现二维码扫码授权登陆
假设现在有2个设备,A设备需要扫码授权登陆,B设备是已经登陆了的设备。然后实现如下:
一、A设备生成生成二维码:
A设备向服务器请求getLoginCode接口,这个接口根据请求的sessionId进行base64或其他加密方式进行加密,然后以此作为二维码的值,并将这个loginCode写到redis里,设置5分钟过期。然后将这个loginCode返回给A设备,A设备以此值来生成登陆的二维码。
二、B设备扫码授权
B设备来扫A设备的二维码的时候,携带二维码的值,请求授权登陆的接口scanConfirmLogin,此接口里先校验二维码是否过期,没过期的话进行后面的业务逻辑处理,将用户的基本信息和token写到redis里。
三、A设备轮询获取授权状态
B设备以每秒一次的频率来刷获取用户授权状态接口,若状态为已授权,拿到用户信息去做后面的逻辑处理。
/**
*获取扫描登陆的二维码
*@paramnoncestr随机字符串
*@throwsException
*/
@RequestMapping(value="user/getLoginCode.json")
publicvoidgetLoginCode(Stringnoncestr,HttpServletRequestrequest,HttpServletResponseresponse)throwsException{
if(StringUtil.isBlank(noncestr)){
apiData(request,response,ReqJson.error(CommonError.PARAMS_IMPERFECT));
return;
}
//参数的有效性校验在拦截器里实现
intexpirationTime=300;//时效5分钟
finalStringsessionId=request.getSession().getId();
StringloginCode=ToolUtils.getBase64(sessionId);
JedisUtil.set(loginCode,loginCode,expirationTime);
Mapmap=newHashMap<>();
map.put("loginCode",loginCode);
map.put("expirationTime",expirationTime);
apiData(request,response,ReqJson.ok(map));
}
/**
*扫码确认登陆
*@paramloginCode
*@paramrequest
*@paramresponse
*@throwsException
*/
@RequestMapping(value="user/scanConfirmLogin.json")
@AuthorizationApi
publicvoidscanConfirmLogin(@CurrentTokenfinalTokentoken,StringloginCode,HttpServletRequestrequest,HttpServletResponseresponse)throwsException{
if(StringUtil.isBlank(loginCode)){
apiData(request,response,ReqJson.error(CommonError.PARAMS_IMPERFECT));
return;
}
StringuserId=token.getUserId();
Mapmap=newHashMap<>();
StringloginTicket=JedisUtil.get(loginCode);
if(StringUtil.isBlank(loginTicket)){
//二维码过期
apiData(request,response,ReqJson.error(CommonError.TWO_DIMENSIONAL_CODE_HAS_EXPIRED));
return;
}
UserInfouserInfo=userInfoBiz.getUser(newUserInfo(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(newObject()));
}
/**
*获取登陆状态
*@paramloginCode
*@paramrequest
*@paramresponse
*@throwsException
*/
@RequestMapping(value="user/getScanConfirmLoginStatus.json")
publicvoidgetLoginStatus(finalStringloginCode,HttpServletRequestrequest,HttpServletResponseresponse)throwsException{
if(StringUtil.isBlank(loginCode)){
apiData(request,response,ReqJson.error(CommonError.PARAMS_IMPERFECT));
return;
}
Mapmap=JedisUtil.getMap(loginCode+"scanConfirmLogin");
if(map==null){
apiData(request,response,ReqJson.error(CommonError.AUTHORIZATION_HAS_EXPIRED));
return;
}
apiData(request,response,ReqJson.ok(map));
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。