维吉尼亚加密算法 PHP版

老师布置期末要做一个维吉尼亚密码的加密和解密程序,话说我C#、JAVA啊什么得都不会,只会PHP和PYTHON。

压根不知道什么叫维吉尼亚算法,上网查了下,加密的算法蛮简单的,思路很清晰。于是用PHP写了个PHP版的维吉尼亚的加密算法。

';
$mkey = 'Jiangbin';                             //密钥
$mstr = 'I known what love is because of you';	//原文
$nkey = strtoupper($mkey);			//转成大写
$nstr = strtoupper($mstr);				//转成大写(明文)
$nstr = str_replace(chr(32),'',$nstr);          	//去空格
$key = str_split($nkey);                        //密钥转换成数组
$str = str_split($nstr);                        //明文转换成数组
$keylen = count($key);                          //获取密钥长度
$strlen = count($str);                          //获取去空格后的明文长度
$arr = array();
for( $i = 0; $i < $strlen; $i++) {
	$arr[$i] = chr(((ord($str[$i])-65) + (ord($key[$i%$keylen])-65))%26+65);	
}
echo '密钥:'.$mkey."
"; echo '原文:'.$mstr."
"; echo '明文:'.$nstr."
"; echo '密文:'.implode("",$arr); echo '
'; ?>

你可能感兴趣的:(PHP,加密,算法,php,python,解密,java)