欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

golang如何實現(xiàn)對用戶加密數(shù)據(jù)進行解密?

加密數(shù)據(jù)解密算法

接口如果涉及敏感數(shù)據(jù)(如wx.getUserInfo當中的 openId 和 unionId),接口的明文內(nèi)容將不包含這些敏感數(shù)據(jù)。開發(fā)者如需要獲取敏感數(shù)據(jù),需要對接口返回的加密數(shù)據(jù)(encryptedData) 進行對稱解密。 解密算法如下:

創(chuàng)新互聯(lián)是一家專業(yè)提供平安企業(yè)網(wǎng)站建設,專注與做網(wǎng)站、成都網(wǎng)站建設、H5場景定制、小程序制作等業(yè)務。10年已為平安眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進行中。

  1. 對稱解密使用的算法為 AES-128-CBC,數(shù)據(jù)采用PKCS#7填充。
  2. 對稱解密的目標密文為 Base64_Decode(encryptedData)。
  3. 對稱解密秘鑰 aeskey = Base64_Decode(session_key), aeskey 是16字節(jié)。
  4. 對稱解密算法初始向量 為Base64_Decode(iv),其中iv由數(shù)據(jù)接口返回。

核心代碼

wechat.go
package wechat

import (
    "crypto/aes"
    "crypto/cipher"
    "encoding/base64"
    "encoding/json"
    "errors"
)

var (
    ErrAppIDNotMatch       = errors.New("app id not match")
    ErrInvalidBlockSize    = errors.New("invalid block size")
    ErrInvalidPKCS7Data    = errors.New("invalid PKCS7 data")
    ErrInvalidPKCS7Padding = errors.New("invalid padding on input")
)

type WxUserInfo struct {
    OpenID    string `json:"openId"`
    UnionID   string `json:"unionId"`
    NickName  string `json:"nickName"`
    Gender    int    `json:"gender"`
    City      string `json:"city"`
    Province  string `json:"province"`
    Country   string `json:"country"`
    AvatarURL string `json:"avatarUrl"`
    Language  string `json:"language"`
    Watermark struct {
        Timestamp int64  `json:"timestamp"`
        AppID     string `json:"appid"`
    } `json:"watermark"`
}

type WXUserDataCrypt struct {
    appID, sessionKey string
}

func NewWXUserDataCrypt(appID, sessionKey string) *WXUserDataCrypt {
    return &WXUserDataCrypt{
        appID:      appID,
        sessionKey: sessionKey,
    }
}

// pkcs7Unpad returns slice of the original data without padding
func pkcs7Unpad(data []byte, blockSize int) ([]byte, error) {
    if blockSize <= 0 {
        return nil, ErrInvalidBlockSize
    }
    if len(data)%blockSize != 0 || len(data) == 0 {
        return nil, ErrInvalidPKCS7Data
    }
    c := data[len(data)-1]
    n := int(c)
    if n == 0 || n > len(data) {
        return nil, ErrInvalidPKCS7Padding
    }
    for i := 0; i < n; i++ {
        if data[len(data)-n+i] != c {
            return nil, ErrInvalidPKCS7Padding
        }
    }
    return data[:len(data)-n], nil
}

func (w *WXUserDataCrypt) Decrypt(encryptedData, iv string) (*WxUserInfo, error) {
    aesKey, err := base64.StdEncoding.DecodeString(w.sessionKey)
    if err != nil {
        return nil, err
    }
    cipherText, err := base64.StdEncoding.DecodeString(encryptedData)
    if err != nil {
        return nil, err
    }
    ivBytes, err := base64.StdEncoding.DecodeString(iv)
    if err != nil {
        return nil, err
    }
    block, err := aes.NewCipher(aesKey)
    if err != nil {
        return nil, err
    }
    mode := cipher.NewCBCDecrypter(block, ivBytes)
    mode.CryptBlocks(cipherText, cipherText)
    cipherText, err = pkcs7Unpad(cipherText, block.BlockSize())
    if err != nil {
        return nil, err
    }
    var userInfo WxUserInfo
    err = json.Unmarshal(cipherText, &userInfo)
    if err != nil {
        return nil, err
    }
    if userInfo.Watermark.AppID != w.appID {
        return nil, ErrAppIDNotMatch
    }
    return &userInfo, nil
}

