Android App 获取权限:代码示例与解析
在开发Android应用程序时,获取用户权限是常见的需求。Android系统通过权限机制来保护用户的隐私和设备安全。本文将介绍如何在Android应用中获取权限,并提供代码示例和类图。
权限的分类
Android权限分为两类:正常权限(Normal Permissions)和危险权限(Dangerous Permissions)。正常权限通常用于访问设备的一些基本功能,如访问网络、读取联系人等。危险权限则涉及到用户的隐私和设备安全,如访问相机、读取短信等。
获取权限的步骤
- 添加权限声明:在AndroidManifest.xml文件中声明需要的权限。
- 动态请求权限:在运行时请求用户授权。
- 处理权限结果:根据用户授权的结果执行相应的操作。
代码示例
以下是一个简单的Android应用示例,展示如何获取相机和存储权限。
AndroidManifest.xml
首先,在AndroidManifest.xml
文件中声明所需的权限:
<manifest xmlns:android="
package="com.example.permissiondemo">
<uses-permission android:name="android.permission.CAMERA"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<application
...
>
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
MainActivity.java
在MainActivity.java
中,我们使用requestPermissions
方法动态请求权限:
import android.Manifest;
import android.content.pm.PackageManager;
import android.os.Build;
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.Toast;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findViewById(R.id.button_request_permission).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
requestPermissions();
}
});
}
private void requestPermissions() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
if (checkPermission()) {
Toast.makeText(this, "权限已授权", Toast.LENGTH_SHORT).show();
} else {
requestRuntimePermission();
}
} else {
Toast.makeText(this, "权限已授权", Toast.LENGTH_SHORT).show();
}
}
private boolean checkPermission() {
return ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA) == PackageManager.PERMISSION_GRANTED &&
ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED;
}
private void requestRuntimePermission() {
ActivityCompat.requestPermissions(this,
new String[]{Manifest.permission.CAMERA, Manifest.permission.WRITE_EXTERNAL_STORAGE},
1);
}
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if (requestCode == 1) {
if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
Toast.makeText(this, "权限授权成功", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(this, "权限授权失败", Toast.LENGTH_SHORT).show();
}
}
}
}
类图
以下是MainActivity
类的类图:
classDiagram
class MainActivity {
+requestPermissions()
+checkPermission() : boolean
+requestRuntimePermission()
+onRequestPermissionsResult(requestCode : int, permissions : String[], grantResults : int[])
}
class View {
+setOnClickListener(listener : View.OnClickListener)
}
class Toast {
+makeText(context : Context, text : CharSequence, duration : int) : Toast
}
class ActivityCompat {
+requestPermissions(activity : Activity, permissions : String[], requestCode : int)
}
class ContextCompat {
+checkSelfPermission(context : Context, permission : String) : int
}
class PackageManager {
PERMISSION_GRANTED : int
}
class Manifest {
permission_CAMERA : String
permission_WRITE_EXTERNAL_STORAGE : String
}
结语
通过上述示例,我们可以看到在Android应用中获取权限的过程。首先在AndroidManifest.xml
中声明权限,然后在运行时动态请求权限,并处理权限结果。希望本文能帮助您更好地理解Android权限机制,并在实际开发中正确地获取和使用权限。