Android studio权限使用相关相关

本文详细介绍了在Android Studio中如何处理高版本SDK的权限管理,包括如何在代码中检查和请求权限,以及在Manifest文件中声明权限。通过具体示例,展示了如何实现短信发送功能,并处理与权限相关的逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android Studio高SDK版本的权限获取和eclipse有一些不一样,下面的例子使用了2个权限,操作方法如下

Android studio按钮详细介绍https://www.open-open.com/lib/view/open1468121363300.html

private static final int PERMISSION_REQUEST_CODE = 1;

if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.M) {

	if (checkSelfPermission(Manifest.permission.READ_EXTERNAL_STORAGE)
			== PackageManager.PERMISSION_DENIED) {

		Log.d("permission", "permission denied to SEND_SMS - requesting it");
		String[] permissions = {Manifest.permission.READ_EXTERNAL_STORAGE};

		requestPermissions(permissions, PERMISSION_REQUEST_CODE);

	}
}

Manifist.xml中申请权限

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.ldw.test">
    <uses-permission android:name="android.permission.SEND_SMS"/>
    <uses-permission android:name="android.permission.CALL_PHONE"/>
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <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>

在MainActivty.java中加入权限限制

package com.ldw.test;

import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;

import android.Manifest;
import android.app.Activity;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.net.Uri;
import android.os.Bundle;
import android.telephony.SmsManager;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

import java.util.ArrayList;

public class MainActivity extends Activity implements View.OnClickListener {

    private Button btn_send;
    private Button btn_dail;
    private EditText et_number;
    private EditText et_content;
    private Button btn_toast1, btn_toast2;
    private static final int PERMISSION_REQUEST_CODE = 1;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.M) {

            if (checkSelfPermission(Manifest.permission.SEND_SMS)
                    == PackageManager.PERMISSION_DENIED) {

                Log.d("permission", "permission denied to SEND_SMS - requesting it");
                String[] permissions = {Manifest.permission.SEND_SMS};

                requestPermissions(permissions, PERMISSION_REQUEST_CODE);

            }
            if (checkSelfPermission(Manifest.permission.CALL_PHONE)
                    == PackageManager.PERMISSION_DENIED) {

                Log.d("permission", "permission denied to CALL_PHONE - requesting it");
                String[] permissions = {Manifest.permission.CALL_PHONE};

                requestPermissions(permissions, PERMISSION_REQUEST_CODE);

            }
        }
        btn_send = (Button) findViewById(R.id.btn_send);
        //第一种点击事件的方法
        btn_send.setOnClickListener(new MyListener());

        //第三种点击事件的方法
        show3();
    }

    //第一种点击事件的方法
    class MyListener implements View.OnClickListener{

        @Override
        public void onClick(View v){
            et_content = (EditText) findViewById(R.id.et_content);
            et_number = (EditText) findViewById(R.id.et_number);
            String content = et_content.getText().toString();
            String number = et_number.getText().toString();
            System.out.println("===="+number);
            System.out.println("===="+content);
            SmsManager sm = SmsManager.getDefault();
            ArrayList<String> smss = sm.divideMessage(content);
            for (String string:smss){
                sm.sendTextMessage(number, null, string, null, null);
            }
        }
    }

    //第二种点击事件,直接在布局文件中添加android:onClick="dail"
    public void dail(View v){
        System.out.println("==============");
        et_number = (EditText) findViewById(R.id.et_number);
        String number = et_number.getText().toString();
        Intent intent = new Intent();
        intent.setAction(intent.ACTION_CALL);
        intent.setData(Uri.parse("tel:" + number));
        startActivity(intent);
    }

    //第三种点击事件的方法
    public void show3(){
        btn_toast1 = (Button) findViewById(R.id.btn_toast1);
        btn_toast2 = (Button) findViewById(R.id.btn_toast2);
        btn_toast1.setOnClickListener(this);
        btn_toast2.setOnClickListener(this);
    }

    //第三种点击的方法
    @Override
    public void onClick(View v){
        switch (v.getId()){
            case R.id.btn_toast1:
                Toast.makeText(this, "弹窗1", Toast.LENGTH_SHORT).show();
                break;
            case R.id.btn_toast2:
                Toast.makeText(this, "弹窗2", Toast.LENGTH_SHORT).show();
                break;
        }
    }

}

申请contentprovider的相关权限

报错如下:

