1, 首先前端会调用授权接口这个不用管, 调用授权接口以后, 会拿到微信用户的头像, 名称, 前端的朋友请往这边走, 微信小程序登入流程, 你可能走错片场了, 我们讨论的是后台的登入
2, 我们只需要知道, 当前端调用微信的授权接口以后, 有一个很重要的参数, 那就是code, 这个code是微信授权以后下发的, 我们拿到这个code , 就可以去微信服务器, 拿到这个用户在微信的上面的唯一标识, 理论上我们需要三个参数, 根据业务不同
code : 微信授权以后的就更随机验证码似的
username: 你可要可不要, 我觉得你最好还是好了
userimage: 用户的头像, 这个最好存起来,
上面这三个参数后台都不需要管, 而是前端调用授权接口以后就会有的, 让前端发送回后台就好了
3, 使用http请求工具访问微信获取用户信息, http请求工具
登入控制器
@RequestMapping("/login") public ResultMap login(@Param("code") String code, HttpServletRequest request, @Param("inviteId") final Long inviteId){ ResultMap resultMap = new ResultMap(); resultMap.setSuccess(true); Map data = resultMap.getData(); try { MapString,String[] parameterMap = request.getParameterMap(); if (StringUtils.isEmpty(code)) { throw new RuntimeException("参数异常"); } //去微信查询用户的openid StringBuilder urlPath = new StringBuilder("https://api.weixin.qq.com/sns/jscode2session"); urlPath.append(String.format("?appid=%s", appId)); //小程序appid urlPath.append(String.format("&secret=%s", secret)); //小程序secretid urlPath.append(String.format("&js_code=%s", code)); urlPath.append(String.format("&grant_type=%s", "authorization_code")); JSONObject object = HttpUtil.doGet(urlPath.toString()); //工具类返回的数据封装成map了 final Map map = object.parseObject(object.toJSONString()); //这个就是我们要的 String openId = (String) map.get("openid"); String sessionKey = (String) map.get("session_key"); if (openId == null){ throw new RuntimeException("登入code错误"); } //查询用户, 拿着openid去数据库查 Account account = accountService.findByOpenid(openId); //查不到就代表未注册 if(account == null){ //新用户, 保存参数到数据库 }else{ //老用户, 登入操作 } return resultMap; } catch (Exception e) { e.printStackTrace(); ResultMap resultMap = new ResultMap(); resultMap.setSuccess(false); resultMap.setMsg("登入失败"); return resultMap; } }登入以后, 根据去微信查询的信息, 判断哪个openid在数据库里面存在不存在, 判断是否为老用户, 还是新用户, 新用户就做注册, 老用户就登入, 关于微信小程序, 服务器如果保持登入态, 点击这里













