Phpseclib заполнение нулевым байтом

Как добавить заполнение нулевым байтом в phpseclib с методом шифрования 3des в режиме EBC?

Вот мой текущий код:

$cipher = new TripleDES(TripleDES::MODE_ECB);
$cipher->setKey('1234567890ABCDEFGHIJKLMN');

Как насчет $cipher->enablePadding();? Поскольку TripleDES расширяет DES расширяет BlockCipher расширяет SymmetricKey, вы можете использовать функцию enablePadding(), определенную в классе SymmetricKey: github.com/phpseclib/phpseclib/blob/master/phpseclib/Crypt/…‌​. Хотя на самом деле не пробовал.

Raptor 25.02.2019 07:14

можем ли мы настроить символ заполнения в методе enablePadding? например $cipher -> enablePadding('\0');

oentoro 25.02.2019 08:15
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
2
241
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Просто разберитесь:

  1. Отключить заполнение:

    $cipher->disablePadding();
    
  2. Вручную дополнить сообщение:

    $message_padded = $urlencoded;
    if (strlen($message_padded) % 8) {
        $message_padded = str_pad($message_padded,
            strlen($message_padded) + 8 - strlen($message_padded) % 8, "\0");
    }
    
  3. зашифровать:

    $result = $cipher -> encrypt($message_padded);
    

Ваш подход выглядит хорошо, но почему вы хотите это сделать? Кстати, вы можете добавить новый метод для переноса приведенных выше кодов, чтобы вы могли легко повторно использовать настраиваемый метод заполнения.

Raptor 26.02.2019 07:57

1. Поскольку существует сервис (партнер), для которого требуется описанный выше метод шифрования. 2. Попробую, спасибо за совет

oentoro 26.02.2019 08:56

Другие вопросы по теме