투케이2K

527. (kotlin/코틀린) [유틸 파일] loadPrivateKey : 특정 문자 제거 및 개인 키 반환 수행 - Private Key 본문

Kotlin

527. (kotlin/코틀린) [유틸 파일] loadPrivateKey : 특정 문자 제거 및 개인 키 반환 수행 - Private Key

투케이2K 2024. 9. 13. 15:10

[개발 환경 설정]

개발 툴 : AndroidStudio

개발 언어 : Kotlin

 

[소스 코드]

 

        // -----------------------------------------------------------------------------------------
        // TODO [SEARCH FAST] : [RETURN] loadPrivateKey : 특정 문자 제거 및 개인키 반환 수행
        // -----------------------------------------------------------------------------------------
        fun loadPrivateKey(inputStream: InputStream?): PrivateKey? {

            /**
             * // -----------------------------------------
             * [stringToInputstream 메소드 설명]
             * // -----------------------------------------
             * 1. 특정 문자 제거 및 개인키 반환 수행
             * // -----------------------------------------
             * 2. 호출 방식 :
             *
             * C_App.loadPrivateKey(keyFile)
             *
             * // -----------------------------------------
             * 3. 리턴 데이터 :
             *
             * PrivateKey
             * // -----------------------------------------
             */


            // [리턴 값 선언]
            var returnData: PrivateKey? = null
            var M_LOG = ""


            // [로직 처리 실시]
            try {

                // [인풋 데이터 체크]
                if (inputStream != null) {

                    var keyBytes = ByteArray(inputStream.available())
                    inputStream.read(keyBytes)
                    inputStream.close()

                    var privateKeyPEM = String(keyBytes)

                    privateKeyPEM = privateKeyPEM.replace("-----BEGIN RSA PRIVATE KEY-----".toRegex(), "")
                    privateKeyPEM = privateKeyPEM.replace("-----END RSA PRIVATE KEY-----".toRegex(), "")

                    privateKeyPEM = privateKeyPEM.replace("-----BEGIN PRIVATE KEY-----".toRegex(), "")
                    privateKeyPEM = privateKeyPEM.replace("-----END PRIVATE KEY-----".toRegex(), "")

                    keyBytes = Base64.decode(privateKeyPEM, Base64.DEFAULT)

                    val spec = PKCS8EncodedKeySpec(keyBytes)
                    val kf = KeyFactory.getInstance("RSA")

                    returnData = kf.generatePrivate(spec)
                    M_LOG = "[Success] :: Private Key File Return"

                } else {
                    M_LOG = "[Error] :: Input Data Is Null"
                }

            } catch (e: Exception) {
                M_LOG = "[Exception] :: " + e.message.toString()
                S_Log._printStackTrace_(null, S_FinalData.LOG_BUG_STATE, null, e)
            }


            // [로그 출력 실시]
            ///*
            // ===============================================================
            S_Log._D_("특정 문자 제거 및 개인키 반환 수행", arrayOf(
                "M_LOG :: $M_LOG",
                "RETURN :: " + returnData.toString()
            ))
            // ===============================================================
            // */


            // [리턴 반환 실시]
            return returnData
        }

 

반응형
Comments