微信小程序获取手机号 -加密数据解密算法-golang版本

微信小程序端主动获取用户手机号时需要后端把加密的数据解密才能得到用户手机号

需要注意的点:

1:key  密钥  前端每获取一次用户openid就会刷新一次。所以在解密数据前要保证密钥为最新的。

微信文档链接地址:

https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/signature.html#加密数据解密算法


package main

import (
	"crypto/aes"
	"crypto/cipher"
	"encoding/base64"
	"encoding/json"
	"fmt"
)
// CBC 模式
//解密
/**
* rawData 原始加密数据
* key  密钥
* iv  向量
 */
func Dncrypt(rawData, key, iv string) (string, error) {
	data, err := base64.StdEncoding.DecodeString(rawData)
	key_b, err_1 := base64.StdEncoding.DecodeString(key)
	iv_b, _ := base64.StdEncoding.DecodeString(iv)
	if err != nil {
		return "", err
	}
	if err_1 != nil {
		return "", err_1
	}
	dnData, err := AesCBCDncrypt(data, key_b, iv_b)
	if err != nil {
		return "", err
	}
	return string(dnData), nil
}

// 解密
func AesCBCDncrypt(encryptData, key, iv []byte) ([]byte, error) {
	block, err := aes.NewCipher(key)
	if err != nil {
		panic(err)
	}
	blockSize := block.BlockSize()
	if len(encryptData) < blockSize {
		panic("ciphertext too short")
	}
	if len(encryptData)%blockSize != 0 {
		panic("ciphertext is not a multiple of the block size")
	}
	mode := cipher.NewCBCDecrypter(block, iv)
	mode.CryptBlocks(encryptData, encryptData)
	// 解填充
	encryptData = PKCS7UnPadding(encryptData)
	return encryptData, nil
}

//去除填充
func PKCS7UnPadding(origData []byte) []byte {
	length := len(origData)
	unpadding := int(origData[length-1])
	return origData[:(length - unpadding)]
}
func main() {
	str := "****qU9A=="
	key := "******P5Y2b9SfejeA=="
	iv := "*****FLgzU09FtANlRw=="
	src, err := Dncrypt(str, key, iv)
	fmt.Println(err)
	var s = map[string]interface{}{}
	json.Unmarshal([]byte(src), &s)
	fmt.Printf("== %+v", src)
	fmt.Printf("cc== %+v", s)

	
}

解密后的数据:

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

附一篇加解密的文章:http://blog.studygolang.com/2013/01/go%E5%8A%A0%E5%AF%86%E8%A7%A3%E5%AF%86%E4%B9%8Bdes/

 

 

你可能感兴趣的:(go)