安卓开发,应用读取图片时出现:Permission denied 解决方法(跟运行时权限管理相关)

最近需要在安卓上用app跑一些实验,就开始学习安卓开发,过程中在访问图片时报了Permission denied。这是因为在安卓6.0(对应API级别为23)及以上版本中,对危险权限引入了运行时权限管理,不能直接通过在 AndroidManifest.xml 中声明获得这些权限。

正文

首先,添加权限到AndroidManifest.xml中

首先,跟很多别的方法一样,要在 AndroidManifest.xml 中先声明需要的权限:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.helloworld">
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>

    <application 
        android:requestLegacyExternalStorage="true"
        <activity
            ...>
            ...
        </activity>
    </application>
</manifest>

添加上 <uses-permission>,还要在<application>中添加上android:requestLegacyExternalStorage="true"

其次,运行时权限获取

假设要实现一个简单功能,就是点击按钮之后输出读取的图片尺寸。
主要注意一下onClick中的部分。

第一部分

public class FirstActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.first_layout);
        Log.d("class info", this.toString());
        Log.d("class name", getClass().getSimpleName());
        Button button = findViewById(R.id.button1);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                // 进行一个判断,是否已经有访问权限,如果没有先获取
                if(ContextCompat.checkSelfPermission(FirstActivity.this, Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED){
                    ActivityCompat.requestPermissions(FirstActivity.this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, 1);
                }
                else {
                // 如果已经有权限,则执行我们要实现的功能
                    readTest();
                }


                // Bitmap bitmap = BitmapFactory.decodeFile("/")
            }
        });
    }
}

第二部分

还要重写onRequestPermissionsResult()函数:

	@Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if(requestCode == 1){
            if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){
            // 表明获取到了权限,直接执行我们的函数
                readTest();
            }
        }
        else {
        // 表明取消了授权
            Toast.makeText(FirstActivity.this, "you denied.", Toast.LENGTH_SHORT).show();
        }
    }

附自己的简单函数

我们要实现的简单功能的函数为:

protected void readTest(){
        try{
            File externalStorage = Environment.getExternalStorageDirectory();
            String picturePath = externalStorage.getPath() + "/1.jpg";
            Bitmap bitmap = BitmapFactory.decodeFile(picturePath);
            // Toast.makeText(FirstActivity.this, bitmap.toString(), Toast.LENGTH_LONG).show();
            Toast.makeText(FirstActivity.this, "读取成功,图片size为 " + bitmap.getWidth() + "x" + bitmap.getHeight(), Toast.LENGTH_LONG).show();
        } catch (Exception e){
            Toast.makeText(FirstActivity.this, "读取失败", Toast.LENGTH_SHORT).show();
            e.printStackTrace();
        }
    }

成功结果如下

在这里插入图片描述 在这里插入图片描述

参考

请求应用权限 | android开发者

ifconfig: ioctl 8927: Permission denied 是一个错误提示,表明执行ifconfig命令遇到了权限拒绝的问题。在Linux系统中,一些敏感的网络配置命令可能需要root权限才能执行。根据引用和引用的描述,您所遇到的问题可能是由于缺少权限而导致的。 引用中的错误提示"cat: sys/class/net/eth0/address: Permission denied"表明您在尝试读取网络接口eth0的地址被拒绝了权限。引用中的错误提示"ifconfig: SIOCSIFADDR: Permission denied"表明您在尝试配置IPv6地址同样被拒绝了权限。 引用中的错误提示"avc: denied { read } for name=“address” dev=“sysfs” ino=25277 scontext=u:r:system_app:s0 tcontext=u:object_r:sysfs:s0 tclass=file permissive=0"提供了更多关于权限被拒绝的详细信息,这可能与SELinux(Security-Enhanced Linux)策略有关。 要解决这个问题,您可以尝试以下方法: 1. 确保您具有足够的权限来执行ifconfig命令。您可以尝试使用sudo命令以root权限执行该命令,例如:sudo ifconfig。 2. 如果您是系统管理员,请确保您已经正确配置了SELinux策略,以便允许执行ifconfig命令。您可以参考相关文档或咨询系统管理员来进行配置。 3. 如果您不是系统管理员,您可以联系系统管理员或具有root权限的用户来帮助您执行相关配置和命令。 请注意,修改系统配置和执行敏感的网络命令可能会对系统安全产生影响,因此请谨慎操作,并确保您知道自己在做什么。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [AndroidQ(10.0) system app 增加访问 sys/class/ 权限](https://blog.csdn.net/u012932409/article/details/108824659)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [LINUX配置ipv6地址出现ifconfig: SIOCSIFADDR: Permission denied](https://blog.csdn.net/liuhaihualy/article/details/101783656)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值