獲取Android簽名證書的公鑰和私鑰的簡(jiǎn)單實(shí)例
本文以Android簽名JKS格式的證書為例:
package com.test; import java.io.FileInputStream; import java.security.Key; import java.security.KeyStore; import java.security.PrivateKey; import java.security.PublicKey; import javax.crypto.Cipher; public class SignTest { public static void main(String[] args) { try { // 用證書的私鑰解密 - 該私鑰存在生成該證書的密鑰庫(kù)中 FileInputStream fis2 = new FileInputStream("G:\\shanhytest.keystore"); KeyStore ks = KeyStore.getInstance("JKS"); // 加載證書庫(kù) char[] kspwd = "shanhytest".toCharArray(); // 證書庫(kù)密碼 char[] keypwd = "shanhytest".toCharArray(); // 證書密碼 String alias = "shanhytest";// 別名 ks.load(fis2, kspwd); // 加載證書 PrivateKey privateKey = (PrivateKey) ks.getKey(alias, keypwd); // 獲取證書私鑰 PublicKey publicKey = ks.getCertificate(alias).getPublicKey();// 獲取證書公鑰 fis2.close(); System.out.println("privateKey = " + getKeyString(privateKey)); System.out.println("publicKey = " + getKeyString(publicKey)); // 測(cè)試加密解密字符串 String srcContent = "今天天氣不錯(cuò)。"; // 將字符串使用公鑰加密后,再用私鑰解密后,驗(yàn)證是否能正常還原。 // 因?yàn)榉菍?duì)稱加密算法適合對(duì)小數(shù)據(jù)量的數(shù)據(jù)進(jìn)行加密和解密,而且性能比較差,所以在實(shí)際的操作過程中,我們通常采用的方式是:采用非對(duì)稱加密算法管理對(duì)稱算法的密鑰,然后用對(duì)稱加密算法加密數(shù)據(jù),這樣我們就集成了兩類加密算法的優(yōu)點(diǎn),既實(shí)現(xiàn)了加密速度快的優(yōu)點(diǎn),又實(shí)現(xiàn)了安全方便管理密鑰的優(yōu)點(diǎn)。 byte[] d1 = crypt(publicKey, srcContent.getBytes(), Cipher.ENCRYPT_MODE); byte[] d2 = crypt(privateKey, d1, Cipher.DECRYPT_MODE); System.out.println(new String(d2)); } catch (Exception e) { e.printStackTrace(); } } /** * 將KEY轉(zhuǎn)換為字符串 * * @param key * @return * @author SHANHY */ private static String getKeyString(Key key) { byte[] keyBytes = key.getEncoded(); String s = new String(org.apache.commons.codec.binary.Base64.encodeBase64(keyBytes)); return s; } /** * 加密/解密 * * @param key * 私鑰打包成byte[]形式 * @param data * 要解密的數(shù)據(jù) * @param opmode * 操作類型(Cipher.DECRYPT_MODE為解密,Cipher.ENCRYPT_MODE為加密) * @return 解密數(shù)據(jù) */ public static byte[] crypt(Key key, byte[] data, int opmode) { try { long startTime = System.currentTimeMillis(); Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");//jdk默認(rèn)標(biāo)準(zhǔn) // Cipher cipher = Cipher.getInstance("RSA/ECB/NoPadding");// android默認(rèn)標(biāo)準(zhǔn) cipher.init(opmode, key); byte[] result = cipher.doFinal(data); System.out.println((Cipher.DECRYPT_MODE==opmode?"解密":"加密") + "耗時(shí):" + (System.currentTimeMillis() - startTime)); return result; } catch (Exception e) { e.printStackTrace(); } return null; } }
以上這篇獲取Android簽名證書的公鑰和私鑰的簡(jiǎn)單實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Android RxJava創(chuàng)建操作符Interval
這篇文章主要為大家詳細(xì)介紹了Android RxJava創(chuàng)建操作符Interval的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12Android Mms之:聯(lián)系人管理的應(yīng)用分析
本篇文章是對(duì)Android中的聯(lián)系人管理進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05Android使用GestureOverlayView控件實(shí)現(xiàn)手勢(shì)識(shí)別
這篇文章主要為大家詳細(xì)介紹了Android使用GestureOverlayView控件實(shí)現(xiàn)手勢(shì)識(shí)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04Android自定義View實(shí)現(xiàn)課程表表格
這篇文章主要為大家詳細(xì)介紹了Android自定義View實(shí)現(xiàn)課程表表格,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03android在異步任務(wù)中關(guān)閉Cursor的代碼方法
android在異步任務(wù)中如何關(guān)閉Cursor?在我們開發(fā)應(yīng)用的時(shí)候,很多時(shí)候會(huì)遇到這種問題,下面我們就看看代碼如何實(shí)現(xiàn)2013-11-11Android編程基于距離傳感器控制手機(jī)屏幕熄滅的方法詳解
這篇文章主要介紹了Android編程基于距離傳感器控制手機(jī)屏幕熄滅的方法,結(jié)合具體實(shí)例形式分析了Android距離傳感器的控制屏幕熄滅的實(shí)現(xiàn)方法與相關(guān)操作技巧,需要的朋友可以參考下2017-11-11Android-Jetpack-Navigation組件使用示例
這篇文章主要介紹了Android-Jetpack-Navigation組件使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08