Home  >  Article  >  Backend Development  >  寻求一种可逆加密算法,加密数据库自增主键,要求密文越短越好。

寻求一种可逆加密算法,加密数据库自增主键,要求密文越短越好。

WBOY
WBOYOriginal
2016-06-06 20:18:381976browse

主要是为了把主键放到url中,但又不像暴露主键的值,url的原因,越短越美观。
base62也考虑过,主要问题是太容易破解了,肉眼就能看出来。

回复内容:

主要是为了把主键放到url中,但又不像暴露主键的值,url的原因,越短越美观。
base62也考虑过,主要问题是太容易破解了,肉眼就能看出来。

base62 是可以的,你可以乱序一下字母表的顺序,这样就让主键较难还原了。

比如 base62 原有的字母表顺序是 0123456789abcde.....XYZ
你可以改成 0Xfeia92nje....

注意最好保证 0 在首位,因为它有定代表意义。

就是对称加密吧,可以用DES.
寻求一种可逆加密算法,加密数据库自增主键,要求密文越短越好。

<code><?php $key='123';
$orign='qaz123...';
$pwd=do_mencrypt($orign, $key);
echo '明文:'.$orign."<br>";
echo '加密结果:'.$pwd."<br>";
echo '解密结果:'.do_mdecrypt($pwd, $key)."<br>";


function do_mencrypt($input, $key)
{
    $input = str_replace("\n", "", $input);
    $input = str_replace("\t", "", $input);
    $input = str_replace("\r", "", $input);
    $key = substr(md5($key), 0, 24);
    $td = mcrypt_module_open('tripledes', '', 'ecb', '');
    $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
    mcrypt_generic_init($td, $key, $iv);
    $encrypted_data = mcrypt_generic($td, $input);
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    return trim(chop(base64_encode($encrypted_data)));
}


function do_mdecrypt($input, $key)
{
    $input = str_replace("\n", "", $input);
    $input = str_replace("\t", "", $input);
    $input = str_replace("\r", "", $input);
    $input = trim(chop(base64_decode($input)));
    $td = mcrypt_module_open('tripledes', '', 'ecb', '');
    $key = substr(md5($key), 0, 24);
    $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
    mcrypt_generic_init($td, $key, $iv);
    $decrypted_data = mdecrypt_generic($td, $input);
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    return trim(chop($decrypted_data));
}</code>

主流的加密算法加密出来的内容都很长。。
你只能自己撸个简单的哈希算法了
但是太简单你又嫌容易解密
啊啊啊啊啊啊啊

gzip+base64 如何

先用
$id_str = base_convert(10,10,36);
然后取最末位放到最前边(或最后)当 sumhash:

$encrypt_id = base_convert(10,10,36).'0';

然后用 xor加密 或者base64、base62都可

取到id后,先解密,再验证sumhash,再base_convert转回原文

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn