首頁(yè) 收藏 QQ群
 網(wǎng)站導(dǎo)航

ZNDS智能電視網(wǎng) 推薦當(dāng)貝市場(chǎng)

TV應(yīng)用下載 / 資源分享區(qū)

軟件下載 | 游戲 | 討論 | 電視計(jì)算器

綜合交流 / 評(píng)測(cè) / 活動(dòng)區(qū)

交流區(qū) | 測(cè)硬件 | 網(wǎng)站活動(dòng) | Z幣中心

新手入門 / 進(jìn)階 / 社區(qū)互助

新手 | 你問(wèn)我答 | 免費(fèi)刷機(jī)救磚 | ROM固件

查看: 11146|回復(fù): 0
上一主題 下一主題
[教程]

專家專欄:AndroidManifest.xml文件詳解

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
發(fā)表于 2013-8-28 16:30 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
0本文為安全專家李洋的最新一篇專欄文章《AndroidManifest.xml文件詳解》。AndroidManifest.xml是一個(gè)跟安全相關(guān)的配置文件,該配置文件是Android安全保障的一個(gè)不可忽視的方面,本文對(duì)AndroidManifest文件進(jìn)行詳細(xì)介紹。以下為全部?jī)?nèi)容:   
AndroidManifest.xml主要包含以下功能:   
說(shuō)明application的java 數(shù)據(jù)包,數(shù)據(jù)包名是application的唯一標(biāo)識(shí);描述application的component;說(shuō)明application的component運(yùn)行在哪個(gè)process下;聲明application所必須具備的權(quán)限,用以訪問(wèn)受保護(hù)的部分API,以及與其他application的交互;聲明application其他的必備權(quán)限,用以component之間的交互;列舉application運(yùn)行時(shí)需要的環(huán)境配置信息,這些聲明信息只在程序開發(fā)和測(cè)試時(shí)存在,發(fā)布前將被刪除;聲明application所需要的AndroidAPI的最低版本級(jí)別,例如1.0,1.1,1.5等;列舉application所需要鏈接的庫(kù);   
   
AndroidManifest.xml文件的結(jié)構(gòu)、元素,以及元素的屬性,可以在AndroidSDK文檔中查看詳細(xì)說(shuō)明。而在看這些眾多的元素以及元素的屬性前,需要先了解一下這些元素在命名、結(jié)構(gòu)等方面的規(guī)則:   
元素:在所有的元素中只有<manifest>和<application>是必需的,且只能出現(xiàn)一次。如果一個(gè)元素包含有其他子元素,必須通過(guò)子元素的屬性來(lái)設(shè)置其值。處于同一層次的元素,這些元素的說(shuō)明是沒有順序的。屬性:按照常理,所有的屬性都是可選的,但是有些屬性是必須設(shè)置的。那些真正可選的屬性,即使不存在,其也有默認(rèn)的數(shù)值項(xiàng)說(shuō)明。除了根元素<manifest>的屬性,所有其他元素屬性的名字都是以android:前綴的;定義類名:所有的元素名都對(duì)應(yīng)其在SDK中的類名,如果你自己定義類名,必須包含類的數(shù)據(jù)包名,如果類與application處于同一數(shù)據(jù)包中,可以直接簡(jiǎn)寫為“.”;多數(shù)值項(xiàng):如果某個(gè)元素有超過(guò)一個(gè)數(shù)值,這個(gè)元素必須通過(guò)重復(fù)的方式來(lái)說(shuō)明其某個(gè)屬性具有多個(gè)數(shù)值項(xiàng),且不能將多個(gè)數(shù)值項(xiàng)一次性說(shuō)明在一個(gè)屬性中;資源項(xiàng)說(shuō)明:當(dāng)需要引用某個(gè)資源時(shí),其采用如下格式:@[package:]type:name。例如<activity android:icon=”@drawable/icon ” . . .>字符串值:類似于其他語(yǔ)言,如果字符中包含有字符“”,則必須使用轉(zhuǎn)義字符“\”;   
   
下面結(jié)合cookie實(shí)例中的AndroidManifest.xml文件來(lái)說(shuō)明一下,原XML文件如下:   
  1. <?xml version=”1.0″ encoding=”utf-8″?> <manifest xmlns:android=”http://schemas.android.com/apk/res/android” package=”moandroid.cookie” android:versionCode=”1″ android:versionName=”1.0″> <application android:icon=”@drawable/icon” android:label=”@string/app_name”> <activity android:name=”.cookie” android:label=”@string/app_name”> <intent-filter> <action android:name=”android.intent.action.MAIN” /> <category android:name=”android.intent.category.LAUNCHER” /> </intent-filter> </activity> </application> <uses-sdk android:minSdkVersion=”3″ /> </manifest>
