RSA공개키 암호화 알고리즘, AES 블록 알고리즘 복호화 메세지 길이에 대해 질문드릴게 있습니다.

anaud2의 이미지

안녕하세요 오늘도 어려운 문제를 만나서 이렇게 질문드립니다.
openssl의 함수를 바탕으로 RSA공개키 암호화 알고리즘과 AES_256_CBC모드 블록 알고리즘을 만들었는데요

에러 핸들링으로 입력되는 메세지와 암,복호화 크기를 비교해서
만약 복호화를 했는데 복호화 저장할 메세지의 크기가 적어버리면 생기는 버퍼 오버플로우를 방지하기 위해 작업하고 있습니다.

RSA공개키 암호화 알고리즘의 경우 키값에 따라 암호화 메세지크기가 정해진다고 알고 있습니다. 저같은경우 256바이트 키를 써서
어떤메세지를 넣어도 256바이트짜리를 만드는걸로 알고있습니다.(틀리면 지적바래요)
그런데 복호화 할경우 메세지 버퍼가 어느정도인지 저도 모르는데 어떻게 메세지 버퍼크기를 확인하고 에러를 던저주는 코딩을 할까요..음!
무슨 표가 있다고 찾아보라는데 못찾겠네요 ㅠ

AES_256_CBC를 쓰고 있는데요
이거같은경우 16바이트로 잘라서 암호화를 하더라구요 음 그러니까 메세지/16 = 몫과 메세지%16해서 나머지가 0> 면 [몫+1 * 16] 의 크기가 되는지~
이렇게 하면 될꺼 같은데 좀 지저분; 해보이기도 하고
좋은방법을 알고 계시는분 답변 좀 부탁 드립니다.

항상 KLDP에 많은 도움을 받아서 감사드립니다.

mips의 이미지

블록 암호화 방식은 반드시 블록 크기를 맞춰줘야 합니다.
마지막 부분의 크기가 블록의 크기보다 작은 경우에는 블록 크기까지 적당히 패딩을 해 줘야됩니다. 이렇게 덧붙인 부분은 암호화 된 결과 파일에 적당히 추가해서 복호화할 때 사용하시면 됩니다.

예전에 작업할 때는,
결과 파일 첫 몇 바이트는 zero padding한 바이트 크기를 표시했었습니다.

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.