RC4加解密算法(PHP版)

//加密(rc4)
function rc4encrypt($data,$pwd){
    $res = rc4($data,$pwd);
    return 'CB01'.toHex($res);
}
//解密(rc4)
function rc4decrypt($data,$pwd){
    $str = fromHex($data);
    return rc4($str,$pwd);
}
/**
 * [rc4 description]
 * @param  [type] $data [需加密的数据]
 * @param  [type] $pwd  [密钥]
 * @return [type]       [加密后为二进制,需要转换成16进制]
 */
function rc4($data, $pwd) {
    $key[]       = "";
    $box[]       = "";
    $pwd_length  = strlen($pwd);
    $data_length = strlen($data);
    $cipher      = '';
    for ($i = 0; $i < 256; $i++) {
        $key[$i] = ord($pwd[$i % $pwd_length]);
        $box[$i] = $i;
    }
    for ($j = $i = 0; $i < 256; $i++) {
        $j       = ($j + $box[$i] + $key[$i]) % 256;
        $tmp     = $box[$i];
        $box[$i] = $box[$j];
        $box[$j] = $tmp;
    }
    for ($a = $j = $i = 0; $i < $data_length; $i++) {
        $a       = ($a + 1) % 256;
        $j       = ($j + $box[$a]) % 256;
        $tmp     = $box[$a];
        $box[$a] = $box[$j];
        $box[$j] = $tmp;
        $k = $box[(($box[$a] + $box[$j]) % 256)];
        $cipher .= chr(ord($data[$i]) ^ $k);
    }
    return $cipher;
}
/**
 * 把数据转换成16进制
 * @param  [type]  $sa  [需要转换的数据]
 * @param  integer $len [数据长度]
 */
function toHex($sa , $len = 0){
    $buf = "";
    if( $len == 0 )
        $len = strlen($sa) ;
    for ($i = 0; $i < $len; $i++)
    {
        $val = dechex(ord($sa{$i}));  
        if(strlen($val)< 2) 
            $val = "0".$val;
            $buf .= $val;
    }
    return $buf;
}
/**
 * 把16进制转换成字符串
 * @param  [type] $sa [16进制数据]
 */
function fromHex($sa){
    $buf = "";
    $len = strlen($sa) ;
    for($i = 0; $i < $len; $i += 2){
        $val = chr(hexdec(substr($sa, $i, 2)));
        $buf .= $val;
    }
    return $buf;
}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RC4是一种流加密算法,由Ronald Rivest于1987年所设计。它被广泛应用于SSL、TLS、WEP、WPA等安全协议中,是一种高效的加密算法。Python支持RC4加密解密算法,只需要使用相应的库即可。 在Python中,使用RC4加密解密算法需要安装pycryptodome库,该库支持多种加密解密算法。使用以下命令可安装该库: pip install pycryptodome 安装完成后,可以使用pycryptodome库中的Crypto.Cipher包中的ARC4类进行RC4加密解密操作。其中,ARC4.new(key)用于创建一个ARC4实例,key为RC4加密密钥。encrypt(plain)方法用于加密明文,plain为要加密的明文字符串;decrypt(cipher)方法用于解密密文,cipher为要解密的密文字符串。 下面是一个简单的RC4加密解密示例: from Crypto.Cipher import ARC4 # RC4加密 def rc4_encrypt(key, plain): rc4 = ARC4.new(key) cipher = rc4.encrypt(plain) return cipher # RC4解密 def rc4_decrypt(key, cipher): rc4 = ARC4.new(key) plain = rc4.decrypt(cipher) return plain # 测试 key = b'123456' plain = b'Hello, World!' cipher = rc4_encrypt(key, plain) print(cipher) # b'h\xab\x0e\xce\xf1d\xa7\x8fo\xa2K\xf7-Q\xcc' plain = rc4_decrypt(key, cipher) print(plain) # b'Hello, World!' 在该示例中,我们使用了ARC4类进行RC4加密解密操作,可以发现在加密和解密时,使用的是同一个密钥。密钥的长度可以任意指定。需要注意的是,由于RC4算法不适合用于长数据的加密,因此,在使用RC4加密时,建议每次仅加密一小段数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值