復(fù)制代碼
除了頭部的XML信息說(shuō)明外,首先是manifest項(xiàng)(也就是根節(jié)點(diǎn)),其屬性包括:schemas URL地址、包名(moandroid.cookie),以及程序的版本說(shuō)明。其次是manifest的子節(jié)點(diǎn)application,其屬性包括:程序圖標(biāo)、程序名稱。前面帶有@表示引用資源,例如:@drawable/icon表示引用的是drawable資源中的icon,可以在其源工程的res/drawable中找到。然后就是application的子節(jié)點(diǎn)activity,其屬性包括:activity的名稱、activity的標(biāo)簽名,其子節(jié)點(diǎn)intent-filter則是對(duì)activity的說(shuō)明。   
而在intent-filter中,actionandroid:name=”android.intent.action.MAIN”和categoryandroid:name=”android.intent.category.LAUNCHER”用以說(shuō)明程序啟動(dòng)時(shí)的入口activity是哪個(gè)。如果這兩個(gè)屬性值中分別含有MAIN和LAUNCHER,則說(shuō)明它就是啟動(dòng)程序時(shí)的入口活動(dòng)。uses-sdkandroid:minSdkVersion=”3″說(shuō)明程序使用的Android SDK的最低版本,其中1表示Android1.0,2表示Android 1.1,而3則表示Android1.5。   
如下所示,文中黑體標(biāo)記的部分為應(yīng)用程序權(quán)限申請(qǐng)內(nèi)容:   
  1. <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="cn.com.fetion.android" android:versionCode="1" android:versionName="1.0.0"> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".welcomActivity" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> <uses-permission android:name="android.permission.SEND_SMS"></uses-permission> </manifest>
復(fù)制代碼
如上述文件描述中加下劃線的斜體部分,該文件的作用是說(shuō)明該軟件需要發(fā)送短信的功能。   
Android定義了百余種permission,可供開發(fā)人員使用,具體詳見網(wǎng)址。   
在文件中,用戶還可以自定義權(quán)限。permission就是自定義權(quán)限的聲明,可以用來(lái)限制app中特殊組件,特性與app內(nèi)部或者和其他app之間訪問(wèn)。寫了一個(gè)引用自定義權(quán)限的例子,在安裝app的時(shí)候,提示權(quán)限:   
定義權(quán)限如下:   
  1. <permission android:label="”自定義權(quán)限”" android:description=”@string/test” android:name=”com.example.project.TEST” android:protectionLevel=”normal” android:icon=”@drawable/ic_launcher”>
復(fù)制代碼
聲明的含義如下;   
android:label:權(quán)限名字,顯示給用戶的,值可是一個(gè)string數(shù)據(jù),例如這里的“自定義權(quán)限”。android:description:比label更長(zhǎng)的對(duì)權(quán)限的描述。值是通過(guò)resource文件中獲取的,不能直接寫string值,例如這里的”@string/test”。android:name:權(quán)限名字,如果其他app引用該權(quán)限需要填寫這個(gè)名字。android:protectionLevel:權(quán)限級(jí)別,分為4個(gè)級(jí)別:   
normal:低風(fēng)險(xiǎn)權(quán)限,在安裝的時(shí)候,系統(tǒng)會(huì)自動(dòng)授予權(quán)限給application。dangerous:高風(fēng)險(xiǎn)權(quán)限,系統(tǒng)不會(huì)自動(dòng)授予權(quán)限給app,在用到的時(shí)候,會(huì)給用戶提示。signature:簽名權(quán)限,在其他app引用聲明的權(quán)限的時(shí)候,需要保證兩個(gè)app的簽名一致。這樣系統(tǒng)就會(huì)自動(dòng)授予權(quán)限給第三方app,而不提示給用戶。signatureOrSystem:這個(gè)權(quán)限是引用該權(quán)限的app需要有和系統(tǒng)同樣的簽名才能授予的權(quán)限,一般不推薦使用。   
   

上一篇:如何在Android emulator上安裝 APK
下一篇:《Android Dev Guide》系列教程4:應(yīng)用基礎(chǔ)之Activities 和任務(wù)

本版積分規(guī)則

Archiver|新帖|標(biāo)簽|軟件|Sitemap|ZNDS智能電視網(wǎng) ( 蘇ICP備2023012627號(hào) )

網(wǎng)絡(luò)信息服務(wù)信用承諾書 | 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證:蘇B2-20221768 丨 蘇公網(wǎng)安備 32011402011373號(hào)

GMT+8, 2024-11-14 12:27 , Processed in 0.058470 second(s), 15 queries , Redis On.

Powered by Discuz!

監(jiān)督舉報(bào):report#znds.com (請(qǐng)將#替換為@)

© 2007-2024 ZNDS.Com

快速回復(fù) 返回頂部 返回列表