[질문] OpenSSL SSL_CTX_use_PrivateKey_file
글쓴이: hopeful1213 / 작성시간: 화, 2005/12/06 - 5:09오후
openssl를 사용하여 MFC 개발을 하고 있습니다.
(리눅스 포탈에 부득히 하게 올리게 된점 사죄드립니다. )
MFC 개발 전에 openssl 기본적인 통신을 구현을 하였고요. 그다음 MFC에 그 소스를 넣는 중간에 문제가 생기네요
SSL_load_error_strings(); SSLeay_add_ssl_algorithms(); ssl_pmeth = SSLv23_server_method(); ssl_pctx = SSL_CTX_new(ssl_pmeth); if(!ssl_pctx) return FALSE; if(SSL_CTX_use_certificate_file(ssl_pctx, CERTF, SSL_FILETYPE_PEM) <= 0){ ERR_print_errors_fp(stderr); return FALSE; } if(SSL_CTX_use_PrivateKey_file(ssl_pctx, KEYF, SSL_FILETYPE_PEM)<= 0){ ERR_print_errors_fp(stderr); return FALSE; } if(!SSL_CTX_check_private_key(ssl_pctx)){ return FALSE; }
원래 위에 SSL_CTX_use_PrivateKey_file 된 함수는 콘솔에서 인증키 암호를 입력받는 함수입니다.
기본적으로 콘솔에서는 정상적으로 실행됩니다.
----------------------
Enter PEM : // 하고 기다리면 암호를 입력하면 실행됩니다.
-------------------------
그런데 MFC에서는 이부분에서 멈춰버리네요.
소스 분석을 해보니 내부적으로 bgets 함수를 사용하여 입력받는 것 같습니다.
어떻게 하면 해결이 가능할까요? 다른 방법 내지는 SSL_CTX_use_PrivateKey_file 함수 대체가 가능한 다른 것이 없는지요?
고수님들의 조언 부탁드립니다.
Forums:
인증키 암호의 입력 방법을 지정해 주지 않으면 기본적으로 (질문글에서 인
인증키 암호의 입력 방법을 지정해 주지 않으면 기본적으로 (질문글에서 인용해 주신 것처럼) 콘솔로 입력을 받게 됩니다. SSL_CTX_set_default_passwd_cb() 함수를 사용해서 암호 입력 방법을 지정해 주시면 됩니다. SSL_CTX_set_default_passwd_cb_userdata()를 이용해서 암호 문자열을 직접 입력해 줄 수도 있고, SSL_CTX_set_default_passwd_cb()를 이용해서 암호 문자열을 입력해 주는 콜백 함수를 지정해 줄 수도 있습니다.
$PWD `date`
감사합니다.
덕분에 잘 해결되었습니다.
감사합니다. ^^
댓글 달기