Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/github/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
将弱加密算法从PHP转换为Coldfusion或Java_Java_Php_Coldfusion - Fatal编程技术网

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

将弱加密算法从PHP转换为Coldfusion或Java,java,php,coldfusion,Java,Php,Coldfusion,我正在与某人合作,他让我使用下面列出的函数“加密”发送给他的Web服务的一些文本。我试图将这些转换为Coldfusion,但我的输出与他的版本不匹配。我更愿意简单地使用AES 256,并称之为一天,但实际上我没有选择,因为这是他们使用的。有人能帮我翻译成Coldfusion或Java吗 function encrypt($string, $key) { $result = ''; for($i=0; $i<strlen($string); $i++) { $char = s

我正在与某人合作,他让我使用下面列出的函数“加密”发送给他的Web服务的一些文本。我试图将这些转换为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版本没有使用%,因为我认为它的计算结果可能与我的计算结果相同,而且它实际上会生成一个没有它的结果。虽然我可能不知道它为什么会在那里。任何同时使用PHP和CF的人对更好的翻译有什么见解?如果用java更容易解释的话,我也很乐意这样做。

删除ord函数

您的CF中的这一行:

char = asc(ord(char) & ord(keychar));
应该是:

char = Chr(Asc(char) + Asc(keychar));
删除您的ord函数

您的CF中的这一行:

char = asc(ord(char) & ord(keychar));
应该是:

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

php与CF中的不同。@elefantphare ord返回“字符的ascii值”。我得到第一个字符并在asc函数中使用它,我认为它返回ascii值。这不对吗?或者你是说我应该把所有的东西都放在一个函数中?@I我想这不是php版本所做的。它获取每个字符的ASCII值,将它们相加,然后返回新字符see。我读得太快了。感谢您花时间回答。现在您已经弄明白了,不要忘记对所有函数局部变量进行var作用域,以避免冲突。此外,尽管我意识到这些函数是对原始代码的重写,但您可能希望避免使用字符串等变量名,因为它们是潜在的关键字。php与CF中的不同。@elefantpord返回“字符的ascii值”。我得到第一个字符并在asc函数中使用它,我认为它返回ascii值。这不对吗?或者你是说我应该把所有的东西都放在一个函数中?@I我想这不是php版本所做的。它获取每个字符的ASCII值,将它们相加,然后返回新字符see。我读得太快了。感谢您花时间回答。现在您已经弄明白了,不要忘记对所有函数局部变量进行var作用域,以避免冲突。此外,尽管我意识到这些函数是对原始代码的重写,但您可能希望避免使用字符串之类的变量名,因为它们是潜在的关键字。