|
|
@@ -36,6 +36,17 @@ type UserInfo struct {
|
|
|
} `json:"watermark"`
|
|
|
}
|
|
|
|
|
|
+// 用户手机号
|
|
|
+type PhoneInfo struct {
|
|
|
+ PhoneNumber string `json:"phoneNumber"`
|
|
|
+ PurePhoneNumber string `json:"purePhoneNumber"`
|
|
|
+ CountryCode string `json:"countryCode"`
|
|
|
+ Watermark struct {
|
|
|
+ Timestamp int64 `json:"timestamp"`
|
|
|
+ AppID string `json:"appid"`
|
|
|
+ } `json:"watermark"`
|
|
|
+}
|
|
|
+
|
|
|
// pkcs7Unpad returns slice of the original data without padding
|
|
|
func pkcs7Unpad(data []byte, blockSize int) ([]byte, error) {
|
|
|
if blockSize <= 0 {
|
|
|
@@ -57,8 +68,8 @@ func pkcs7Unpad(data []byte, blockSize int) ([]byte, error) {
|
|
|
return data[:len(data)-n], nil
|
|
|
}
|
|
|
|
|
|
-// Decrypt 解密数据
|
|
|
-func (wxa *MiniProgram) Decrypt(sessionKey, encryptedData, iv string) (*UserInfo, error) {
|
|
|
+// get cipherText
|
|
|
+func getCipherText(sessionKey, encryptedData, iv string) ([]byte, error) {
|
|
|
aesKey, err := base64.StdEncoding.DecodeString(sessionKey)
|
|
|
if err != nil {
|
|
|
return nil, err
|
|
|
@@ -81,6 +92,16 @@ func (wxa *MiniProgram) Decrypt(sessionKey, encryptedData, iv string) (*UserInfo
|
|
|
if err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
|
+ return cipherText, err
|
|
|
+}
|
|
|
+
|
|
|
+// Decrypt 解密(用户)数据
|
|
|
+func (wxa *MiniProgram) Decrypt(sessionKey, encryptedData, iv string) (*UserInfo, error) {
|
|
|
+ // 拿到 cipherText
|
|
|
+ cipherText,err := getCipherText(sessionKey, encryptedData, iv)
|
|
|
+ if err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
var userInfo UserInfo
|
|
|
err = json.Unmarshal(cipherText, &userInfo)
|
|
|
if err != nil {
|
|
|
@@ -91,3 +112,21 @@ func (wxa *MiniProgram) Decrypt(sessionKey, encryptedData, iv string) (*UserInfo
|
|
|
}
|
|
|
return &userInfo, nil
|
|
|
}
|
|
|
+
|
|
|
+// Decrypt 解密(手机)数据
|
|
|
+func (wxa *MiniProgram) DecryptPhone(sessionKey, encryptedData, iv string) (*PhoneInfo, error) {
|
|
|
+ // 拿到 cipherText
|
|
|
+ cipherText,err := getCipherText(sessionKey, encryptedData, iv)
|
|
|
+ if err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
+ var phoneInfo PhoneInfo
|
|
|
+ err = json.Unmarshal(cipherText, &phoneInfo)
|
|
|
+ if err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
+ if phoneInfo.Watermark.AppID != wxa.AppID {
|
|
|
+ return nil, ErrAppIDNotMatch
|
|
|
+ }
|
|
|
+ return &phoneInfo, nil
|
|
|
+}
|