成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Android 簽名詳解

移動開發 Android
Android 系統中,所有安裝 到 系統的應用程序都必有一個數字證書,此數字證書用于標識應用程序的作者和在應用程序之間建立信任關系,如果一個 permission的protectionLevel為signature,那么就只有那些跟該permission所在的程序擁有同一個數字證書的應 用程序才能取得該權限。

在Android 系統中,所有安裝 到 系統的應用程序都必有一個數字證書,此數字證書用于標識應用程序的作者和在應用程序之間建立信任關系,如果一個 permission的protectionLevel為signature,那么就只有那些跟該permission所在的程序擁有同一個數字證書的應 用程序才能取得該權限。Android使用Java的數字證書相關的機制來 給apk加蓋數字證書,要理解android的數字證書,需要先了解以下數字證書的概念和java的數字證書機制。Android系統要求每一個安裝進系 統的應用程序都是經過數字證書簽名的,數字證書的私鑰則保存在程序開發者的手中。Android將數字證書用來標識應用程序的作者和在應用程序之間建立信 任關系,不是用來決定最終用戶可以安裝哪些應用程序。這個數字證書并不需要權威的數字證書簽名機構認證,它只是用來讓應用程序包自我認證的。

一:同一個開發者的多個程序盡可能使用同一個數字證書 ,這可以帶來以下好處。

(1)有利于程序升級,當新版程序和舊版程序的數字證書相同時,Android系統才會認為這兩個程序是同一個程序的不同版本。如果新版程序和舊版程序的數字證書不相同,則Android系統認為他們是不同的程序,并產生沖突,會要求新程序更改包名。

(2)有利于程序的模塊化設計和開發。Android系統允許擁有同一個數字簽名的程序運行在一個進程中,Android程序會將他們視為同一個程序。所以開發者可以將自己的程序分模塊開發,而用戶只需要在需要的時候下載適當的模塊。

(3) 可以通過權限(permission)的方式在多個程序間共享數據和代碼。Android提供了基于數字證書的權限賦予機制,應用程序可以和其他的程序共 享概功能或者數據給那那些與自己擁有相同數字證書的程序。如果某個權限(permission)的protectionLevel是signature, 則這個權限就只能授予那些跟該權限所在的包擁有同一個數字證書的程序。

在簽名時,需要考慮數字證書的有效期 :

(1)數字證書的有效期要包含程序的預計生命周期,一旦數字證書失效,持有改數字證書的程序將不能正常升級。

(2)如果多個程序使用同一個數字證書,則該數字證書的有效期要包含所有程序的預計生命周期。

(3)Android Market強制要求所有應用程序數字證書的有效期要持續到2033年10月22日以后。

二:Android數字證書包含以下幾個要點:

(1)所有的應用程序都必須有數字證書 ,Android系統不會安裝一個沒有數字證書的應用程序

(2)Android程序包使用的數字證書可以是自簽名的,不需要一個權威的數字證書機構簽名認證

(3)如果要正式發布 一個Android ,必須使用一個合適的私鑰生成的數字證書來給程序簽名 ,而不能使用adt插件 或者ant工具 生成的調試證書來發布。

(4)數字證書都是有有效期 的,Android只是在應用程序安裝的時候才會檢查證書的有效期。如果程序已經安裝在系統中,即使證書過期也不會影響程序的正常功能。

