RSA공개키 암호화 알고리즘, AES 블록 알고리즘 복호화 메세지 길이에 대해 질문드릴게 있습니다.
글쓴이: anaud2 / 작성시간: 화, 2008/06/17 - 11:21오전
안녕하세요 오늘도 어려운 문제를 만나서 이렇게 질문드립니다.
openssl의 함수를 바탕으로 RSA공개키 암호화 알고리즘과 AES_256_CBC모드 블록 알고리즘을 만들었는데요
에러 핸들링으로 입력되는 메세지와 암,복호화 크기를 비교해서
만약 복호화를 했는데 복호화 저장할 메세지의 크기가 적어버리면 생기는 버퍼 오버플로우를 방지하기 위해 작업하고 있습니다.
RSA공개키 암호화 알고리즘의 경우 키값에 따라 암호화 메세지크기가 정해진다고 알고 있습니다. 저같은경우 256바이트 키를 써서
어떤메세지를 넣어도 256바이트짜리를 만드는걸로 알고있습니다.(틀리면 지적바래요)
그런데 복호화 할경우 메세지 버퍼가 어느정도인지 저도 모르는데 어떻게 메세지 버퍼크기를 확인하고 에러를 던저주는 코딩을 할까요..음!
무슨 표가 있다고 찾아보라는데 못찾겠네요 ㅠ
AES_256_CBC를 쓰고 있는데요
이거같은경우 16바이트로 잘라서 암호화를 하더라구요 음 그러니까 메세지/16 = 몫과 메세지%16해서 나머지가 0> 면 [몫+1 * 16] 의 크기가 되는지~
이렇게 하면 될꺼 같은데 좀 지저분; 해보이기도 하고
좋은방법을 알고 계시는분 답변 좀 부탁 드립니다.
항상 KLDP에 많은 도움을 받아서 감사드립니다.
Forums:
블록 암호화는
블록 암호화 방식은 반드시 블록 크기를 맞춰줘야 합니다.
마지막 부분의 크기가 블록의 크기보다 작은 경우에는 블록 크기까지 적당히 패딩을 해 줘야됩니다. 이렇게 덧붙인 부분은 암호화 된 결과 파일에 적당히 추가해서 복호화할 때 사용하시면 됩니다.
예전에 작업할 때는,
결과 파일 첫 몇 바이트는 zero padding한 바이트 크기를 표시했었습니다.
댓글 달기