| | |
| | | import cn.binarywang.wx.miniapp.bean.WxMaJscode2SessionResult; |
| | | import com.alibaba.fastjson.JSON; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.alibaba.fastjson.TypeReference; |
| | | import com.alibaba.fastjson.parser.Feature; |
| | | import com.alipay.api.AlipayApiException; |
| | | import com.alipay.api.AlipayClient; |
| | | import com.alipay.api.DefaultAlipayClient; |
| | | import com.alipay.api.internal.util.AlipayEncrypt; |
| | | import com.alipay.api.internal.util.AlipaySignature; |
| | | import com.alipay.api.request.AlipaySystemOauthTokenRequest; |
| | | import com.alipay.api.response.AlipaySystemOauthTokenResponse; |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | |
| | | import java.util.Set; |
| | | import java.util.concurrent.TimeUnit; |
| | | import javax.annotation.Resource; |
| | | |
| | | import com.ruoyi.system.api.domain.dto.MobileDTO; |
| | | import org.apache.commons.io.IOUtils; |
| | | import org.apache.http.HttpEntity; |
| | | import org.apache.http.HttpResponse; |
| | |
| | | @Override |
| | | public AppMiniLoginVO loginThird(AppMiniLoginDTO appMiniLoginDto) throws Exception { |
| | | AppMiniLoginVO appMiniLoginVo = new AppMiniLoginVO(); |
| | | |
| | | if(appMiniLoginDto.getType()==1){ |
| | | if (appMiniLoginDto.getAuth_code()== null || appMiniLoginDto.getAuth_code().length() == 0) { |
| | | } else { |
| | |
| | | String password = "123456"; |
| | | sysUser.setPassword(SecurityUtils.encryptPassword(password)); |
| | | sysUser = sysUserService.registerUser(sysUser).getData(); |
| | | |
| | | if (sysUser==null){ |
| | | sysUser = sysUserService.getSysUser(member.getUserId()).getData(); |
| | | } |
| | | |
| | | member = new Member(); |
| | | member.setUserId(sysUser.getUserId()); |
| | | member.setDelFlag(0); |
| | |
| | | if (member != null) { |
| | | sysUser = sysUserService.getSysUser(member.getUserId()).getData(); |
| | | } |
| | | |
| | | LambdaQueryWrapper<Member> wrapper1= Wrappers.lambdaQuery(); |
| | | wrapper1.eq(Member::getMiniOpenid,openid); |
| | | Member member1=this.getOne(wrapper1); |
| | |
| | | if (sysUser==null){ |
| | | sysUser = sysUserService.getSysUser(member.getUserId()).getData(); |
| | | } |
| | | |
| | | |
| | | member = new Member(); |
| | | member.setUserId(sysUser.getUserId()); |
| | | member.setDelFlag(0); |
| | |
| | | member.setWxUnionid(unionid); |
| | | member.setMiniOpenid(openid); |
| | | this.save(member); |
| | | |
| | | appMiniLoginVo.setMiniOpenid(member.getMiniOpenid()); |
| | | appMiniLoginVo.setWxUnionid(member.getWxUnionid()); |
| | | appMiniLoginVo.setSysUser(sysUser); |
| | |
| | | member.setPhone(memberDTO.getPhone()); |
| | | member.setIdNumber(memberDTO.getIdNumber()); |
| | | member.setRealName(memberDTO.getRealName()); |
| | | |
| | | String realname = "";// 姓名 |
| | | String idcard = "";// 身份证 |
| | | int type = 1;// 普通版,不需要加密 |
| | | Map<String, Object> params = new HashMap<>(); |
| | | params.put("realname", realname); |
| | | params.put("idcard", idcard); |
| | | |
| | | CloseableHttpClient httpClient = HttpClients.createDefault(); |
| | | CloseableHttpResponse response = null; |
| | | String result = null; |
| | |
| | | if (Integer.valueOf(jsonObject1.get("res").toString())==2){ |
| | | throw new ServiceException("实名认证失败"); |
| | | } |
| | | |
| | | String sex=getGender(idcard); |
| | | if (sex.equals("女")){ |
| | | member.setGender(GenderEnum.FEMALE); |
| | |
| | | if (sex.equals("男")){ |
| | | member.setGender(GenderEnum.MALE); |
| | | } |
| | | |
| | | this.updateById(member); |
| | | } |
| | | |
| | |
| | | int genderNum = Integer.parseInt(idNumber.substring(16, 17)); |
| | | return genderNum % 2 == 0 ? "女" : "男"; |
| | | } |
| | | |
| | | |
| | | public static String urlencode(Map<String, ?> data) { |
| | | StringBuilder sb = new StringBuilder(); |
| | |
| | | } |
| | | |
| | | @Override |
| | | public AppMiniLoginVO miniRegister(AppMiniRegisterDTO appMiniRegisterDTO) { |
| | | AppMiniLoginVO appMiniLoginVO =new AppMiniLoginVO(); |
| | | SysUser sysUser; |
| | | if (appMiniRegisterDTO.getType() == 1) { |
| | | LambdaQueryWrapper<Member> wrapper = Wrappers.lambdaQuery(); |
| | | wrapper.eq(Member::getZfbOpenid, appMiniRegisterDTO.getZfbuserid()); |
| | | Member member = this.getOne(wrapper); |
| | | public void mobile(MobileDTO mobileDTO) { |
| | | Member byId = this.getById(mobileDTO.getMemberid()); |
| | | if (mobileDTO.getType()==1) { |
| | | if (mobileDTO.getAuth_code() == null || mobileDTO.getAuth_code().length() == 0) { |
| | | } else { |
| | | //1. 获取验签和解密所需要的参数 |
| | | Map<String, String> openapiResult = JSON.parseObject(mobileDTO.getAuth_code(), |
| | | new TypeReference<Map<String, String>>() { |
| | | }, Feature.OrderedField); |
| | | String signType = "RSA2"; |
| | | String charset = "UTF-8"; |
| | | String encryptType = "AES"; |
| | | String sign = openapiResult.get("sign"); |
| | | String content = openapiResult.get("response"); |
| | | |
| | | //获取用户为空则新建 |
| | | if (member == null) { |
| | | //创建新用户 |
| | | String memberId = IdUtils.simpleUUID(); |
| | | sysUser = new SysUser(); |
| | | sysUser.setUserName(memberId); |
| | | sysUser.setNickName("白金用户"); |
| | | sysUser.setPhonenumber(appMiniRegisterDTO.getMiniOpenid()); |
| | | sysUser.setAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png"); |
| | | String password = "123456"; |
| | | sysUser.setPassword(SecurityUtils.encryptPassword(password)); |
| | | sysUser = sysUserService.registerUser(sysUser).getData(); |
| | | //如果密文的 |
| | | boolean isDataEncrypted = !content.startsWith("{"); |
| | | boolean signCheckPass = false; |
| | | |
| | | member = new Member(); |
| | | member.setUserId(sysUser.getUserId()); |
| | | member.setDelFlag(0); |
| | | member.setRealName("白酒用户"); |
| | | member.setAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png"); |
| | | member.setWxUnionid(appMiniRegisterDTO.getWxUnionid()); |
| | | member.setMiniOpenid(appMiniRegisterDTO.getMiniOpenid()); |
| | | this.save(member); |
| | | //2. 验签 |
| | | String signContent = content; |
| | | |
| | | appMiniLoginVO.setMiniOpenid(member.getMiniOpenid()); |
| | | appMiniLoginVO.setWxUnionid(member.getWxUnionid()); |
| | | appMiniLoginVO.setSysUser(sysUser); |
| | | appMiniLoginVO.setMemberid(member.getId()); |
| | | } else { |
| | | sysUser = sysUserService.getSysUser(member.getUserId()).getData(); |
| | | appMiniLoginVO.setZfbuserid( appMiniRegisterDTO.getZfbuserid()); |
| | | appMiniLoginVO.setSysUser(sysUser); |
| | | appMiniLoginVO.setMemberid(member.getId()); |
| | | //如果是加密的报文则需要在密文的前后添加双引号 |
| | | if (isDataEncrypted) { |
| | | signContent = "\"" + signContent + "\""; |
| | | } |
| | | try { |
| | | signCheckPass = AlipaySignature.rsaCheck(signContent, sign, ALIPAY_PUBLIC_KEY, charset, signType); |
| | | } catch (AlipayApiException e) { |
| | | //验签异常, 日志 |
| | | } |
| | | if (!signCheckPass) { |
| | | //验签不通过(异常或者报文被篡改),终止流程(不需要做解密) |
| | | } |
| | | |
| | | } |
| | | if (appMiniRegisterDTO.getType() == 2) { |
| | | LambdaQueryWrapper<Member> wrapper = Wrappers.lambdaQuery(); |
| | | wrapper.eq(Member::getMiniOpenid, appMiniRegisterDTO.getMiniOpenid()); |
| | | Member member = this.getOne(wrapper); |
| | | //获取用户为空则新建 |
| | | if (member == null) { |
| | | //创建新用户 |
| | | String memberId = IdUtils.simpleUUID(); |
| | | sysUser = new SysUser(); |
| | | sysUser.setUserName(memberId); |
| | | sysUser.setNickName("白金用户"); |
| | | sysUser.setPhonenumber(appMiniRegisterDTO.getMiniOpenid()); |
| | | sysUser.setAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png"); |
| | | String password = "123456"; |
| | | sysUser.setPassword(SecurityUtils.encryptPassword(password)); |
| | | sysUser = sysUserService.registerUser(sysUser).getData(); |
| | | |
| | | member = new Member(); |
| | | member.setUserId(sysUser.getUserId()); |
| | | member.setDelFlag(0); |
| | | member.setRealName("白酒用户"); |
| | | member.setAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png"); |
| | | member.setWxUnionid(appMiniRegisterDTO.getWxUnionid()); |
| | | member.setMiniOpenid(appMiniRegisterDTO.getMiniOpenid()); |
| | | this.save(member); |
| | | |
| | | appMiniLoginVO.setMiniOpenid(member.getMiniOpenid()); |
| | | appMiniLoginVO.setWxUnionid(member.getWxUnionid()); |
| | | appMiniLoginVO.setSysUser(sysUser); |
| | | appMiniLoginVO.setMemberid(member.getId()); |
| | | } else { |
| | | sysUser = sysUserService.getSysUser(member.getUserId()).getData(); |
| | | appMiniLoginVO.setMiniOpenid(member.getMiniOpenid()); |
| | | appMiniLoginVO.setWxUnionid(member.getWxUnionid()); |
| | | appMiniLoginVO.setSysUser(sysUser); |
| | | appMiniLoginVO.setMemberid(member.getId()); |
| | | //3. 解密 |
| | | String plainData = null; |
| | | if (isDataEncrypted) { |
| | | try { |
| | | plainData = AlipayEncrypt.decryptContent(content, encryptType, "VSpPcLQjLSoTz6Yd7KNoyQ==", charset); |
| | | } catch (AlipayApiException e) { |
| | | //解密异常, 记录日志 |
| | | e.getMessage(); |
| | | } |
| | | } else { |
| | | plainData = content; |
| | | } |
| | | |
| | | Map<String, String> openapiResult1 = JSON.parseObject(plainData, |
| | | new TypeReference<Map<String, String>>() { |
| | | }, Feature.OrderedField); |
| | | |
| | | |
| | | |
| | | byId.setPhone(openapiResult1.get("mobile")); |
| | | this.updateById(byId); |
| | | } |
| | | return appMiniLoginVO; |
| | | }else{ |
| | | String responseAccessToken = null; |
| | | try { |
| | | responseAccessToken = getAccessTokenByWX(); |
| | | } catch (Exception e) { |
| | | throw new RuntimeException(e); |
| | | } |
| | | |
| | | JSONObject jsonAccessToken = JSONObject.parseObject(responseAccessToken); |
| | | String accessToken = jsonAccessToken.getString("access_token"); |
| | | String errmsg = jsonAccessToken.getString("errmsg"); |
| | | Long expiresIn = jsonAccessToken.getLong("expires_in"); |
| | | if (StringUtils.isBlank(accessToken)) { |
| | | throw new ServiceException(errmsg); |
| | | } |
| | | String responseUserPhoneNumber = null; |
| | | try { |
| | | responseUserPhoneNumber = getMobileByWX(accessToken, mobileDTO.getCode()); |
| | | } catch (Exception e) { |
| | | throw new RuntimeException(e); |
| | | } |
| | | JSONObject jsonUserPhoneNumber = JSONObject.parseObject(responseUserPhoneNumber); |
| | | String phoneInfo = jsonUserPhoneNumber.getString("phone_info"); |
| | | JSONObject jsonUserPhoneInfo = JSONObject.parseObject(phoneInfo); |
| | | String mobile = jsonUserPhoneInfo.getString("purePhoneNumber"); |
| | | byId.setPhone(mobile); |
| | | this.updateById(byId); |
| | | } |
| | | } |
| | | |
| | | public static String getAccessTokenByWX() throws Exception { |