当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 微信小程序如何获取用户手机号

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

2018年01月29日  | 移动技术网IT编程  | 我要评论

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

流程图:


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); 
} 

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

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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网