1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Android开发——本地存储 用户权限获取

Android开发——本地存储 用户权限获取

时间:2021-10-13 02:03:58

相关推荐

Android开发——本地存储 用户权限获取

Android的逻辑存储结构有三种

内部存储结构 Internal Private Storage外部私有存储结构 External Private Storage外部公有存储结构 External Public Storage

权限内容区别如下

每次安装APP,最初开始的时候都有一系列的获取用户权限的按钮,包括地理位置,picture,movie等目录。

Android要求获取公共权限时,必须先要经过用户的批准,下面是user-premission的过程

1、在AndroidManifest.xml中添加user-permission

外部存储的写的权限(可写意味着可读可写,如果想要只读,在这里更改)

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

2、弹出获取权限的请求

定义一个按钮,当用户点击这个按钮的时候,弹出来系统获取用户权限允许的请求。

自行定义这个,很普通的一个按钮控件

<Buttonandroid:id="@+id/btn_request_permission"android:layout_width="match_parent"android:layout_height="40dp"android:layout_marginTop="10dp"android:text="@string/request_storage_permission"android:textAllCaps="false" />

3、在activity中对按钮进行监听,处理事务

找到按钮 permissionBtn对该按钮进行监听监听内部点击事件OnClick

首先,我们需要检测是否已经获取了用户权限

checkSelfPermission()源代码如下,其实我们只需要知道两个参数是什么就行了。参数一:上下文环境,一般传入的参数为currActivity.this;参数二:被验证的权限,之前在AndroidManifest中声明的权限相对应

public static int checkSelfPermission(@NonNull Context context, @NonNull String permission) {if (permission == null) {throw new IllegalArgumentException("permission is null");} else {return context.checkPermission(permission, Process.myPid(), Process.myUid());}}

如果上述验证成功,那么没有必要再进行用户权限获取,否则进行如下操作,requestPermissions(),三个参数。

第一个参数上下文关系;

第二个参数String数组的permission,意味着可以传入多个permission请求

第三个参数请求码,可以自行定义一个数字,将在之后用到

ActivityCompat.requestPermissions(activity, String[], int requestcode)

我的代码中的部分

ActivityCompat.requestPermissions(DebugActivity.this,new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},REQUEST_CODE_STORAGE_PERMISSION);

到这里,我们点击了这个按钮permissionBtn,那么系统就会弹出一个权限框,这个框中的一系列内容就是我们申请的permission内容,自行联想一下我们刚进入app的时候弹出来很多层权限申请,这里我们只演示一个。

我们可以点击允许或者拒绝,在英文中就是GRANT、DENY

用户点击的信息需要进行交互。

重写onRequestPermissionsResult,这就是对用户交互信息的处理的函数。

public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {

参数一:之前requestPermissions中传入的第三个参数对应,起到定位的作用

参数二:申请的permission

参数三:用户交互返回的结果

我的代码

@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,@NonNull int[] grantResults) {super.onRequestPermissionsResult(requestCode, permissions, grantResults);if (permissions.length == 0 || grantResults.length == 0) {return;}if (requestCode == REQUEST_CODE_STORAGE_PERMISSION) {// for(int i=0;i<permissions.length;i++){//String permisson = permissions[i];//int grantResult = grantResults[i];//Log.d("RequestPermission", permisson + ": " + grantResult);// }int state = grantResults[0];if (state == PackageManager.PERMISSION_GRANTED) {Toast.makeText(DebugActivity.this, "permission granted",Toast.LENGTH_SHORT).show();} else if (state == PackageManager.PERMISSION_DENIED) {Toast.makeText(DebugActivity.this, "permission denied",Toast.LENGTH_SHORT).show();}}}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。