main.go 文件
package main

import (
    "fmt"
    "test/wxbizdatacrypt"
)

func main() {
    appID := "wx33f640141e02040e"
    sessionKey := `SE/BLocg+sMlvcKmxm8vQA==`
    encryptedData :="7SfFtStsHqKZYhbIkke3BH2bCRzGD15T0jEiUtuksrl9lDeHm9LsPmswJymBXuinPCiXkZhd/uq7s7pACTvbWuvvoKEwz5fAJ6Vr9bTx79XVxiIN4r+Fwm6QHO9DjPkFrxTGAZvMYLyH6IOyOV/nmmlMoBM3G4peSnBi1qCYukwlyCMNp67lb93wSiPAoI7eRhYYw8ayPTsZ/MAJ9CBBUiCwM5aFOUWrMKNTikeq7YVjNCv7KCz0LJTrMKda0YMS0J/034L8x9vJ1OnIkxlWVMQEy/f55IfWVHI1I1fSKd5azzyVKXCbWDpU0PLJnU8XM/l4L7ZUlDOcRMR5KQVGhB9rIjVkykdXUPQK87v8lpnitslK06XceOJqDjK6mRkhJWOYpFUozZa6idFV6xmLZX8bkBsLxczzp1h/satEH7rIz3nKbxd3O1c+3dI2soSt8qFtaumcGdwhenTm+at0gxccAp8JD8PZiB5ZDLTofZIQ4RmI004SIExYUDZUje9mZO+3aC8McVwzrEyK7NKD/NZ5/dYPgDRwzBl1Vm99niY="
    iv := "z3tGYrgMcbLzd0qXqZuduQ=="
    pc := wxbizdatacrypt.NewWXBizDataCrypt(appID, sessionKey)
    userInfo, err := pc.Decrypt(encryptedData, iv)
    if err != nil {
        fmt.Println(err.Error())
        return
    }
    fmt.Printf("userData:%+v", userInfo)
}

結果

golang如何實現(xiàn)對用戶加密數(shù)據(jù)進行解密?

網(wǎng)頁名稱:golang如何實現(xiàn)對用戶加密數(shù)據(jù)進行解密?
當前鏈接:http://aaarwkj.com/article8/pjdeip.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供關鍵詞優(yōu)化網(wǎng)站制作、響應式網(wǎng)站、小程序開發(fā)、網(wǎng)站維護、手機網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
校花出白浆视频一区二区三区| 中日韩中文字幕一区二区| 中文字幕在线看精品乱码| 亚洲欧美日韩一区二区视频| 亚洲一区二区三区日韩精品| 18禁免费无遮挡免费视频| 国产乡下三级_三级全黄| 少妇欧美日韩精品在线观看 | 国产一区 亚洲精品| 欧美激情片免费在线观看| 热门精品一区二区三区| 欧美性精品不卡在线观看| 日韩久久精品国产亚洲av成人| 欧美十日本亚洲激情视频| 中文字幕在线看二区不卡 | 一区二区三区四区在线视频观看 | 十八禁无遮挡污污污网站| 最新手机免费黄色av网站| 久久精品国产亚洲av麻豆她| 白小白的视频在线观看| 在线不卡日本v二区到六区| 亚洲中文有码在线播放| 免费成人自拍偷拍视频| 美日韩黄色大片免费看| 欧美在线观看黄片视频| 激情综合婷婷中文字幕| 亚洲天堂男人的天堂狠狠操| 亚洲男人天堂日本一区| 午夜未满十八禁止观看| 欧美一区二区高清不卡| 国产亚洲欧美久久精品| 丁香六月婷婷激情啪啪综合 | 黄片视频免费在线观看播放| 欧美日韩国产精品一区二区在线观看 | 中文字幕国产成人在线视频| 97国产成人精品视频免费| 国产麻豆精品二区视频| 人妻熟女一区二区aⅴ在线视频| 国产成人一区二区三区综合区| 女同同性av观看免费| 黄色大片免费在线观看|