Caused by: java.lang.SecurityException: Permission Denial: opening provider 
com.android.providers.contacts.ContactsProvider2 from ProcessRecord{8e31224 
29224:activity.gudd.com.review/u0a212} (pid=29224, uid=10212)requires 
android.permission.READ_CONTACTS or android.permission.WRITE_CONTACTS
    final private int REQUEST_CODE_ASK_PERMISSIONS = 123;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_contact);
        if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.M) {
            int hasWriteContactsPermission = checkSelfPermission(Manifest.permission.READ_CONTACTS);
            if (hasWriteContactsPermission != PackageManager.PERMISSION_GRANTED){
                requestPermissions(new String[]{Manifest.permission.WRITE_CONTACTS},REQUEST_CODE_ASK_PERMISSIONS);
                return;
            }
        }
        lvList = (ListView) findViewById(R.id.lv_list);
        readContact = readContact();
        System.out.println("HashMap" + readContact);

        lvList.setAdapter(new SimpleAdapter(this, readContact,
                R.layout.activity_contact_item, new String[] {"name", "phone"},
                new int[] { R.id.tv_name, R.id.tv_phone }));

        //给list设置监听,点击以后返回数据
        lvList.setOnItemClickListener(new AdapterView.OnItemClickListener(){

            @Override
            public void onItemClick(AdapterView<?> parent, View view,
                                    int position, long id) {
                //读取联系人的电话号码,并返回数据到上一个页面
                String phone = readContact.get(position).get("phone");
                Intent intent = new Intent();
                intent.putExtra("phone", phone);
                //回传resultCode区分是否选了选项
                setResult(Activity.RESULT_OK, intent);
                //关闭页面
                finish();

            }

        });
    }

                       

### Android Studio权限的配置与使用 在开发 Android 应用程序时,权限管理是一个非常重要的部分。以下是关于如何在 Android Studio 中配置和使用权限的具体方法。 #### 1. 权限分类 Android权限分为两类:正常权限 (Normal Permissions) 和危险权限 (Dangerous Permissions)[^4]。 - **正常权限**不需要用户显式授权即可授予应用。 - **危险权限**则需要开发者主动请求,并由用户决定是否授予权限。 #### 2. 在 `AndroidManifest.xml` 文件中声明权限 无论哪种类型的权限都需要先在项目的 `AndroidManifest.xml` 文件中进行声明。例如: ```xml <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.myapp"> <!-- 声明访问网络的权限 --> <uses-permission android:name="android.permission.INTERNET" /> <!-- 声明读取存储卡的权限 --> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> </manifest> ``` 以上代码片段展示了如何声明两个常见的权限:互联网访问权限以及外部存储读取权限[^5]。 #### 3. 动态申请危险权限 对于危险权限,在运行时还需要通过代码动态向用户请求。以下是一段用于请求权限的示例代码: ```java import android.Manifest; import android.content.pm.PackageManager; import androidx.core.app.ActivityCompat; import androidx.appcompat.app.AppCompatActivity; public class MainActivity extends AppCompatActivity { private static final int REQUEST_CODE_PERMISSIONS = 1001; public void requestPermissions() { String[] permissions = new String[]{ Manifest.permission.CAMERA, Manifest.permission.WRITE_EXTERNAL_STORAGE }; ActivityCompat.requestPermissions(this, permissions, REQUEST_CODE_PERMISSIONS); } @Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); if (requestCode == REQUEST_CODE_PERMISSIONS) { boolean allGranted = true; for (int result : grantResults) { if (result != PackageManager.PERMISSION_GRANTED) { allGranted = false; break; } } if (!allGranted) { // 处理权限被拒绝的情况 } else { // 执行需要权限的操作 } } } } ``` 此代码实现了对相机和写入外部存储两项危险权限的请求逻辑[^6]。 #### 4. 检查权限状态 除了请求权限外,还可以检查当前应用程序是否已经拥有某项特定权限。这可以通过 `ContextCompat.checkSelfPermission()` 方法实现: ```java if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) { // 如果没有该权限,则发起请求 ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, 1); } else { // 已经有权限,执行相应操作 } ``` 这段代码演示了如何检测并处理定位服务的相关权限[^7]。 --- ### 总结 为了确保应用程序能够安全地访问设备资源或数据,必须合理配置和使用权限。具体来说,需要完成以下几个步骤: 1. 在 `AndroidManifest.xml` 文件中声明所需权限; 2. 对于危险权限,还需编写代码以动态请求这些权限; 3. 使用适当的方式检查权限的状态以便做出相应的响应。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值