主要是為了把主鍵放到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轉回原文