Java

Java 에서 RSA 복호화 시 Decryption error

2023. 6. 1. 14:49

Android에서 RSA 암호화 후 암호화한 데이터를 서버로 보내서 복호화를 하려고 하는데 계속해서 오류가 났다,,,

BadPaddingException: Decryption error

나 같은 경우에는 클라이언트에서 RSA 키 쌍 생성 후에 공개 키(Public Key)는 서버에 저장,

개인 키(Private Key) 는 암호화 후 클라이언트에 저장을 했다.

 

공개 키나 암호화 한 데이터를 전달할 때 인코딩하면서 문제가 생긴건가 싶어서 Android 와 서버에서의 값을

모두 비교해봤지만 전부 동일했고, 심지어 Android 에서 바로 복호화 했을 때는 정상적으로 복호화가 되었다...!

 

[Android]

public static String encrypt(String plainText, String strPrivateKey) throws Exception {
        KeyFactory keyFactory = KeyFactory.getInstance("RSA");
        byte[] bytePrivateKey = Base64.decode(strPrivateKey, Base64.NO_WRAP);
        PKCS8EncodedKeySpec privateKeySpec = new PKCS8EncodedKeySpec(bytePrivateKey);
        PrivateKey privateKey = keyFactory.generatePrivate(privateKeySpec);

        Cipher cipher = Cipher.getInstance("RSA");
        cipher.init(Cipher.ENCRYPT_MODE, privateKey);

        byte[] encryptedBytes = cipher.doFinal(plainText.getBytes());

        return Base64.encodeToString(encryptedBytes, Base64.NO_WRAP);
    }

 

[Server]

public static String decrypt(String encryptedText, String strPublicKey) throws Exception {
        KeyFactory keyFactory = KeyFactory.getInstance("RSA");
        byte[] bytePublicKey = Base64.getDecoder().decode(strPublicKey);
        X509EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(bytePublicKey);
        PublicKey publicKey = keyFactory.generatePublic(publicKeySpec);
        
        Cipher cipher = Cipher.getInstance("RSA");
        cipher.init(Cipher.DECRYPT_MODE, publicKey);

        byte[] encryptedBytes = Base64.getDecoder().decode(encryptedText.getBytes());
        byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
        return new String(decryptedBytes);
    }

 

진짜.. 다를 게 없는데 복호화시 오류가 나서 이것저것 삽질하느라 시간을 많이 썼는데 결국 아래처럼 코드 수정 후 해결했다.

Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");

해결책은 형식을 명시적으로 지정하는 것... 하루 꼬박 날린 것 같은데 나와 같이 삽질하는 사람이 없길 바라면서 글을 작성한다😢

저작자표시 비영리 변경금지 (새창열림)
'Java' 카테고리의 다른 글
  • Java Base64 Decode 시 "illegal base64 character a"
따봉냥이
따봉냥이
iOS 개발 공부해봅시다.
따봉냥이
개발하는 따봉냥이
따봉냥이
글쓰기 / 관리자
  • 분류 전체보기 (11)
    • iOS (8)
    • Java (2)
    • Project (0)
    • 기타 (1)

최근 글

블로그 메뉴

  • 방명록
전체
오늘
어제
hELLO · Designed By 정상우.
따봉냥이
Java 에서 RSA 복호화 시 Decryption error
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.