我正在与某人合作,使用下面列出的功能“加密”发送给他的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));

09-10 08:46
查看更多