文章詳情頁
運(yùn)用加密技術(shù)保護(hù)Java源代碼(3)
瀏覽:74日期:2024-06-29 13:17:53
內(nèi)容: // 現(xiàn)在,獲取數(shù)據(jù)并解密byte encryptedData[] = /* 獲得經(jīng)過加密的數(shù)據(jù) */// 正式執(zhí)行解密操作byte decryptedData[] = cipher.doFinal( encryptedData );// 進(jìn)一步處理解密后的數(shù)據(jù)doSomething( decryptedData );四、應(yīng)用實(shí)例 前面介紹了如何加密和解密數(shù)據(jù)。要部署一個經(jīng)過加密的應(yīng)用,步驟如下: 步驟1:創(chuàng)建應(yīng)用。我們的例子包含一個App主類,兩個輔助類(分別稱為Foo和Bar)。這個應(yīng)用沒有什么實(shí)際功用,但只要我們能夠加密這個應(yīng)用,加密其他應(yīng)用也就不在話下。 步驟2:生成一個安全密匙。在命令行,利用GenerateKey工具(參見GenerateKey.java)把密匙寫入一個文件: % java GenerateKey key.data步驟3:加密應(yīng)用。在命令行,利用EncryptClasses工具(參見EncryptClasses.java)加密應(yīng)用的類: % java EncryptClasses key.data App.class Foo.class Bar.class該命令把每一個.class文件替換成它們各自的加密版本。 步驟4:運(yùn)行經(jīng)過加密的應(yīng)用。用戶通過一個DecryptStart程序運(yùn)行經(jīng)過加密的應(yīng)用。DecryptStart程序如Listing 6所示。 【Listing 6:DecryptStart.java,啟動被加密應(yīng)用的程序】import java.io.*;import java.security.*;import java.lang.reflect.*;import javax.crypto.*;import javax.crypto.spec.*;public class DecryptStart extends ClassLoader{// 這些對象在構(gòu)造函數(shù)中設(shè)置,// 以后loadClass()方法將利用它們解密類private SecretKey key;private Cipher cipher;// 構(gòu)造函數(shù):設(shè)置解密所需要的對象public DecryptStart( SecretKey key ) throws GeneralSecurityException,IOException {this.key = key;String algorithm = 'DES';SecureRandom sr = new SecureRandom();System.err.println( '[DecryptStart: creating cipher]' );cipher = Cipher.getInstance( algorithm );cipher.init( Cipher.DECRYPT_MODE, key, sr );}// main過程:我們要在這里讀入密匙,創(chuàng)建DecryptStart的// 實(shí)例,它就是我們的定制ClassLoader。// 設(shè)置好ClassLoader以后,我們用它裝入應(yīng)用實(shí)例,// 最后,我們通過Java Reflection API調(diào)用應(yīng)用實(shí)例的main方法static public void main( String args[] ) throws Exception {String keyFilename = args[0];String appName = args[1];// 這些是傳遞給應(yīng)用本身的參數(shù)String realArgs[] = new String[args.length-2];System.arraycopy( args, 2, realArgs, 0, args.length-2 );// 讀取密匙System.err.println( '[DecryptStart: reading key]' );byte rawKey[] = Util.readFile( keyFilename );DESKeySpec dks = new DESKeySpec( rawKey );SecretKeyFactory keyFactory = SecretKeyFactory.getInstance( 'DES' );SecretKey key = keyFactory.generateSecret( dks );// 創(chuàng)建解密的ClassLoaderDecryptStart dr = new DecryptStart( key );// 創(chuàng)建應(yīng)用主類的一個實(shí)例// 通過ClassLoader裝入它System.err.println( '[DecryptStart: loading '+appName+']' );Class clasz = dr.loadClass( appName );// 最后,通過Reflection API調(diào)用應(yīng)用實(shí)例// 的main()方法// 獲取一個對main()的引用String proto[] = new String[1];Class mainArgs[] = { (new String[1]).getClass() };Method main = clasz.getMethod( 'main', mainArgs );// 創(chuàng)建一個包含main()方法參數(shù)的數(shù)組Object argsArray[] = { realArgs };System.err.println( '[DecryptStart: running '+appName+'.main()]' );// 調(diào)用main()main.invoke( null, argsArray );}public Class loadClass( String name, boolean resolve )throws ClassNotFoundException {try {// 我們要創(chuàng)建的Class對象Class clasz = null;// 必需的步驟1:如果類已經(jīng)在系統(tǒng)緩沖之中// 我們不必再次裝入它c(diǎn)lasz = findLoadedClass( name ); Java, java, J2SE, j2se, J2EE, j2ee, J2ME, j2me, ejb, ejb3, JBOSS, jboss, spring, hibernate, jdo, struts, webwork, ajax, AJAX, mysql, MySQL, Oracle, Weblogic, Websphere, scjp, scjd
標(biāo)簽:
Java
相關(guān)文章:
1. 詳解c#與js的rsa加密互通2. Python實(shí)現(xiàn)AES加密,解密的兩種方法3. python實(shí)現(xiàn)希爾密碼加密的示例代碼4. 深入Java字節(jié)碼加密5. JavaScript中高階函數(shù)的巧妙運(yùn)用6. vue3使用base64加密的兩種方法舉例7. PHP基于openssl實(shí)現(xiàn)非對稱加密代碼實(shí)例8. .Net加密神器Eazfuscator.NET?2023.2?最新版使用教程9. Python實(shí)現(xiàn)常見的幾種加密算法(MD5,SHA-1,HMAC,DES/AES,RSA和ECC)10. jsp中javaBean的運(yùn)用
排行榜
