获取微信小程序手机号,后端为java

微信小程序获取手机号步骤

1、前端调用 wx.login() 获取loginCode

wx.login({   
    success:function(res){
        console.log('loginCode:', res.code)
    }
});

 

2、后端拿到该 loginCode 发送https请求微信接口获取 session_key , 

          该url也即获取 openidurl   url为

 https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code

返回结果

{
	"session_key": "kI+3ookOAYC9olOcGzYPmQ",
	"openid": "oNZE65Pu0XfTg2yFP-dFks"
}

 3、前端调用 etPhoneNumber组件,用户确认授权。拿到encryptedData和iv。并传给后端。(此步骤不能在 1、2步骤之前)

<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"> </button>
getPhoneNumber: function(e) { 
    console.log(e.detail.errMsg) 
    console.log(e.detail.iv) 
    console.log(e.detail.encryptedData) 
} 

返回参数说明

参数类型说明
encryptedDataString包括敏感数据在内的完整用户信息的加密数据,详细见加密数据解密算法
ivString加密算法的初始向量,详细见加密数据解密算法

4、后端 用  session_key ,encryptedData ,iv 解密获取手机号

       后端解密其实就这么简单,只要流程对了就可以解密,如果解密出错,基本就是流程出错了。不用再去换什么解密算法。

import com.anmoyi.common.Base64; //此包为自己封装的,只要能解密base64都行

import java.security.spec.AlgorithmParameterSpec;

import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;

 /**
     * 解密用户手机号
     * @param keyStr sessionkey
     * @param ivStr  ivData
     * @param encDataStr 带解密数据
     * @return
     * @throws Exception
     * @date 2019年05月08日
     */
    public static String decrypt(String keyStr, String ivStr, String encDataStr)throws Exception {

        byte[] encData = Base64.decode(encDataStr);
        byte[] iv =Base64.decode(ivStr);
        byte[] key = Base64.decode(keyStr);

        AlgorithmParameterSpec ivSpec = new IvParameterSpec(iv);
        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
        SecretKeySpec keySpec = new SecretKeySpec(key, "AES");
        cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec);



        return new String(cipher.doFinal(encData),"UTF-8");
    }

返回

{
    "phoneNumber": "187*********",  
    "purePhoneNumber": "187********", 
    "countryCode": "86",
    "watermark":
    {
        "appid":"APPID",
        "timestamp":TIMESTAMP
    }
}

 

 

 

 

 


心到抢票  抢票软件     https://www.xdticket.com/

 

 

您好!要开发微信小程序手机号登录接口,您可以使用Java后端来处理请求和验证手机号登录。下面是一个简单的示例代码,供您参考: ```java @RestController @RequestMapping("/api") public class LoginController { @PostMapping("/login") public ResponseEntity<?> login(@RequestBody LoginRequest request) { // 在这里进行手机号验证逻辑,例如检查数据库中的用户信息 // 如果手机号有效,可以生成并返回访问令牌(access token) // 如果手机号无效,可以返回相应的错误信息 // 这里只是一个示例,您需要根据自己的业务需求进行实现 if (isValidPhoneNumber(request.getPhoneNumber())) { String accessToken = generateAccessToken(request.getPhoneNumber()); return ResponseEntity.ok(new LoginResponse(accessToken)); } else { return ResponseEntity.badRequest().body("Invalid phone number"); } } private boolean isValidPhoneNumber(String phoneNumber) { // 在这里实现您的手机号验证逻辑,可以检查数据库、调用第三方API等 // 返回 true 表示手机号有效,返回 false 表示手机号无效 // 这里只是一个示例,您需要根据自己的业务需求进行实现 return phoneNumber.matches("^\\d{11}$"); } private String generateAccessToken(String phoneNumber) { // 在这里生成访问令牌(access token),可以使用 JWT、UUID等方式 // 返回生成的访问令牌 // 这里只是一个示例,您需要根据自己的业务需求进行实现 return UUID.randomUUID().toString(); } } ``` 上述示例代码中,`LoginController` 是一个处理登录请求的控制器。`/api/login` 路径对应着手机号登录接口。在 `login` 方法中,您可以实现手机号验证的逻辑,并根据验证结果返回相应的响应。 请根据您的具体业务需求进行修改和补充。这只是一个简单示例,您可能还需要添加数据库查询、加密解密等功能来完善您的登录接口。 希望对您有所帮助!如有更多问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值