Android应用权限

开发Android应用时要在AndroidManifest.xml添加一些权限,但不是所有的权限都能被用户应用(UserApplication)使用,有些只能被系统应用(SystemApplication)使用。

如果用户应用使用了权限,那么就会出现类似这样的错误信息:
Not granting permission android.permission.INTERNAL_SYSTEM_WINDOW to package com.myPackage.myApp。

以下权限只能被系统应用使用:
android.permission.ACCESS_CHECKIN_PROPERTIES

android.permission.ACCESS_SURFACE_FLINGER

android.permission.ACCOUNT_MANAGER

android.permission.BIND_APPWIDGET

android.permission.BIND_DEVICE_ADMIN

android.permission.BIND_INPUT_METHOD

android.permission.BIND_WALLPAPER

android.permission.BRICK

android.permission.BROADCAST_PACKAGE_REMOVED

android.permission.BROADCAST_SMS

android.permission.BROADCAST_WAP_PUSH

android.permission.CALL_PRIVILEGED

android.permission.CHANGE_COMPONENT_ENABLED_STATE

android.permission.CLEAR_APP_USER_DATA

android.permission.CONTROL_LOCATION_UPDATES

android.permission.DELETE_CACHE_FILES

android.permission.DELETE_PACKAGES

android.permission.DEVICE_POWER

android.permission.DIAGNOSTIC

android.permission.FACTORY_TEST

android.permission.FORCE_BACK

android.permission.GLOBAL_SEARCH

android.permission.HARDWARE_TEST

android.permission.INJECT_EVENTS

android.permission.INSTALL_LOCATION_PROVIDER

android.permission.INSTALL_PACKAGES

android.permission.INTERNAL_SYSTEM_WINDOW

android.permission.MANAGE_APP_TOKENS

android.permission.MASTER_CLEAR

android.permission.READ_FRAME_BUFFER

android.permission.READ_INPUT_STATE

android.permission.REBOOT

android.permission.SET_ACTIVITY_WATCHER

android.permission.SET_ORIENTATION

android.permission.SET_PREFERRED_APPLICATIONS

android.permission.SET_TIME

android.permission.STATUS_BAR

android.permission.UPDATE_DEVICE_STATS

android.permission.WRITE_GSERVICES

android.permission.WRITE_SECURE_SETTINGS

用户应用就是那些安装在/data/app目录中的应用。
系统应用是安装在/system/app目录中的。
在调试时用adb install安装的应用都会被安装到/data/app,从而成为用户应用;
而用adb push可以指定安装到/system/app目录,从而成为系统应用。但是要发布的话,普通用户的应用是没法安装到/system/app下的,除非跟厂商合作。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 应用权限检测可以通过以下步骤进行: 1. AndroidManifest.xml 文件中查应用程序声明的。这个文件位应用程序的根录下。权限声明以uses-permission>` 标的形式出现,你可以检查这些标签是否包含你所需的权限。 2. 在运行时检查权限。在 Android 6.0(API 级别 23)及更高版本中,应用需要在运行时动态请求某些权限。你可以使用 `checkSelfPermission()` 方法检查应用是否拥有某个权限,如果没有,可以使用 `requestPermissions()` 方法请求该权限。 以下是一个示例代码,演示如何在运行时检查和请求权限: ```java // 检查权限是否已授权 if (ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { // 如果没有授权,则请求权限 ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, REQUEST_CODE); } else { // 已经授权,可以执行相应操作 // ... } // 处理权限请求结果 @Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { if (requestCode == REQUEST_CODE) { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { // 权限已授权,可以执行相应操作 // ... } else { // 权限被拒绝,无法执行相应操作 } } } ``` 请注意,不同的权限可能需要不同的请求代码(`REQUEST_CODE`)。你需要根据你的需求进行相应的更改。 以上是一种基本的权限检测方法,你可以根据具体情况进行适当的调整和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值