gpt4 book ai didi

java - 将弱加密算法从 PHP 转换为 Coldfusion 或 Java

转载 作者:行者123 更新时间:2023-11-29 03:05:47 26 4
gpt4 key购买 nike

我正在与某人合作,他让我使用下面列出的函数“加密”我发送到他的网络服务的一些文本。我试图将这些翻译成 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 更容易解释,我也非常乐意。

最佳答案

删除您的 ord 函数。

CF 中的这一行:

char = asc(ord(char) & ord(keychar));

应该是:

char = Chr(Asc(char) + Asc(keychar));

关于java - 将弱加密算法从 PHP 转换为 Coldfusion 或 Java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32261654/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com