PBE算法加密

PBE算法是一种常用的密码加密方法,涉及加密或解密操作,需要三个参数:操作类型、密钥和盐。该算法通过结合盐和密码进行加密,实现简单高效。
摘要由CSDN通过智能技术生成

PBE是一种常见的用于加密密码的一种方式,和昨天的DES加密一样,有三个参数,行为(加密或者解密),密钥,盐。

它其实就是将盐和密码杂糅在一块进行加密。很简便。

import java.security.Key;
import java.util.Random;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.PBEKeySpec;
import javax.crypto.spec.PBEParameterSpec;

/**
 * PBE安全编码组件
 */
public abstract class PBECoder extends Coder {
	/**
	 * 支持以下任意一种算法
	 * 
	 * <pre>
	 * PBEWithMD5AndDES 
	 * PBEWithMD5AndTripleDES 
	 * PBEWithSHA1AndDESede
	 * PBEWithSHA1AndRC2_40
	 * </pre>
	 */
	public static final String ALGORITHM = "PBEWITHMD5andDES";

	/**
	 * 盐初始化
	 * 
	 * @return
	 * @throws Exception
	 */
	public static byte[] initSalt() throws Exception {
		byte[] salt = new byte[8];
		Random random = new Random();
		random.nextBytes(salt);
		return salt;
	}

	/**
	 * 转换密钥<br>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Go语言实现PBE加密算法的示例代码: ```go package main import ( "crypto/cipher" "crypto/des" "crypto/md5" "encoding/base64" "fmt" ) func main() { // 设置加密参数 password := "123456" // 密码 salt := "salt" // 盐值 iterations := 1000 // 迭代次数 // 生成密钥 key := pbkdf1([]byte(password), []byte(salt), iterations, 8) // 加密明文 plaintext := "hello world" ciphertext, err := pbeEncrypt([]byte(plaintext), key) if err != nil { panic(err) } // 输出加密结果 fmt.Println(base64.StdEncoding.EncodeToString(ciphertext)) // 解密密文 decrypted, err := pbeDecrypt(ciphertext, key) if err != nil { panic(err) } // 输出解密结果 fmt.Println(string(decrypted)) } // PBE加密 func pbeEncrypt(plaintext []byte, key []byte) ([]byte, error) { // 创建加密器 block, err := des.NewCipher(key) if err != nil { return nil, err } iv := make([]byte, block.BlockSize()) stream := cipher.NewCTR(block, iv) // 加密明文 ciphertext := make([]byte, len(plaintext)) stream.XORKeyStream(ciphertext, plaintext) return ciphertext, nil } // PBE解密 func pbeDecrypt(ciphertext []byte, key []byte) ([]byte, error) { // 创建解密器 block, err := des.NewCipher(key) if err != nil { return nil, err } iv := make([]byte, block.BlockSize()) stream := cipher.NewCTR(block, iv) // 解密密文 plaintext := make([]byte, len(ciphertext)) stream.XORKeyStream(plaintext, ciphertext) return plaintext, nil } // PBKDF1算法 func pbkdf1(password []byte, salt []byte, iterations int, keyLen int) []byte { key := password for i := 0; i < iterations; i++ { data := append(key, salt...) hash := md5.Sum(data) key = hash[:] } return key[:keyLen] } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值