欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

微信小程序如何获取用户手机号

程序员文章站 2022-04-29 12:09:30
最近在做一款微信小程序,需要获取用户手机号,具体步骤如下: 流程图: 1、首先,客户端调用wx.login,回调数据了包含jscode,用于获取openid(用...

最近在做一款微信小程序,需要获取用户手机号,具体步骤如下:

流程图:

微信小程序如何获取用户手机号

1、首先,客户端调用wx.login,回调数据了包含jscode,用于获取openid(用户唯一标识)和sessionkey(会话密钥)。

2、拿到jscode后,将其发送给服务端,服务端拿它与微信服务端做交互获取openid和sessionkey。具体获取方法如下:

(1)需要写一个httpurlconnection工具类:

public class myhttpurlconnection { 
 private final int mtimeout = 10000; // 超时时间 
 /** 
 * get访问 
 */ 
 public string[] requestjson(string url) { 
 return request(url); 
 } 
 private string[] request(string connurl) { 
 string[] resultstr = new string[]{"", ""}; 
 stringbuilder resultdata = new stringbuilder(""); 
 httpurlconnection conn = null; 
 try { 
  url url = new url(connurl); 
  conn = (httpurlconnection) url.openconnection(); 
  conn.setrequestmethod("get"); 
  conn.setusecaches(false); 
  conn.setconnecttimeout(mtimeout); 
  conn.connect(); 
  int resultcode = conn.getresponsecode(); 
  inputstreamreader in; 
  if (resultcode == 200) { 
  in = new inputstreamreader(conn.getinputstream()); 
  bufferedreader buffer = new bufferedreader(in); 
  string inputline; 
  while ((inputline = buffer.readline()) != null) { 
   resultdata.append(inputline); 
   resultdata.append("\n"); 
  } 
  buffer.close(); 
  in.close(); 
  } 
  resultstr[0] = resultdata.tostring(); 
  resultstr[1] = resultcode + ""; 
 } catch (exception e) { 
  e.printstacktrace(); 
 } finally { 
  if (conn != null) { 
  conn.disconnect(); 
  } 
 } 
 return resultstr; 
 } 
} 

(2)然后通过这个工具类与微信服务器建立连接,获取想要的数据:

 string url = "https://api.weixin.qq.com/sns/jscode2session?appid=""&secret=""&js_code=" 
   + jscode + "&grant_type=authorization_code"; 
 string res[] = connection.requestjson(url); 
 system.out.println(res[0]); 
 jsonobject object = json.parseobject(res[0]); 
 string openid = object.getstring("openid"); 
 string session_key = object.getstring("session_key");

其中appid和secret都是自己开发者账号里可以查询到的,js_code是客户端发过来的,这样在返回的数据中就可以获取sessionkey。

3、服务器a拿到sessionkey后,生成一个随机数我们叫3rdsession,以3rdsessionid为key,以sessionkey + openid为value缓存到redis或memcached中;因为微信团队不建议直接将sessionkey在网络上传输,由开发者自行生成唯一键与sessionkey关联。其作用是: (1)、将3rdsessionid返回给客户端,维护小程序登录态。

(2)、通过3rdsessionid找到用户sessionkey和openid。

4、客户端拿到3rdsessionid后缓存到storage,
5、通过wx.getuseriinfo可以获取到用户敏感数据encrypteddata 。
6、客户端将encrypteddata、3rdsessionid和偏移量一起发送到服务器a
7、服务器a根据3rdsessionid从缓存中获取session_key
8、在服务器a使用aes解密encrypteddata,从而实现用户敏感数据解密。

解密数据需要用到的参数有三个,分别是:

1、encrypteddata(密文)
2、iv(向量)
3、aeskey(密钥)也就是sessionkey

在解密的时候要将上述三个变量做base64解码:

byte[] encrypdata = utilengine.decode(encdata); 
byte[] ivdata = utilengine.decode(iv); 
byte[] sessionkey = utilengine.decode(session_key); 

然后使用aes解密方法进行解密:

public static byte[] decrypt(byte[] key, byte[] iv, byte[] encdata) 
 throws nosuchpaddingexception, nosuchalgorithmexception, invalidalgorithmparameterexception, 
 invalidkeyexception, badpaddingexception, illegalblocksizeexception { 
 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 cipher.dofinal(encdata); 
} 

这样在返回的数据中就可以拿到用户的手机号。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。