android自定义权限的实现

在android开发中,有时需要利用自定义权限来保证android应用的安全,今天写一个自定义权限的小案例。包含了访问activity,service,以及发送广播可广播接受者,和自定义权限。

首先,新建两个工程,一个叫做security,另一个叫做securitytest

在seurity中定义,声明,并利用自定义的几个权限,在securitytest中就像用普通的权限一样,利用即可

security中声明权限如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.security"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="11"
        android:targetSdkVersion="18" />

    <permission android:name="com.tct.permission.READ_PROVIDER"  android:protectionLevel="dangerous">
    </permission>
    <permission android:name="com.tct.apermission.WRITE_PROVIDER" android:protectionLevel="dangerous">
    </permission>
    <permission
        android:name="com.tct.attach.start_activity"
        android:protectionLevel="normal" >
    </permission>
    <permission
        android:name="com.tct.attach.service.permission"
        android:protectionLevel="normal" >
    </permission>
    <permission
        android:name="com.tct.attach.broadcastreceiver"
        android:protectionLevel="dangerous" >
    </permission>

    <uses-permission android:name="com.tct.attach.service.permission" />
    <uses-permission android:name="com.tct.attach.start_activity" />
    <uses-permission android:name="com.tct.attach.broadcastreceiver" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.example.security.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <service
            android:name="com.example.security.MyService"
            android:permission="com.tct.attach.service.permission" >
            <intent-filter>
                <action android:name="com.test.action.service" >
                </action>

                <category android:name="android.intent.category.DEFAULT" >
                </category>
            </intent-filter>
        </service>

        <activity
            android:name="com.example.security.MyActivity"
            android:permission="com.tct.attach.start_activity" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" >
                </action>

                <category android:name="android.intent.category.DEFAULT" >
                </category>
            </intent-filter>
        </activity>

        <receiver
            android:name="com.example.security.MyBroadcaseReceiver"
            android:permission="com.tct.attach.broadcastreceiver" >
            <intent-filter>
                <action android:name="com.tct.receiver.action" >
                </action>
            </intent-filter>
        </receiver>

        <activity android:name="com.example.security.ShowReceiverActivity" >
        </activity>
        <activity android:name="com.example.security.MyBroadCast" >
        </activity>

        <provider
            android:name="com.example.contentprovider.MyContentProvider"
            android:authorities="com.liuhang.urlcontent"
            android:exported="true" >
<!--             android:path="content://com.liuhang.urlcontent/person/3" -->
            <path-permission
                android:pathPrefix="/person"
                android:readPermission="com.tct.apermission.WRITE_PROVIDER"
                android:writePermission="com.tct.apermission.WRITE_PROVIDER"
                ></path-permission>
            
            <grant-uri-permission android:pathPrefix="/person"/>
        </provider>
    </application>

</manifest>
securitytest中的AndroidManifest.xml文件如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.securitytest"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="12"
        android:targetSdkVersion="18" />

    
    <uses-permission android:name="com.tct.attach.service.permission"/>
    <uses-permission android:name="com.tct.attach.start_activity"/>
    <uses-permission android:name="com.tct.attach.broadcastreceiver"/>
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
    <uses-permission android:name="com.tct.permission.READ_PROVIDER"/>
    <uses-permission android:name="com.tct.apermission.WRITE_PROVIDER"/>
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.example.securitytest.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        
        <receiver android:name="com.example.securitytest.MyTestReceiver">
            <intent-filter>
                <action android:name="com.test.permission.sendbroadcast"></action>
            </intent-filter>
        </receiver>
    </application>

</manifest>
只有当在securitytest中利用了这些权限才可以访问对应的activity,service,contentprovider以及接受和发送对应的广播。


源码如下:http://download.csdn.net/detail/mockingbirds/8109057


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值