本网站(662p.com)打包出售,且带程序代码数据,662p.com域名,程序内核采用TP框架开发,需要联系扣扣:2360248666 /wx:lianweikj
精品域名一口价出售:1y1m.com(350元) ,6b7b.com(400元) , 5k5j.com(380元) , yayj.com(1800元), jiongzhun.com(1000元) , niuzen.com(2800元) , zennei.com(5000元)
需要联系扣扣:2360248666 /wx:lianweikj
Android中的权限问题
奔跑的男人 · 2419浏览 · 发布于2019-10-16 +关注

在Android程序中,在执行形如访问网络、读取联系人时都要声明权限,在 Android 系统版本小于6.0时,所有的权限只需要在AndroidManifest文件中声明就可以使用对应的功能了。 但是在Android6.0版本以上,Android将权限分为了普通权限和危险权限,其中普通权限的使用和以前的Android版本一样,直接在AndroidManifest文件中声明就行了,系统会自动帮我们授权,但是危险权限不仅要在AndroidManifest文件中声明,还需要在使用权限的时候通过代码来判断用户授权并且对用户授权的结果进行对应的处理。那么哪些权限是危险权限呢,下面给出了Android所有的危险权限,那么除了下表中的危险权限,其它的权限就都是Android普通权限了:

我们可以通过权限组的方式大致记一下危险权限:

  1. 读写日历:android.permission.READ_CALENDAR android.permission.WRITE_CALENDAR

  2. 使用相机: android.permission.CAMERA

  3. 读写联系人:android.permission.READ_CONTACTS android.permission.WRITE_CONTACTS

  4. android.permission.GET_ACCOUNTS

  5. 位置服务:android.permission.ACCESS_FINE_LOCATION ACCESS_COARSE_LOCATION

  6. 电话:android.permission.READ_PHONE_STATE android.permission.CALL_PHONE android.permission.READ_CALL_LOG android.permission.WRITE_CALL_LOG android.permission.ADD_VOICEMAIL android.permission.USE_SIP android.permission.PROGRESS_OUTGOING_CALLS

  7. 使用传感器:android.permission.BODY_SENSORS

  8. 短信:android.permission.SEND_SMS android.permission.RECEIVE_SMS android.permission.READ_SMS android.permission.RECEIVE_WAP_PUSH RECEIVE_MMS

  9. 读写手机储存:android.permission.READ_EXTERNAL_STORAGE android.permission.WRITE_EXTERNAL_STORAGE

好了,以上就是Android的所有危险权限,我们在使用这些权限的时候不仅要在AndroidManifest文件中声明,还需要在代码中对用户的授权情况进行处理,下面以一个简单的例子来看一下如何在代码中处理危险权限:

新建一个Android工程:

activity_main.xml:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
xmlns:tools="http://schemas.android.com/tools"  
android:id="@+id/activity_main"  
android:layout_width="match_parent"  
android:layout_height="match_parent"  
android:orientation="vertical"  
android:gravity="center_horizontal"  
tools:context="com.example.administrator.blogandroidpermissiondeal.MainActivity">  
<EditText  
android:id="@+id/phonenumberEditText"  
android:layout_width="wrap_content"  
android:layout_height="wrap_content"  
android:hint="输入你想拨打的电话号码" />  
<Button  
android:id="@+id/callPhoneButton"  
android:layout_width="wrap_content"  
android:layout_height="wrap_content"  
android:text="拨打"/> 
</LinearLayout> 

很简单的布局文件,一行EditText控件用于,电话号码,一行Button用于拨打电话::

接下来是MainActivity.java:

package com.example.administrator.blogandroidpermissiondeal; 
import android.Manifest; 
import android.content.Intent; 
import android.content.pm.PackageManager; 
import android.net.Uri; 
import android.support.annotation.NonNull; 
import android.support.v4.app.ActivityCompat; 
import android.support.v4.content.ContextCompat; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.Button; 
import android.widget.EditText; 
import android.widget.Toast; 
public class MainActivity extends AppCompatActivity {  
private Button button = null;  
private EditText editText = null;  
private static final int PERMISSION_REQUEST_CODE = 1;  
@Override  
protected void onCreate(Bundle savedInstanceState) {  
super.onCreate(savedInstanceState);  
setContentView(R.layout.activity_main);  
editText = (EditText) findViewById(R.id.phonenumberEditText);  
button = (Button) findViewById(R.id.callPhoneButton);  
button.setOnClickListener(new View.OnClickListener() {  
@Override  
public void onClick(View v) {  
/*  
* 先判断用户以前有没有对我们的应用程序允许过打电话的权限,  
* 如果有,那么直接打电话,如果没有,那么向用户申请,并且回调onRequestPermissionResult方法  
*/  
if(ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE)  
!= PackageManager.PERMISSION_GRANTED) {  
/*  
* 下面是对权限进行申请,第二个参数填入权限名,如果有多个权限,那么第二个参数String数组加入多个权限参数  
*/ ActivityCompat.requestPermissions(MainActivity.this,
new String[]{Manifest.permission.CALL_PHONE}, PERMISSION_REQUEST_CODE);  

else {  
callPhonenumber();  
}  
}  
});  
}  
private void callPhonenumber() {  
try {  
Intent intent = new Intent(Intent.ACTION_CALL);  
intent.setData(Uri.parse("tel:" + editText.getText().toString()));  
startActivity(intent);  
}catch (Exception e) {  
e.printStackTrace();  
}  
}  
/*  
* 当我们向用户申请权限的时候,用户操作的结果会调用这个方法,无论用户允许或者禁止,  
* 我们要在这个方法里面做出对应的处理  
*/  
@Override  
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {  
super.onRequestPermissionsResult(requestCode, permissions, grantResults);  
switch (requestCode) {  
/*  
* 对传入的requestCode进行判断  
*/  
case PERMISSION_REQUEST_CODE:  
// 如果用户授权  
if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {  
callPhonenumber();  

else {  
Toast.makeText(this, "打电话权限已被用户拒绝", Toast.LENGTH_SHORT).show();  
}  
}  


在MainActivity.java中我们对我们需要的权限进行了处理,

最后别忘了在AndroidManifest文件中声明打电话权限:

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

下面来运行一下:

Android中的权限问题

我们输入一个号码,点击“拨打”按钮:

Android中的权限问题

因为我们是第一次运行这个程序,所以用户以前并没有对我们的程序进行授权,因此出现权限申请对话框,我们点击DENY(否):

Android中的权限问题

成功弹出了提示框,那么我们再试一次点击ALLOW(允许)试试:

Android中的权限问题

成功的进入拨打电话的界面并且拨打我们输入的电话号码!

当我们允许了之后,那么程序以后就不需要再经过用户授权了,即可以直接拨打电话(除非用户在应用程序管理中收回了我们的打电话的权限)。


相关推荐

android下vulkan与opengles纹理互通

talkchan · 1179浏览 · 2020-11-23 10:37:39
Android 使用RecyclerView实现轮播图

奔跑的男人 · 2175浏览 · 2019-05-09 17:11:13
微软发布新命令行工具 Windows Terminal

吴振华 · 869浏览 · 2019-05-09 17:15:04
Facebook 停止屏蔽部分区块链广告

· 754浏览 · 2019-05-09 17:20:08
加载中

0评论

评论
分类专栏
小鸟云服务器
扫码进入手机网页