我正在和那些让我加密的人一起工作。我使用下面列出的函数发送给他的webservice的一些文本。我试图将这些翻译成Coldfusion但我的输出与他的版本不匹配。我宁愿简单地使用AES 256并将其称为一天,但我完全没有选择,因为这是他们使用的。有人可以帮我翻译成Coldfusion或Java。
function encrypt($string, $key) {
$result = '';
for($i=0; $i<strlen($string); $i++) {
$char = substr($string, $i, 1);
$keychar = substr($key, ($i % strlen($key))-1, 1);
$char = chr(ord($char)+ord($keychar));
$result.=$char;
}
return base64_encode($result);
}
function decrypt($string, $key) {
$result = '';
$string = base64_decode($string);
for($i=0; $i<strlen($string); $i++) {
$char = substr($string, $i, 1);
$keychar = substr($key, ($i % strlen($key))-1, 1);
$char = chr(ord($char)-ord($keychar));
$result.=$char;
}
return $result;
}
我的Coldfusion版本:
function hideText(argsString, key) {
var result = '';
for(i=1; i <= len(argsString); i++) {
char = mid(argsString, i, 1);
keychar = mid(key, i, 1);
char = asc(ord(char) & ord(keychar));
result &= char;
}
return toBase64(result);
}
function unHideText(argsString, key) {
result = '';
string = toString( ToBinary( argsString ) );
for(i=1; i<= strlen(argsString); i++) {
char = mid(argsString, i, 1);
keychar = mid(key, i, 1);
char = asc(ord(char) - ord(keychar));
result &= char;
}
return result;
}
function ord(any argString){
return Left(argString, 1);
}
我的CF版本并没有使用%,因为我认为它可能只是评估与 i 相同的事情 - 并且它实际上产生了没有它的结果。虽然我可能会遗漏 为什么 但它首先出现在那里。任何使用PHP和CF的人都能更好地了解更好的翻译吗?如果它更容易在java中解释我也非常满意。
答案 0 :(得分:4)
删除ord
功能。
CF中的这一行:
char = asc(ord(char) & ord(keychar));
应该是:
char = Chr(Asc(char) + Asc(keychar));