Android 自定义权限 ( )



 在android系统的安全模型中,应用程序在默认的情况下不可以执行任何对其他应用程序,系统或者用户带来负面影响的操作。如果应用需要执行某些操作,就需要声明使用这个操作对应的权限。 (在manifest文件中 添加<uses-permission>标记) 

   android 系统提供了一系列这样的权限,具体可以查看android 权限,另外,android系统在新的版本中会增加一些permission,可以查看android 版本信息。 

   当然,app也可以自定义属于自己的permission 或属于开发者使用的同一个签名的permission。定义一个permission 就是在menifest文件中添加一个permission标签。 

Xml代码  收藏代码
  1. <permission android:description="string resource"  
  2.             android:icon="drawable resource"  
  3.             android:label="string resource"  
  4.             android:name="string"  
  5.             android:permissionGroup="string"  
  6.             android:protectionLevel=["normal" | "dangerous" |   
  7.                                      "signature" | "signatureOrSystem"] />  


android:description :对权限的描述,一般是两句话,第一句话描述这个权限所针对的操作,第二句话告诉用户授予app这个权限会带来的后果 
android:label: 对权限的一个简短描述 
android:name :权限的唯一标识,一般都是使用 报名加权限名 
android:permissionGroup: 权限所属权限组的名称 
android:protectionLevel: 权限的等级, 
normal 是最低的等级,声明次权限的app,系统会默认授予次权限,不会提示用户 
dangerous  权限对应的操作有安全风险,系统在安装声明此类权限的app时会提示用户 
signature  权限表明的操作只针对使用同一个证书签名的app开放 
signatureOrSystem  与signature类似,只是增加了rom中自带的app的声明 

android:name 属性是必须的,其他的可选,未写的系统会指定默认值 ;


我们在实际开发中,经常会用到系统的功能,比如打电话功能只要如以下简单代码:

  1. Uri uri = Uri.parse("tel.xxxxxx");  

并且在AndroidManifest.xml文件中添加如下权限:

  1. <uses-permission id="android .permission.CALL_PHONE" />   



下面我将实例给大家分享一下自定义action与permission.实例有两个Android工程Demo,与Demo2. Demo工程有两个Activity一个是主Activity,另一个是ViewActivity,这个Activity我们给自定义了android.tutor.action.VIEW的action以及com.tutor.permission.VIEW的permission。

另一个Demo2的主Activity去调用Demo里的ViewActivity;


下面是具体步骤如下:

第一步:新建第一个Android工程Demo.目录结构如下:

第二步:新建名为ViewActivity的Activity,代码如下:

  1. package com.tutor.demo;  
  2. import android.app.Activity;  
  3. import android.os.Bundle;  
  4. import android.widget.TextView;  
  5. public class ViewActivity extends Activity {  
  6.     @Override  
  7.     protected void onCreate(Bundle savedInstanceState) {  
  8.         super.onCreate(savedInstanceState);  
  9.           
  10.         TextView mTextView = new TextView(this);  
  11.         mTextView.setText("我是自定义action并且加了权限的Activity.");  
  12.         setContentView(mTextView);  
  13.     }  
  14. }  

第三步:在AndroidMainfest.xml中定义action与permission,代码如下:

 第6,7,20行代码定义了permission,第18-21行定义了action.第28行是同一个android工程访问ViewActivity也要申请权限.

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"  
  3.       package="com.tutor.demo"  
  4.       android:versionCode="1"  
  5.       android:versionName="1.0">  
  6.      <permission android:protectionLevel="normal" android:name="com.tutor.permission.VIEW">  
  7.      </permission>  
  8.       
  9.     <application android:icon="@drawable/icon" android:label="@string/app_name">  
  10.         <activity android:name=".Demo"  
  11.                   android:label="@string/app_name">  
  12.             <intent-filter>  
  13.                 <action android:name="android.intent.action.MAIN" />  
  14.                 <category android:name="android.intent.category.LAUNCHER" />  
  15.             </intent-filter>  
  16.         </activity>  
  17.           
  18.         <activity android:name=".ViewActivity"  
  19.                   android:label="自定义action与permission"  
  20.                   android:permission="com.tutor.permission.VIEW"  
  21.         >  
  22.             <intent-filter>  
  23.                 <action android:name="android.tutor.action.VIEW" />  
  24.                 <category android:name="android.intent.category.DEFAULT" />  
  25.             </intent-filter>  
  26.         </activity>  
  27.     </application>      
  28.     <uses-permission android:name="com.tutor.permission.VIEW"></uses-permission>  
  29. </manifest>  

第四步:修改主Activity,Demo.java代码如下(在onCreate()里去跳转到ViewActivity,也需要申请权限的如上面的第28行代码):

  1. package com.tutor.demo;  
  2. import com.tutor.demo.R;  
  3. import android.app.Activity;  
  4. import android.content.Intent;  
  5. import android.os.Bundle;  
  6. public class Demo extends Activity {  
  7.    
  8.     @Override  
  9.     public void onCreate(Bundle savedInstanceState) {  
  10.         super.onCreate(savedInstanceState);  
  11.         setContentView(R.layout.main);        
  12.         //跳转ViewActivity   
  13.         Intent mIntent = new Intent();  
  14.         mIntent.setAction("android.tutor.action.VIEW");  
  15.         startActivity(mIntent);  
  16.     }  
  17. }  

第五步:运行Demo工程,效果如下图:

 

上面是同一个Android工程里访问ViewActivity的情形,下面我们新建一个Demo2的android工程,去调用ViewActivity.

Demo2.java代码如下:

  1. package com.tutor.demo2;  
  2. import com.tutor.demo2.R;  
  3. import android.app.Activity;  
  4. import android.content.Intent;  
  5. import android.os.Bundle;  
  6. public class Demo2 extends Activity {  
  7.     @Override  
  8.     public void onCreate(Bundle savedInstanceState) {  
  9.         super.onCreate(savedInstanceState);  
  10.         setContentView(R.layout.main);  
  11.         //访问应用demo里的ViewActivity   
  12.         Intent mIntent = new Intent();  
  13.         mIntent.setAction("android.tutor.action.VIEW");  
  14.         startActivity(mIntent);       
  15.     }  
  16. }  

在Demo2工程里的AndroidMainifest.xml中申请权限,不加权限程序会报错,代码如下:

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"  
  3.       package="com.tutor.demo2"  
  4.       android:versionCode="1"  
  5.       android:versionName="1.0">  
  6.     <application android:icon="@drawable/icon" android:label="@string/app_name">  
  7.         <activity android:name=".Demo2"  
  8.                   android:label="@string/app_name">  
  9.             <intent-filter>  
  10.                 <action android:name="android.intent.action.MAIN" />  
  11.                 <category android:name="android.intent.category.LAUNCHER" />  
  12.             </intent-filter>  
  13.         </activity>  
  14.     </application>  
  15.      <uses-permission android:name="com.tutor.permission.VIEW"></uses-permission>  
  16. </manifest>  

运行之效果如下图所示:

 

这样app B 给app A 发送消息,A就可以收到了,若未在app B的menifest文件中声明使用相应的权限,app B发送的消息,A是收不到的。 

另外,也可在app B 的menifest文件中声明权限时,添加android:protectionLevel=“signature”,指定app B只能接收到使用同一证书签名的app 发送的消息。 










原文地址:https://www.cnblogs.com/liulaolaiu/p/11744486.html