kotlin根据文件的filePath转化为uri

本文介绍了如何在Android应用中使用FileProvider创建安全的文件URI,包括在AndroidManifest.xml中配置FileProvider、定义file_paths.xml路径以及处理Android10及以上版本的权限请求。
摘要由CSDN通过智能技术生成

方法实现

使用File类来创建一个文件对象,然后通过FileProvider来获取文件的URI

import android.content.Context
import android.net.Uri
import androidx.core.content.FileProvider
import java.io.File

fun getFileUri(context: Context, filePath: String): Uri {
    val file = File(filePath)
    return FileProvider.getUriForFile(context, context.packageName + ".fileprovider", file)//["context.packageName + ".fileprovider"]与AndroidManifest.xml中配置的authority一致。
}

getFileUri函数接受一个Context对象和文件的路径filePath作为参数,然后使用File类创建文件对象,最后通过FileProvider.getUriForFile方法将文件转换为URI。

添加配置

1. 在AndroidManifest.xml文件中配置了FileProvider。
AndroidManifest.xml文件配置FileProvider的authority。在使用FileProvider时,需要在AndroidManifest.xml文件中正确配置FileProvider的authority,以便系统能够正确识别和处理文件URI。

<application>

    <provider
        android:name="androidx.core.content.FileProvider"
        android:authorities="xx.xx.xx.xx.fileprovider"
        android:exported="false"
        android:grantUriPermissions="true">
        <meta-data
            android:name="android.support.FILE_PROVIDER_PATHS"
            android:resource="@xml/file_paths" />
    </provider>
</application>

android:authorities属性指定了FileProvider的authority,需要与上面FileProvider.getUriForFile方法中传递的authority一致。

2. 在res/xml目录下创建一个名为file_paths.xml的文件,用于指定FileProvider的路径配置。这个文件中定义了应用程序可以访问的文件路径。
在res/xml目录下创建一个名为file_paths.xml的文件,用于指定FileProvider的路径配置。如果没有xml目录,可以手动创建。

<?xml version="1.0" encoding="utf-8"?>
<paths>
    <external-path name="external_files" path="." />
</paths>

方法调用:

在使用这个函数时,您可以传入当前的Context对象和文件的路径,然后获取文件的URI。
请注意,由于Android 10及以上版本对文件访问权限进行了更严格的限制,因此在处理文件时需要特别注意权限问题。
权限申请:


    private fun applyPermission() {
        if (Build.VERSION.SDK_INT >= 23) {
            val allPermissions = arrayOf(
                Manifest.permission.WRITE_EXTERNAL_STORAGE,
                Manifest.permission.READ_EXTERNAL_STORAGE
            )
            var needapply = false
            for (i in allPermissions.indices) {
                val checkPermission = ContextCompat.checkSelfPermission(
                    applicationContext,
                    allPermissions[i]
                )
                if (checkPermission != PackageManager.PERMISSION_GRANTED) {
                    needapply = true
                }
            }
            if (needapply) {
                ActivityCompat.requestPermissions(this, allPermissions, 1)
            }
        }
    }

Activity中,this关键字表示当前的Activity对象,因为Activity本身就是一个Context,所以可以直接将this传递给getFileUri函数。

applyPermission()
val fileUri = getFileUri(this, filePath)

拓展

Q:FileProvider的authority有什么作用?
A:FileProvider的authority是用于唯一标识FileProvider、授权访问文件、权限控制以及生成安全的URI的重要参数

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值