(***ndroid使用標準的java工具 Keytool and Jarsigner 來生成數字證書,并給應用程序包簽名。

(6)使用zipalign 優化 程序。

Android 系統不會安裝運行任何一款未經數字簽名的apk程序,無論是在模擬器上還是在實際的物理設備上。Android的開發工具(ADT插件和Ant)都可以協 助開發者給apk程序簽名,它們都有兩種模式:調試模式(debug mode)和發布模式(release mode)。

在調試模式下,android的開發工具會在每次編譯時使用調試用的數字證書給程序簽名,開發者無須關心。

當要發布程序時,開發者就需要使用自己的數字證書給apk包簽名,可以有兩種方法。

(1)在命令行下使用JDK中的和Keytool(用于生成數字證書)和Jarsigner(用于使用數字證書簽名)來給apk包簽名。

(2)使用ADT Export Wizard進行簽名(如果沒有數字證書可能需要生成數字證書)。
三;兩種簽名方式


***種簽名方式, 使用Keytool和Jarsigner給程序簽名( 用于1.5以下版本 )


命令:keytool -genkey -v -keystore android.keystore -alias android -keyalg RSA -validity 20000

該 命令中,-keystore ophone.keystore 表示生成的證書,可以加上路徑(默認在用戶主目錄下);-alias ophone 表示證書的別名是ophone;-keyalg RSA 表示采用的RSA算法;-validity 20000表示證書的有效期是20000天。

此時,我們會在互用主目錄下看到ophone.keystore,即我們剛剛創建的證書。

 

 

 

 


第二種簽名方式:現在介紹android 1.5及更新版本的apk簽名方式

 

 

1,打開Eclipse->選擇你要簽名的項目->右擊->android tools->Export signed Application package...


2,跳出窗口

 

 

3,project checks 如果核對項目名沒有問題的話 點擊 Next
然后跳出keystore selection 如果是已經存在keystore的文件就選擇然后next 輸入keystore的密碼進行簽名。
如果沒有的話選擇 create new keystore 然后選擇 keystore 保存的位置,設置keystore的密碼,點擊Next。

 


4.填寫keystore的基本信息,如,別名,密碼,有效期,姓名,組織,組織名稱,所在城市,所在省份,國家等,點擊Next


5.選擇被簽名后的APK保存位置。點擊finish。

 


6.就可以在你保存的位置中找到相應的被簽名后的APK文件。


 

責任編輯:chenqingxiang 來源: cnblogs
相關推薦

2017-09-07 16:00:20

2019-04-18 15:00:36

2011-05-27 09:33:31

Android 程序 簽名

2009-09-17 13:26:55

.NET方法簽名

2012-05-23 09:33:37

TitaniumStudioAndroid APK

2011-05-27 10:13:39

Android 簽名

2011-05-27 15:02:15

Android ListView

2013-11-14 10:42:48

MTPAndroid

2014-07-24 09:11:34

2017-01-11 19:05:45

AndroidAndroid Loa詳解

2013-11-14 16:50:08

2023-05-23 14:53:26

鴻蒙應用開發

2023-03-01 14:55:09

2013-12-25 09:34:26

Android SDKAndroid組件

2009-08-14 13:40:17

數字簽名電子簽名安全體系結構

2010-07-13 09:02:19

Widget開發

2021-09-07 08:49:35

Android

2011-09-09 20:14:58

Android Wid

2013-01-11 13:48:41

Android開發組件Notificatio

2013-01-10 14:39:28

Android開發Content Pro組件
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 激情国产 | 久久逼逼 | 国产亚洲成av人片在线观看桃 | 天天色图 | 大象视频一区二区 | 欧美日韩综合 | 九九亚洲精品 | 中文字幕亚洲一区二区三区 | 国产精品久久久久久久7电影 | 国产精品theporn| 看一级毛片 | 欧美成人精品二区三区99精品 | 欧美lesbianxxxxhd视频社区 | 羞羞视频在线观看 | 日本一区二区不卡视频 | 国产精品av久久久久久久久久 | 狠狠夜夜 | 播放一级毛片 | 成人午夜免费视频 | 亚洲五码久久 | 欧美激情精品久久久久久 | 久久久久久国产精品免费免费男同 | 人人爽日日躁夜夜躁尤物 | 2019天天干天天操 | www.色五月.com | 五月天激情综合网 | 欧美不卡在线 | 久久久高清 | 精品久久久久久久 | 日本三级电影免费观看 | 亚洲成人一区二区 | 在线āv视频 | 日韩精品一区二区三区中文在线 | 日本免费视频在线观看 | 国产精品久久久久久久久久久久久 | yeyeav| 红桃视频一区二区三区免费 | 精品一区二区三 | 成人三级av | 国产 欧美 日韩 一区 | 在线免费观看色 |