Перевод слабого алгоритма шифрования с PHP на Coldfusion или Java

Я работаю с кем-то, кто заставляет меня «зашифровать» некоторый текст, который я посылаю его веб-сервису, используя функцию, указанную ниже. Я пытался перевести их в 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, мне это тоже вполне по душе.

1

Решение

Удалить свой ord функция.

Эта строка в вашем CF:

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

должно быть:

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

Другие решения

Других решений пока нет …