이 글에서는 자바 암호 프로그래밍을 위하여 Eclipse와 JDK를 설치하고 SUN JCE를 이용해서 AES 암호화 하는 방법에 대해서 알아보겠습니다.
안녕하세요. IT반장입니다.
이번 글에서는 '자바 암호 프로그래밍'을 하기 위한 가장 기초적인 단계인 '개발 도구 설치'에 대해서 알아보겠습니다. 자바 프로그래밍에서 가장 많이 쓰이는 Eclipse(Java IDE)와 JDK(Java Development Kit) 설치 방법에 대해서 설명하고, SUN JCE 라이브러리로 AES 암복호화 하는 방법에 대해서 알아보겠습니다.
1. Eclipse 다운로드 및 설치
■ Eclipse 다운로드
- http://www.eclipse.org/downloads [1]에서 최신 버전의 Eclipse를 다운로드 받습니다. ('제 PC는 windows7 64비트 환경이어서 자동으로 64비트 다운로드 버튼이 보이네요.')
■ Eclipse 설치
1) 다운로드 받은 설치파일을 실행하고, 설치 화면에서 'Eclipse IDE for Java Developers"를 선택
2) 설치할 디렉토리 지정 (여기서는 "c:\eclipse"로 지정)
3) 라이선스 동의
4) 설치 완료 후 실행('LAUNCH')
5) 작업디렉토리(workspace) 지정(여기서는 "C:\eclipse\workspace")
6) 설치 완료 !
※ eclipse가 실행이 안 되시는 분은 Java(JRE)가 시스템에 설치가 안되어 있을 수 있습니다. http://www.java.com 에서 JRE를 설치하시고 실행하시면 됩니다.
2. JDK 다운로드 및 설치
- eclipse가 동작한다면 해당 PC 또는 개발 시스템에 JDK 또는 JRE가 이미 설치되어 있을 겁니다. 여기서는 개발 환경의 독립성, 호환성을 위해서 별도의 JDK/JRE를 설치합니다.
■ JDK 다운로드 [2]
- http://www.oracle.com/technetwork/java/javase/downloads/index.html 에서 JDK를 다운로드 받습니다.
- 라이선스에 동의하고 시스템에 맞는 버전을 다운로드 합니다. (여기서는 8u102 JDK와 Demo/Sample을 다운로드 합니다.)
■ JDK 설치
- 다운로드 한 JDK실행파일을 실행합니다.
- JDK 설치 디렉토리를 "C:\eclipse\jdk1.8.0_102"로 지정합니다. (개발 환경의 독립성을 위해 별도의 디렉토리에 설치합니다.)
- JRE 설치 디렉토리를 "C:\eclipse\jre1.8.0_102"로 지정합니다. (개발 환경의 독립성을 위해 별도의 디렉토리에 설치합니다.)
- 설치가 완료되면 'Next Steps' 버튼을 눌러 'java document'를 확인합니다.
※ Java에서 제공하는 많은 기능 중에, 암호 프로그래밍을 위해 우선 일부(java, security tool 등)만 사용하게 될 것입니다.
3. 개발 환경 설정하기
- eclipse와 jdk/jre 가 설치 완료되었으니, 설치한 개발 도구들을 독립적인 환경으로 설정해 보겠습니다.
※ 여기서 '독립적 환경'이란 '컴파일 환경'(jdk)과 '실행 환경'(jre)을 동일하게 하여 개발시스템에 의존적이지 않도록 하는 것을 말합니다. 즉, 개발 환경만을 위해 jdk와 jre를 별도로 설치해서 환경을 구성하는 겁니다.
■ eclipse 환경 설정하기
- eclipse 실행 후 Window->Preference 선택
- Java->Compiler->Installed JREs 선택
- Add->'Standard VM'->Next 선택
- Directory->"C:\eclipse\jdk1.8.0_102" 선택 ->Finish
- 새로 설치한 "jdk1.8.0_102" 체크박스 선택 -> OK(또는 Apply) 선택
※ 이제 새로 설치한 JDK가 'eclipse 기본 Java 환경'으로 됩니다.
4. '자바 암호 프로그래밍' 시작하기
■ Eclipse 프로젝트 시작하기
- File -> New -> Java Project 선택
- Project name : "EncryptionTest01"로 입력하고
- JRE -> 'Use a project specific JRE' 선택 -> 'jdk1.8.0_102' 선택 -> Finish 선택
- 'JRE System Library'에서 라이브러리들이 "C:\eclipse\jdk1.8.0_102\..."에 위치한 것인지 확인
■ AES 암호화 및 복호화 프로그래밍
※ 여기서는 OWASP [3]에서 제공하는 SUN JCE(Java Cryptography Extension) 예제로 설명하겠습니다. [4]
- src 우클릭 -> New -> Class 선택
- Name: "AES" 입력 -> Finish
- 소스 복사 : OWASP AES 예제 소스[4]를 복사하여 붙여 넣기
※ 첫 번째 줄 빼고, 복사한다. ("package org.owasp.java.crypto;")
※ 참고 소스(AES암호화)[4]
|
- Run As -> Java Application 선택 (소스를 컴파일하고 실행한다.)
- 에러가 발생하는지 확인한다.
("No Such Algorithm exists java.security.NoSuchAlgorithmException: Cannot find any provider supporting AES/CBC/PKCS7PADDING")
※ 해당 에러는 SUN JCE에서 해당 패딩을 지원하지 않기 때문입니다.[5][6] 자바 버전9부터는 포함시킨다고 합니다.
- "AES/CBC/PKCS7PADDING"을 "AES/CBC/PKCS5PADDING"로 수정합니다. (라인 67, 98)
- Run As -> Java Application 선택하여 다시 실행
※ 하단 콘솔 창에 암복호화 결과를 확인할 수 있습니다.
이번 글에서는 '자바 암호 프로그래밍'을 하기 위한 가장 기초적인 단계인 '개발 도구 설치'(Eclipse, JDK)와SUN JCE 라이브러리로 AES 암복호화 하는 방법에 대해서 알아보았습니다. JCE로도 간단히 구현할 수는 있지만 아직까지는 bouncycastle 라이브러리만큼의 호환성을 보장하지 않습니다. 하지만 간단한 데이터 암호화 정도는 쉽게 적용이 가능합니다.
참고 목록
[1] http://www.eclipse.org/downloads
[2] http://www.oracle.com/technetwork/java/javase/downloads/index.html
[4] https://www.owasp.org/index.php/Using_the_Java_Cryptographic_Extensions
[5] http://bugs.java.com/bugdatabase/view_bug.do?bug_id=8076969
[6] https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html#pkcs5Pad
문서 이력
- v1.00(2016.09.06) : 최초 등록
'IT > Security' 카테고리의 다른 글
자바 암호 패키지(JCA, JCE) 및 실무 활용 방법 (0) | 2017.02.09 |
---|---|
오픈소스 암호 라이브러리 비교 및 실무 고려 사항 (1) | 2017.02.09 |