Android组件安全

本文介绍了Android组件安全,包括Activity、Service、BroadcastReceiver和ContentProvider的安全问题。讲解了如何防止Activity被非法访问,Service被恶意启动或停止,以及如何避免广播和ContentProvider的串谋攻击。建议开发者谨慎使用,并采用自定义权限、限制广播接收者以及设置ContentProvider权限来提升应用安全性。
摘要由CSDN通过智能技术生成

一.介绍篇

1.Activity

(1)访问,串谋攻击

正如Android开发文档中所说的,Android系统组件在制定Intent过滤器(intent-filter)后,默认是可以被外部程序访问的。这就很意味着很容易被其他程序进行串谋攻击,如何防止Activity被外部使用?

Android所有组件声明时可以通过指定android:exported属性值为false,来设置组件不能被外部程序调用。这里的外部程序是指签名不同、用户ID不同的程序,签名相同且用户ID相同的程序在执行时共享同一个进程空间,彼此之间是没有组件访问限制的。如果希望Activity能够被特定的程序访问,就不能用android:exported属性了,可以使用android:permission属性来指定一个自定义权限字符串,声明例子如下:

 

这样声明的Activity在被调用时,Android系统就会检查调用者是否具有com.test.permission.MyActivity权限,如果不具备就会触发一个SecurityException安全异常。要想启动该Activity必须在AndroidManifest.xml文件中加入以下声明:

<uses-permission android:name="winter.permission.FANGACTIVITY"/>

(2)关于自定义权限

 

参数介绍

name:权限名
protectionLevel&#

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值