paramiko.SSHException: Unknown private key cipher "AES-128-CBC"

원문:http://jianshu.io/p/7Mm9Wk
오늘 paramiko 를 사용 하여 DSA 키 를 분석 할 때 다음 ERROR 이 나타 납 니 다.
... ...paramiko.SSHException: Unknown private key cipher "AES-128-CBC"

DSA 키 내용 은 다음 과 같 습 니 다.
-----BEGIN DSA PRIVATE KEY-----Proc-Type: 4,ENCRYPTEDDEK-Info: AES-128-CBC,381624AF862F1717C46EF898D9E1FA92... ...OCGYNLsO68FToi8qJEP1DI9Jvk6tpU3y4ebBqSZnX7jr1M5+Hj5rfMqv7+kp3T4R314ae9Ism9AXLIK2miTAcvbexZpbcesadqvo69DMsfhSmKKJYABK3eRYaDlUwkzN... ...-----END DSA PRIVATE KEY-----

사용 ssh-keygen -t rsa 테스트 에 문제 가 없 었 으 나, 이전 DSA 키 를 알 았 을 때 Secure CRT 로 생 성 된 AES 알고리즘 암호 화 를 찾 아 보 니 파 라미 코 가 기본적으로 AES 알고리즘 을 지원 하지 않 아 이전 Unknown Error 오류 가 발생 했 습 니 다.나중에 구 글 을 통 해 관련 답 을 찾 았 습 니 다. Unknown private key ciper AES - 128 - CBC 는 기록 하 는 김 에.
해결 방법 은 수정 paramiko 코드 가 필요 합 니 다. 열기 /usr/lib/pythonX.X/site-packages/paramiko/pkey.py 수정 은 다음 과 같 습 니 다.
from Crypto.Cipher import DES3, AES
 _CIPHER_TABLE = {
    'AES-128-CBC': { 'cipher': AES, 'keysize': 16, 'blocksize': 16, 'mode': AES.MODE_CBC },
    'DES-EDE3-CBC': { 'cipher': DES3, 'keysize': 24, 'blocksize': 8, 'mode': DES3.MODE_CBC }
    }

                                         
이상 수정, 저장 후 종료 하면 됩 니 다.
다음으로 전송:https://blog.51cto.com/mstools/1400232

좋은 웹페이지 즐겨찾기