[완료 :해결책첨부 필요하신분 보세요]openssl 개인키로드중 에러 질문입니다.

anaud2의 이미지

openssl RSA 개인키를 만들고 있는데
어제까지 개인키의 비밀번호 설정에 궁금증을 가지고 질문을 올렸는데
오늘은 개인키를 비밀번호를 설정을 하고 비밀번호로 입력을해도 로드가 안되는 문제 입니다.

FILE *privatekeyfile = fopen("keyfile.pem","wt");

PEM_write_PrivateKey(privatekeyfile, pkey, NULL ,NULL,0,NULL, NULL);

privKey = PEM_read_PrivateKey(privatekeyfile, NULL, 0,NULL);

이렇게 개인키를 만들고 불러오면 전혀 문제가 없이 로드가 가능하게 됩니다.
비밀번호가 안걸려 있으니까요

FILE *privatekeyfile = fopen("keyfile.pem","wt");

PEM_write_PrivateKey(privatekeyfile, pkey, EVP_des_ede3_cbc() ,NULL,0,NULL, "hello");

privkey = PEM_read_PrivateKey(privatekeyfile, NULL, 0,"hello");

이렇게 하면 안됩니다. 비밀번호가 틀렸다는 식인거 같은데
3064:error:0906B072:lib(9):func(107):reason(114):.\crypto\pem\pem_lib.c:481:

이런식으로 에러가 나옵니다 에러문은 검색을해봐도 안나오더라구요.

왜 같은 문자열을 넣었는데 입력을해도 안되는것일까요 이해가 전 되질 않네요..
이런비슷한 일하신분 안계신가요?

========================================
해결책
========================================
에러1 : 3064:error:0906B072:lib(9):func(107):reason(114):.\crypto\pem\pem_lib.c:481:
에러2 : 192:error:0906B072:PEM routines:PEM_get_EVP_CIPHER_INFO:unsupported encryption:
\crypto\pem\pem_lib.c:481:

에러 1의 경우 ERR_load_crypto_strings(); <- 실행하지 않아서 에러내용이 자세히 나오지 않음
함수에 명시적으로 ERR_load_crypto_strings(); 해주면 에러내용이 자세요 나옴
ERR_print_errors_fp (stderr); <-에러 출력

위의 에러는 개인키를 로드할때 비밀번호를(pass phrase) 맞게 넣어줘도 에러가 발생 키로드 안됨
OpenSSL_add_all_algorithms(); <---를 명시적으로 사전에 선언을 해주면
문제 없이 돌아감..

제생각에는 EVP_des_ede3_cbc() 이렇게 데스로 암호화해준 개인키를 로드하기 위해 암호 알고리즘이 필요? 해서 그런거 같아요

이걸로 2틀을 고생해서 저랑 비슷한 사유로 고생하시는분에게 힘이 되었으면 좋겠네요

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.