• 技术文章 >Java >java教程

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

    little bottlelittle bottle2019-04-09 14:04:40转载2138

    如今的生活中,登录网站也变得如此简单,当你已经登录一微信时,当你想要登录另一个网站时,只需扫码便可,可是大家知道用Java怎么实现扫码授权吗?本文讲述的就是关于如何用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视频课程

    以上就是Java实现二维码扫码授权登陆的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:CSDN,如有侵犯,请联系admin@php.cn删除
    专题推荐:Java 授权
    上一篇:java-利用udp做一个简单的发送与接收 下一篇:Android获取当前系统日期和时间
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• Java实现微信公众号和扫码支付的案例• 微信授权后用户头像保存到服务器实现方法• 跳转到微信指定扫码关注网页(附代码)• Java中关于package(包)的总结介绍
    1/1

    PHP中文网