zoukankan      html  css  js  c++  java
  • golang token的生成和获取

    golang 加减密

    token的生成和获取

    // GetToken 获取token
    func GetToken(appId, userId, deviceId int64, expire int64, publicKey string) (string, error) {
    	info := TokenInfo{
    		AppId:    appId,
    		UserId:   userId,
    		DeviceId: deviceId,
    		Expire:   expire,
    	}
    	bytes, err := json.Marshal(info)
    	if err != nil {
    		logger.Sugar.Error(err)
    		return "", err
    	}
    
    	token, err := RsaEncrypt(bytes, []byte(publicKey))
    	if err != nil {
    		return "", err
    	}
    	return base64.StdEncoding.EncodeToString(token), nil
    }
    
    // DecryptToken 对加密的token进行解码
    func DecryptToken(token string, privateKey string) (*TokenInfo, error) {
    	bytes, err := base64.StdEncoding.DecodeString(token)
    	if err != nil {
    		logger.Sugar.Error(err)
    		return nil, err
    	}
    	result, err := RsaDecrypt(bytes, Str2bytes(privateKey))
    	if err != nil {
    		logger.Sugar.Error(err)
    		return nil, err
    	}
    
    	var info TokenInfo
    	err = jsoniter.Unmarshal(result, &info)
    	if err != nil {
    		logger.Sugar.Error(err)
    		return nil, err
    	}
    	return &info, nil
    }
    

    加减密

    // 公钥生成
    //openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
    
    // 加密
    func RsaEncrypt(origData []byte, publicKey []byte) ([]byte, error) {
    	//解密pem格式的公钥
    	block, _ := pem.Decode(publicKey)
    	if block == nil {
    		return nil, errors.New("public key error")
    	}
    	// 解析公钥
    	pubInterface, err := x509.ParsePKIXPublicKey(block.Bytes)
    	if err != nil {
    		return nil, err
    	}
    	// 类型断言
    	pub := pubInterface.(*rsa.PublicKey)
    	//加密
    	return rsa.EncryptPKCS1v15(rand.Reader, pub, origData)
    }
    
    // 解密
    func RsaDecrypt(ciphertext []byte, privateKey []byte) ([]byte, error) {
    	//解密
    	block, _ := pem.Decode(privateKey)
    	if block == nil {
    		return nil, errors.New("private key error!")
    	}
    	//解析PKCS1格式的私钥
    	priv, err := x509.ParsePKCS1PrivateKey(block.Bytes)
    	if err != nil {
    		return nil, err
    	}
    	// 解密
    	return rsa.DecryptPKCS1v15(rand.Reader, priv, ciphertext)
    }
    
  • 相关阅读:
    菜根谭#308
    菜根谭#307
    菜根谭#306
    菜根谭#305
    菜根谭#304
    菜根谭#303
    菜根谭#302
    菜根谭#301
    菜根谭#300
    菜根谭#299
  • 原文地址:https://www.cnblogs.com/tomtellyou/p/12769270.html
Copyright © 2011-2022 走看看