> 백엔드 개발 > PHP 튜토리얼 > 求一个可逆的加密算法,要求有点高

求一个可逆的加密算法,要求有点高

WBOY
풀어 주다: 2016-06-23 14:17:20
원래의
1247명이 탐색했습니다.

要求:
1.加密后的长度和加密前的长度一样长
2.加密后的字符串中只允许出现a到z中的字母和0到9的数字
3.根据秘钥可以再算回来
加密前的字符串也都是字母和数字的组合
如加密前的字符串:us3kqvu


回复讨论(解决方案)

你可以试试凯撒加密和栅栏加密,或者将两种方法都用进去

凯撒密码

$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

凯撒密码

$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位的位运算就多的是了,任君选择,再反向映射为字母数字

上面的过程都是可逆的

凯撒加密和栅栏加密

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