期待更好更穩定的開源FrameWork的出現,讓我們一起努力吧!  


          日歷
          <2008年3月>
          2425262728291
          2345678
          9101112131415
          16171819202122
          23242526272829
          303112345
          統計
          • 隨筆 - 78
          • 文章 - 1
          • 評論 - 29
          • 引用 - 0

          導航

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案(42)

          文章檔案(37)

          相冊

          搜索

          •  

          積分與排名

          • 積分 - 45228
          • 排名 - 1064

          最新隨筆

          最新評論

          閱讀排行榜

          評論排行榜

           
          本文摘自:http://www.javaeye.com/topic/154531
          作者:ferreousbox
          最實用的部分就是打包跟簽名

          最近在研究applet,打算使用applet來開發一個上傳文件上傳控件,之前因為一直覺得applet的沙箱控制導致applet不能主動的訪問客戶端的資源,所以也曾因此而放棄.不過最近在研究applet的簽名后,有了點收獲,可以通過簽名jar文檔來達到這樣的控制策略,下面是我在實際實驗過程中的一些心得和體會,跟大家一起分享下.(注:如果轉載此文,請注明出處和作者,尊重作者的勞動成果,謝謝)

          一、壓縮你的class類文件為jar包
          1.假設你的需要壓縮的類文件存在的包為:cn.mbq.test1和cn.mbq.test2
          2.進入你的classes目錄,在DOS窗口中執行命令:jar cf mytest.jar cn.mbq.test1 cn.mbq.test2
          3.執行命令后你會在當前目錄中找到mytest.jar文件,這個就是剛才生成的檔案文件。你可以修改它的后綴為rar,然后使用winrar壓縮程序打開它查看看是否正確。
          (說明:正確的方法應該是 jar cf mytest.jar cn/mbq/test1 cn/mbq/test2 )

          二、使用keytool工具生成密匙庫
          1.keytool工具位于${java_home}/bin目錄下;
          2.在DOS窗口中執行命令:keytool -genkey -keystore mytest.store -alias mbq 
           注意:mytest.store 是你的密匙庫的名稱,可以隨意修改,后綴請不要修改!
          如果需要可以添加參數DOS命令
          keytool -genkey -keystore mytest.store -alias mbq -validity 3650
           
          -validity 3650 表示的是有效期是3650天,默認情況是六個月有效期。
          mbq 為別名,這個也可以改成自己的名稱
          3.執行上述命令后,DOS窗口中會提示你輸入keystore的密碼、你的姓名、組織單位等等信息。這里要注意的是輸入密碼請記住,后面要用到的。在最后,我們輸入y確認信息。然后再直接回車設置mbq的主密碼和store密碼一致即可!


          三、使用keytool工具導出簽名時用到的證書
          1.在DOS窗口中執行命令:keytool -export -keystore mytest.store -alias mbq -file mbq.cert
          注意:mytest.store 就是第二步生成的密匙庫名稱
          mbq 也是在第二步中我們指定的別名
          mbq.cert 為我們生成的證書的名稱,可以自己修改名稱,注意后綴不要改
          2.命令執行成功,我們會在當前目錄下找到一個mbq.cert文件,這個就是我們剛才生成的證書。


          四、使用jarsigner工具簽名jar壓縮文檔
          1.jarsigner工具位于${java_home}/bin目錄下;
          2.在當前DOS窗口中執行命令:jarsigner -keystore mytest.store mytest.jar mbq
          注意:mytest.store 就是我們在第二步中生成的密匙庫名稱
          mytest.jar 就是我們這第一步壓縮的jar文檔
          mbq 是提供者的名稱,我們這里設置為我們的別名
          修改客戶端的程序是需要重新打包和簽名。

          五、創建mytest.policy文件
          1.在當前目錄下創建一個mytest.policy文件,其內容如下:
          keystore"file:mytest.store","JKS";
          grantsignedBy"mbq"
          {
          permission java.io.FilePermission"<<ALLFILES>>","read";
          };
          2.這個文件的意思就是說讓所有由mbq簽名的applet都可以對本地的所有文件進行讀操作。


          六、歸檔文件
          通過上述的五個操作后,我們會在當前目錄中找到如下幾個文件:mytest.jar-簽名后的jar文檔、mytest.store-密匙庫、 mbq.cert-證書、mytest.policy-訪問策略文件。如果沒有這些文件,那么你的applet數字簽名過程就沒有正確的完成,請檢查上述的操作。以后,如果對打包的java文件做了修改,那么就需要重新簽名一次才可以!


          七、在網頁中運行applet
          1.假設你的applet中的主啟動類為:cn.test.TestApplet.class;整個前面生成的檔案文件、證書啊存儲在目錄:d:\test\myapplet下;
          2.建立一applet_test.html文件存放在任何目錄下都可以,然后內容如下:

          Java代碼 復制代碼
          1. 1 <HTML>...</HTML><HTML>   
          2. 2 <BODY>...</BODY><BODY>   
          3. 3 <APPLET CODEBASE="d:\test\myapplet" CODE="cn.test.TestApplet.class" ARCHIVE="mytest.jar" WIDTH=200 HEIGHT=100 name="myapp">   
          4. 4 </APPLET>   
          5. 5 </BODY>   
          6. 6 </HTML>  


          注意:其中的CODEBASE就是你的類的基礎目錄,CODE也就是你的APPLET的啟動主類,ARCHIVE也就是簽名后的JAR文檔。
          2.然后在IE中打開該html文件,那么會看到IE提示你是否信任該插件,也就是說我們的證書起作用了,然后確定運行后,就可以在頁面上看到applet的運行效果了。

          但是由于SUN和MS的問題,目前IE并不支持最新的JRE,而是使用MS自己開發的JRE,所以這個也是影響APPLET發展壯大的一個原因。而且正是由于這個原因,SUN的java-plugin技術才會出現。使用SUN的java-plugin技術我們就可以在applet中使用最新的JAVA類庫了。由于IE在遇到APPLET標簽的時候會調用自己的JRE,但是如果客戶機器上安裝的JRE不是我們想要的版本,那么就會出錯了。所謂java- plugin技術就是利用IE的插件機制來制定我們想要的JRE,我們可以在IE中使用OBJECT標簽來調用APPLET,這樣就不會引用MS的JRE 了,從而達到我們想要的效果,而且java-plugin技術不僅僅支持IE,還支持Navigator等瀏覽器。不過我們需要編寫比較復雜的HTML代碼了,但是這一且SUN已經幫我們做到了,呵呵,在JDK1.4或更高的版本中SUN提供了一個HtmlConverter.exe工具來幫助將包含 applet標簽的html轉換成包含OBJECT和EMBED標簽的html代碼,該工具位于${java_home}/bin目錄下,對于1.4以前的版本該工具則是單獨提供的,不過現在幾乎都是1.4或1.5甚至更高版本的JDK了吧,呵呵。

          該工具很簡單,是圖形化的工具,我們直接運行即可。比如我將上面的包含applet的html轉換后(比如我選擇只支持IE的),其代碼變成了如下:

          Java代碼 復制代碼
          1. 01 <HTML>...</HTML><HTML>   
          2. 02 <BODY>...</BODY><BODY>   
          3. 03 <!--"CONVERTED_APPLET"-->   
          4. 04 <!-- HTML CONVERTER -->   
          5. 05 <object   
          6. 06     classid = "clsid:8AD9C840-044E-11D1-B3E9-00805F499D93"   
          7. 07     codebase = "http://java.sun.com/update/1.5.0/jinstall-1_5-windows-i586.cab#Version=5,0,0,3"   
          8. 08     WIDTH = 200 HEIGHT = 100 NAME = "myapp" >   
          9. 09     <PARAM NAME = CODE VALUE = "cn.test.TestApplet.class" >   
          10. 10     <PARAM NAME = CODEBASE VALUE = "d:\test\myapplet" >   
          11. 11     <PARAM NAME = ARCHIVE VALUE = "mytest.jar" >   
          12. 12     <PARAM NAME = NAME VALUE = "myapp" >   
          13. 13     <param name = "type" value = "application/x-java-applet;version=1.5">   
          14. 14     <param name = "scriptable" value = "false">   
          15. 15 </object>   
          16. 16 <!--   
          17. 17 <APPLET CODEBASE="d:\test\myapplet" CODE="cn.test.TestApplet.class" ARCHIVE="mytest.jar"   
          18. 18 WIDTH=200 HEIGHT=100 name="myapp">   
          19. 19 </APPLET>   
          20. 20 -->   
          21. 21 <!--"END_CONVERTED_APPLET"-->   
          22. 22 </BODY>   
          23. 23 </HTML>  


          注意其中的OBJECT標簽,可以看到APPLET標簽已經被注釋掉了。其中PARAM NAME=NAME這一行中的myapp就是我們applet應用程序的名稱,在IE提示的確認運行中顯示的就是這個名稱了,我們可以改為自己的公司或組織的名稱。然后提示的提供者也就是我們在簽名時用到的名稱了。

          另外,還要特別注意的就是這個包含OBJECT標簽的html頁面必須和你的mytest.jar壓縮文檔放在同一個目錄下,這樣才可以正確的加載,否則會一直報ClassNotFound的異常的,即使我們在OBJECT標簽中指定了CODEBASE也不行,這個是我在測試的時候遇到的問題!


          八、在Internet上應用簽名的applet
          如果要把applet部署在網絡上,那么最好是采用OBJECT標簽的形式,同時也要兼顧采用EMBED標簽來支持諸如FF等瀏覽器。我們把已簽名了的 mytest.jar和我們的網頁放在同一個目錄下,至于其他的如mytest.store和mbq.cert可以不用放在一起,至少我在測試的過程中沒有放到一起也不會出錯,而且在不同的機器上運行的也非常好,可以讀取客戶端機器的資源!另外,也發現mytest.policy其實也沒什么用處,因為這是參考網絡上的,而且他們的版本都是1.3左右,所以估計是版本低的緣故吧!


          到此,我們就已經完成了applet的簽名到部署,以及到實際的網絡應用中了。這樣我們使用applet來開發控件時就不會因為無法讀取客戶端資源而放棄了,呵呵~~

          說明:根據實際應用,其實最 有用的就是將程序打成jar包,并對jar包進行數字簽名。
          posted on 2008-03-27 14:57 BlueSky_itwangxinli 閱讀(1893) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
           
          Copyright © BlueSky_itwangxinli Powered by: 博客園 模板提供:滬江博客
          主站蜘蛛池模板: 中超| 尼玛县| 揭西县| 平利县| 南康市| 岐山县| 晋州市| 汤原县| 磐安县| 东海县| 嵊泗县| 逊克县| 芷江| 舟曲县| 仪陇县| 富锦市| 海兴县| 游戏| 高唐县| 高邑县| 尤溪县| 丹凤县| 鹤岗市| 丹巴县| 鸡泽县| 无棣县| 同德县| 高清| 鹤岗市| 洪雅县| 石嘴山市| 沧州市| 醴陵市| 汶川县| 清涧县| 平南县| 梧州市| 神农架林区| 重庆市| 双桥区| 开封县|