91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在微信小程序中獲取用戶手機號

發布時間:2021-02-05 17:19:24 來源:億速云 閱讀:263 作者:Leah 欄目:web開發

這篇文章將為大家詳細講解有關如何在微信小程序中獲取用戶手機號,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

流程圖:

如何在微信小程序中獲取用戶手機號

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

關于如何在微信小程序中獲取用戶手機號就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

丰顺县| 方城县| 浦江县| 普宁市| 会宁县| 南陵县| 涟水县| 巴林右旗| 百色市| 察雅县| 泸州市| 金山区| 蓝田县| 石城县| 延庆县| 宁远县| 桃园市| 汝阳县| 杂多县| 旌德县| 修文县| 吕梁市| 临邑县| 钟祥市| 稻城县| 井陉县| 磴口县| 中牟县| 安庆市| 连云港市| 高密市| 荣昌县| 南川市| 安化县| 宜都市| 曲阜市| 成武县| 山阴县| 行唐县| 来凤县| 柏乡县|