![Можно ли добавить шифр для sftp-клиента?](https://rvso.com/image/1451234/%D0%9C%D0%BE%D0%B6%D0%BD%D0%BE%20%D0%BB%D0%B8%20%D0%B4%D0%BE%D0%B1%D0%B0%D0%B2%D0%B8%D1%82%D1%8C%20%D1%88%D0%B8%D1%84%D1%80%20%D0%B4%D0%BB%D1%8F%20sftp-%D0%BA%D0%BB%D0%B8%D0%B5%D0%BD%D1%82%D0%B0%3F.png)
У меня возникла проблема, когда сервер был обновлен до RHEL 6.5, а на установке RHEL 5.9 есть автоматизированные скрипты, которые подключаются через команды 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
решение2
Директива 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)Чтобы получить больше информации.