![Как исправить проблему несоответствия шифра в sftp?](https://rvso.com/image/1451215/%D0%9A%D0%B0%D0%BA%20%D0%B8%D1%81%D0%BF%D1%80%D0%B0%D0%B2%D0%B8%D1%82%D1%8C%20%D0%BF%D1%80%D0%BE%D0%B1%D0%BB%D0%B5%D0%BC%D1%83%20%D0%BD%D0%B5%D1%81%D0%BE%D0%BE%D1%82%D0%B2%D0%B5%D1%82%D1%81%D1%82%D0%B2%D0%B8%D1%8F%20%D1%88%D0%B8%D1%84%D1%80%D0%B0%20%D0%B2%20sftp%3F.png)
Я столкнулся с проблемой, когда сервер был обновлен до RHEL 6.5, а на установке RHEL 5.9 есть автоматизированные bash-скрипты, которые подключаются через команды sftp и ssh.
Теперь новый сервер поддерживает только шифры aes128-ctr, aes192-ctr и aes256-ctr.
Мне удалось обновить команды ssh, чтобы использовать опцию -c с aes256-ctr, и это сработало:
ssh -c aes256-ctr ${remote_host} ${my_command}
Однако, когда я попытался сделать то же самое для sftp:
sftp -oCipher=aes256-ctr ${remote_host} <<< $'get /home/me/* me/'
Я получаю сообщение об ошибке, что клиент не поддерживает те же шифры, что и сервер:
не найдено ни одного соответствующего шифра: клиент arcfour256,aes128-cbc,3des-cbc,blowfish-cbc,cast128-cbc,arcfour,aes192-cbc,aes256-cbc сервер aes128-ctr,aes192-ctr,aes256-ctr
Эти команды ssh и sftp выполняются на одном и том же компьютере RHEL 5.9, поэтому мне интересно, почему это работает для ssh, но не для sftp?
Кроме того, как это исправить, чтобы я мог подключиться с помощью sftp без каких-либо изменений на стороне клиента?
решение1
Директива Cipher
предназначена для SSH версии 1 (которая в настоящее время не используется).
Для SSH версии 2 используйте Ciphers
:
sftp -oCiphers=aes256-ctr
Смотритеssh_config
страница руководства.
Хотя обратите внимание, что также sftp
поддерживает -c
коммутатор. Так что нет необходимости использовать -o
.
Смотритеsftp
страница руководства:
-c cipher
Выбирает шифр, который будет использоваться для шифрования передачи данных.
Эта опция напрямую передаетсясш(1).
Опция поддерживается сOpenSSH 5.4. Изменение замаскировано под«Поддержка большинства аргументов командной строки scp(1) в sftp(1)".
Обратите внимание, что аргумент командной строки -c
в первую очередь эквивалентен директиве Ciphers
(хотя он может возвращаться к Cipher
). Цитата изssh
страница руководства:
-c cipher_spec
Выбирает спецификацию шифра для шифрования сеанса.
Протокол версии 1 допускает спецификацию одного шифра. Поддерживаемые значения: «3des», «blowfish» и «des». Для протокола версии 2cipher_spec
— это разделенный запятыми список шифров, перечисленных в порядке предпочтения. См.Ciphers
ключевое слово вssh_config(5)Чтобы получить больше информации.