var sha1=CryptoJS.SHA1("abc");
document.write("sha1:",sha1);
document.write("
");
var sha1_Latin=sha1.toString(CryptoJS.enc.Latin1);
document.write("sha1_Latin:",sha1_Latin);
document.write("Latin.len:",sha1_Latin.length);
document.write("
");
var sha1_hex=strToHex(sha1_Latin);//此处为自己定义的一个函数,将字符串转换为ASCII的16进制形式
document.write("hex:",sha1_hex);
document.write("
");
var xmlhttp1;
if (window.XMLHttpRequest)
{
xmlhttp1=new XMLHttpRequest();
}
else
{
xmlhttp1=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp1.open("GET","web/tes.php?sha1_html="+sha1_Latin,false);//发送G给服务器
xmlhttp1.send();
document.write(xmlhttp1.responseText);
$username_php=$_GET['sha1_html'];
cho "true";
echo '
';
echo $username_php;
echo '
';
echo strlen($username_php);
echo '
';
echo bin2hex($username_php);
echo '
';
?>
该代码JS端自主输出的
sha1_Latin:©>6Gjº>%qxPÂlÐØ / /此段为sha1(“abc”)生成的字符串
Latin.len:20
hex:a9993e364706816aba3e25717850c26c9cd0d89d//此段为sha1_Latin的16进制字符串形式,可以确定此处的hex转换是正确的
而通过AJAX传输到php后在浏览器端输出的
©>6Gjº>%qxPÂlÐØ //此处看着仍和前面的sha1_Latin对应
29//此处的长度不对应了
c2a9c2993e364706c2816ac2ba3e25717850c3826cc29cc390c398c29d//转换为16进制发现和前面的hex不一样,观察发现多了一些c2,c3,请问是为什么?????