【问题标题】:Translating weak encryption algorithm from PHP to Coldfusion or Java将弱加密算法从 PHP 转换为 Coldfusion 或 Java
【发布时间】:2015-08-28 00:46:54
【问题描述】:

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

【问题讨论】:

  • php ord() 不等同于您在 CF 中的内容。
  • @ElefantPhave ord() 返回“字符的 ascii 值”。我得到第一个字符并在 asc() 函数中使用它,我认为它返回 ascii 值。那是错的吗?还是你说我应该把整个东西放在一个函数中?
  • @ialexander 这不是 php 版本正在做的事情。它获取每个字符的 ASCII 值,将它们加在一起,然后返回新字符
  • 我明白了。我读得太快了。感谢您花时间回答。
  • 既然你已经弄清楚了,不要忘记var 作用域所有函数局部变量以避免冲突。此外,虽然我意识到这些函数是对原始代码的重写,但您可能希望避免使用像“string”这样的变量名,因为它们是潜在的关键字。

标签: java php coldfusion


【解决方案1】:

删除您的 ord 函数。

你的 CF 中的这一行:

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

应该是:

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

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-02-26
    • 2011-08-14
    • 2013-07-05
    • 1970-01-01
    • 1970-01-01
    • 2018-11-10
    相关资源
    最近更新 更多