首页 >后端开发 >php教程 > 正文

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

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

回复内容:

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

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

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

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

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

";
echo '加密结果:'.$pwd."
"; echo '解密结果:'.do_mdecrypt($pwd, $key)."
"; 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)); }

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

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转回原文

php中文网最新课程二维码

声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理

  • 相关标签:php
  • 相关文章

    相关视频


    网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
  • 专题推荐

    作者信息

    php中文网

    认证0级讲师

    推荐视频教程
  • javascript初级视频教程javascript初级视频教程
  • jquery 基础视频教程jquery 基础视频教程
  • 视频教程分类