国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

運用加密技術(shù)保護Java源代碼(2)

瀏覽:63日期:2024-06-29 14:49:34
內(nèi)容: resolveClass( clasz );// 把類返回給調(diào)用者return clasz;} catch( IOException ie ) {throw new ClassNotFoundException( ie.toString() );} catch( GeneralSecurityException gse ) {throw new ClassNotFoundException( gse.toString() );}}Listing 2顯示了一個簡單的loadClass實現(xiàn)。代碼中的大部分對所有ClassLoader對象來說都一樣,但有一小部分(已通過注釋標記)是特有的。在處理過程中,ClassLoader對象要用到其他幾個輔助方法: findLoadedClass:用來進行檢查,以便確認被請求的類當前還不存在。loadClass方法應該首先調(diào)用它。 defineClass:獲得原始類文件字節(jié)碼數(shù)據(jù)之后,調(diào)用defineClass把它轉(zhuǎn)換成一個Class對象。任何loadClass實現(xiàn)都必須調(diào)用這個方法。 findSystemClass:提供默認ClassLoader的支持。如果用來尋找類的定制方法不能找到指定的類(或者有意地不用定制方法),則可以調(diào)用該方法嘗試默認的裝入方式。這是很有用的,特別是從普通的JAR文件裝入標準Java類時。 resolveClass:當JVM想要裝入的不僅包括指定的類,而且還包括該類引用的所有其他類時,它會把loadClass的resolve參數(shù)設(shè)置成true。這時,我們必須在返回剛剛裝入的Class對象給調(diào)用者之前調(diào)用resolveClass。三、加密、解密 Java加密擴展即Java Cryptography Extension,簡稱JCE。它是Sun的加密服務軟件,包含了加密和密匙生成功能。JCE是JCA(Java Cryptography Architecture)的一種擴展。 JCE沒有規(guī)定具體的加密算法,但提供了一個框架,加密算法的具體實現(xiàn)可以作為服務提供者加入。除了JCE框架之外,JCE軟件包還包含了SunJCE服務提供者,其中包括許多有用的加密算法,比如DES(Data Encryption Standard)和Blowfish。 為簡單計,在本文中我們將用DES算法加密和解密字節(jié)碼。下面是用JCE加密和解密數(shù)據(jù)必須遵循的基本步驟:步驟1:生成一個安全密匙。在加密或解密任何數(shù)據(jù)之前需要有一個密匙。密匙是隨同被加密的應用一起發(fā)布的一小段數(shù)據(jù),Listing 3顯示了如何生成一個密匙。 【Listing 3:生成一個密匙】// DES算法要求有一個可信任的隨機數(shù)源SecureRandom sr = new SecureRandom();// 為我們選擇的DES算法生成一個KeyGenerator對象KeyGenerator kg = KeyGenerator.getInstance( 'DES' );kg.init( sr );// 生成密匙SecretKey key = kg.generateKey();// 獲取密匙數(shù)據(jù)byte rawKeyData[] = key.getEncoded();/* 接下來就可以用密匙進行加密或解密,或者把它保存為文件供以后使用 */doSomething( rawKeyData );步驟2:加密數(shù)據(jù)。得到密匙之后,接下來就可以用它加密數(shù)據(jù)。除了解密的ClassLoader之外,一般還要有一個加密待發(fā)布應用的獨立程序(見Listing 4)。 【Listing 4:用密匙加密原始數(shù)據(jù)】// DES算法要求有一個可信任的隨機數(shù)源SecureRandom sr = new SecureRandom();byte rawKeyData[] = /* 用某種方法獲得密匙數(shù)據(jù) */;// 從原始密匙數(shù)據(jù)創(chuàng)建DESKeySpec對象DESKeySpec dks = new DESKeySpec( rawKeyData );// 創(chuàng)建一個密匙工廠,然后用它把DESKeySpec轉(zhuǎn)換成// 一個SecretKey對象SecretKeyFactory keyFactory = SecretKeyFactory.getInstance( 'DES' );SecretKey key = keyFactory.generateSecret( dks );// Cipher對象實際完成加密操作Cipher cipher = Cipher.getInstance( 'DES' );// 用密匙初始化Cipher對象cipher.init( Cipher.ENCRYPT_MODE, key, sr );// 現(xiàn)在,獲取數(shù)據(jù)并加密byte data[] = /* 用某種方法獲取數(shù)據(jù) */// 正式執(zhí)行加密操作byte encryptedData[] = cipher.doFinal( data );// 進一步處理加密后的數(shù)據(jù)doSomething( encryptedData );步驟3:解密數(shù)據(jù)。運行經(jīng)過加密的應用時,ClassLoader分析并解密類文件。操作步驟如Listing 5所示。 【Listing 5:用密匙解密數(shù)據(jù)】// DES算法要求有一個可信任的隨機數(shù)源SecureRandom sr = new SecureRandom();byte rawKeyData[] = /* 用某種方法獲取原始密匙數(shù)據(jù) */;// 從原始密匙數(shù)據(jù)創(chuàng)建一個DESKeySpec對象DESKeySpec dks = new DESKeySpec( rawKeyData );// 創(chuàng)建一個密匙工廠,然后用它把DESKeySpec對象轉(zhuǎn)換成// 一個SecretKey對象SecretKeyFactory keyFactory = SecretKeyFactory.getInstance( 'DES' );SecretKey key = keyFactory.generateSecret( dks );// Cipher對象實際完成解密操作Cipher cipher = Cipher.getInstance( 'DES' );// 用密匙初始化Cipher對象cipher.init( Cipher.DECRYPT_MODE, key, sr ); 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
標簽: Java
相關(guān)文章:
主站蜘蛛池模板: 云浮市| 郧西县| 浪卡子县| 英吉沙县| 新平| 团风县| 瓦房店市| 青冈县| 克东县| 大荔县| 阆中市| 清水河县| 比如县| 沁阳市| 宁陕县| 绥德县| 收藏| 资阳市| 清苑县| 阳信县| 靖西县| 龙陵县| 杨浦区| 申扎县| 黔西县| 仁寿县| 额尔古纳市| 丹棱县| 龙川县| 房产| 海口市| 安多县| 湾仔区| 若尔盖县| 天台县| 永顺县| 新野县| 师宗县| 闽侯县| 阿拉善左旗| 胶州市|