求一个可逆的加密算法,要求有点高 要求:1.加密后的长度和加密前的长度一样长2.加密后的字符串中只允许出现a到z中的字母和0到9的数字3.根据秘钥可以再算回来加密前的字符串也都是字母和数字的组合如加密前的字符串:us3kqvu 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 凯撒密码$key = '3ae';$s = caesar_encode('us3kqvu', $key);echo "$s\n";echo caesar_decode($s, $key);function caesar_encode($s, $k) { $k = "$k"; for($i=0; $i<strlen($k); $i++) { $d = base_convert($k{$i}, 36, 10); $t = ''; for($j=0; $j<strlen($s); $j++) $t .= base_convert((base_convert($s{$j}, 36, 10)+$d)%36, 10, 36); $s = $t; } return $t;}function caesar_decode($s, $k) { $k = "$k"; for($i=0; $i<strlen($k); $i++) { $d = 36 - base_convert($k{$i}, 36, 10); $t = ''; for($j=0; $j<strlen($s); $j++) $t .= base_convert((base_convert($s{$j}, 36, 10)+$d)%36, 10, 36); $s = $t; } return $t;}密文:ljubhml原文:us3kqvu 凯撒密码 通过移动字符表映射来实现的,理论上不存在重复的可能性所谓 移动字符表映射 就是例如原文 abcd移动距离 4密文 efgh 一个字节有8位(bit),6位则有2^6=64种可能,字母+数字合计62个所以有个映射表就能压缩到6位内6位转6位的位运算就多的是了,任君选择,再反向映射为字母数字上面的过程都是可逆的 如何查看所分配到的mysql数据库大小?(不是已使用的大小) CSDN-PHP学院 LAMP兄弟连 2010最新视频 php在线解压bz2为后缀的压缩包 用XAMPP和EclipsePDT进行配置PHP开发环境的问题 在php中全角空格如何替换掉 发一个PHP实现网站打包为XML文件的类 php如何分页显示 php文件解密。哪位大神帮忙解密下 微信公众号,新增永久素材(图文)总失败 php项目怎么配置mysql 微信公众平台音乐在线点歌,求指点,一直无法实现呀 php链接嵌入变量,怎么搞啊
$s = caesar_encode('us3kqvu', $key);
echo "$s\n";
echo caesar_decode($s, $key);function caesar_encode($s, $k) {
$k = "$k";
for($i=0; $i<strlen($k); $i++) {
$d = base_convert($k{$i}, 36, 10);
$t = '';
for($j=0; $j<strlen($s); $j++)
$t .= base_convert((base_convert($s{$j}, 36, 10)+$d)%36, 10, 36);
$s = $t;
}
return $t;
}
function caesar_decode($s, $k) {
$k = "$k";
for($i=0; $i<strlen($k); $i++) {
$d = 36 - base_convert($k{$i}, 36, 10);
$t = '';
for($j=0; $j<strlen($s); $j++)
$t .= base_convert((base_convert($s{$j}, 36, 10)+$d)%36, 10, 36);
$s = $t;
}
return $t;
}
密文:ljubhml
原文:us3kqvu
原文 abcd
移动距离 4
密文 efgh
所以有个映射表就能压缩到6位内6位转6位的位运算就多的是了,任君选择,再反向映射为字母数字上面的过程都是可逆的