search

Home  >  Q&A  >  body text

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

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

PHPzPHPz2902 days ago659

reply all(5)I'll reply

  • PHP中文网

    PHP中文网2017-04-10 16:48:16

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

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

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

    reply
    0
  • 怪我咯

    怪我咯2017-04-10 16:48:16

    就是对称加密吧,可以用DES.

    <?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));
    }

    reply
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-10 16:48:16

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

    reply
    0
  • PHPz

    PHPz2017-04-10 16:48:16

    gzip+base64 如何

    reply
    0
  • 天蓬老师

    天蓬老师2017-04-10 16:48:16

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

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

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

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

    reply
    0
  • Cancelreply