암호화 알고리즘 SEED의 엔디안 문제 ㅠㅠ
글쓴이: NYAGU / 작성시간: 화, 2018/01/02 - 5:38오후
암호화 알고리즘 SEED를 윈도우와 솔라리스에서 실행시켜보면 전혀 다른 암호문값이 출력되요.
이와 관련해서 여기 게시판 검색해 보니 과거에도 그런 질문이 있었는데 역시나 엔디안 문제이네요..
제가 사용한 SEED는 과거 질문자가 사용한 SEED 소스코드 보다 더 새로운 버전?의 SEED인데요
운영모드가 추가된 SEED입니당.. 그중 저는 CBC를 사용했어요.
어디가 잘 못 되는지 찾기위해 솔라리스에서 printf찍어가면서 찾아보니까 패딩부분에서
엉뚱한 값이 찍히더라구요. 덕분에 솔라리스에서는 복호자체도 안되구요..
그런데 함수 내에 보면 define으로 엔디안을 바꿔서 입력하게 되어있는데..
이상하게 실제로는 엉뚱한 값이 찍히네요.
어디를 어떻게 고쳐야 할까요?
Forums:
일단 저 소스 내에 있는 ifndef 문이 제대로
일단 저 소스 내에 있는 ifndef 문이 제대로 동작하는지부터 확인해보시는 게 어떨까요.
잘 기억은 안 납니다만 예전에 다른 암호화 알고리즘 소스를 보는데 동작이 이상해서 살펴보니
자체적으로 BIG_ENDIAN, LITTLE_ENDIAN 상수를 쓰고 있는데 이게 이미 GNU C라이브러리에서 정의된 상수였기 때문에 중복되어서 문제가 되었던가 했었던 적이 있거든요.
좋은 하루 되세요!
아아 해결되었어요
말씀대로 define문제였네요.. 엄한곳에서 한참을 헤맸네요
감사합니다!
새해 복 많이받으세용
저도 똑같은 문제를 겪고있는데요..
혹시 이글을 보실지 모르겠지만 어떻게 해결하셨는지 알려주실수 있나요?
저도 증상은 똑같은데요.
솔라리스에서 동작을 안합니다.
endian define 은 잘 동작하는거 같아요 ..
define명을 바꿔서 해봐도 동일하네요..
댓글 달기