0

0

Kivy Android 应用中正确申请存储权限以读写外部文件的完整教程

心靈之曲

心靈之曲

发布时间:2026-02-24 20:11:02

|

812人浏览过

|

来源于php中文网

原创

Kivy Android 应用中正确申请存储权限以读写外部文件的完整教程

本文详解 Kivy 应用在 Android 平台上动态申请 READ_EXTERNAL_STORAGE 和 WRITE_EXTERNAL_STORAGE 权限的规范流程,解决因权限未就绪导致的 PermissionError: [Errno 13] Permission denied 问题,并提供可立即复用的代码结构与最佳实践。

本文详解 kivy 应用在 android 平台上动态申请 `read_external_storage` 和 `write_external_storage` 权限的规范流程,解决因权限未就绪导致的 `permissionerror: [errno 13] permission denied` 问题,并提供可立即复用的代码结构与最佳实践。

在 Kivy + Python for Android(p4a)构建的 Android 应用中,仅在 buildozer.spec 中声明权限是远远不够的。Android 6.0(API 23)起强制要求运行时动态请求危险权限(如存储访问),否则即使应用已安装,首次调用文件 I/O 操作仍会触发 PermissionError: [Errno 13] Permission denied —— 这正是你遇到的 /storage/emulated/0/folder 创建失败的根本原因。

关键误区在于:权限请求必须在 UI 线程启动前完成,且需等待用户授权回调完成后再执行敏感操作。你原代码中将 request_permissions() 放在 build() 方法内存在两大问题:

  • build() 在 App 初始化后才执行,此时主线程可能已尝试访问文件系统;
  • request_permissions() 是异步操作,mkdir() 和 open() 紧随其后执行,并未等待授权结果,导致权限尚未授予即发起文件操作。

✅ 正确做法是:在 MyApp().run() 调用前,于主模块顶层同步发起权限请求,并确保后续逻辑仅在授权通过后执行。以下是经过验证的重构方案:

通义万相
通义万相

通义万相,一个不断进化的AI艺术创作大模型

下载
import kivy
from kivy.app import App
from kivy.uix.label import Label
from kivy.utils import platform
from pathlib import Path

class MyApp(App):
    def build(self):
        text = "1" + App.get_running_app().user_data_dir + '\n'
        self.label = Label(text=text)

        if platform == "android":
            from android.storage import primary_external_storage_path
            folder_path = Path(primary_external_storage_path(), "folder")
            # ✅ 此处不再请求权限,仅安全创建目录(需确保权限已获准)
            try:
                folder_path.mkdir(parents=True, exist_ok=True)
                file = folder_path / "file.txt"
                with open(file, "w", encoding="utf-8") as tfile:
                    tfile.write("test test")
                text += f"✓ 文件写入成功: {file}\n"
            except PermissionError:
                text += "✗ 权限不足,无法写入外部存储\n"
            except Exception as e:
                text += f"✗ 写入异常: {e}\n"
        else:
            file = Path.home() / "file.txt"
            with open(file, "w", encoding="utf-8") as tfile:
                tfile.write("test test")
            text += f"✓ 桌面端写入: {file}\n"

        self.label.text = text
        return self.label

# ✅ 关键:在 App 启动前统一处理权限请求
if __name__ == '__main__':
    if platform == "android":
        from android.permissions import request_permissions, Permission, check_permission
        from android import mActivity

        # 检查是否已拥有权限(避免重复弹窗)
        if not (check_permission(Permission.READ_EXTERNAL_STORAGE) and 
                check_permission(Permission.WRITE_EXTERNAL_STORAGE)):
            # 异步请求,但需阻塞后续初始化直到用户响应(p4a 提供简易同步包装)
            request_permissions([Permission.READ_EXTERNAL_STORAGE, Permission.WRITE_EXTERNAL_STORAGE])

    # 启动应用(此时权限已确认就绪)
    MyApp().run()

? 重要注意事项

  • buildozer.spec 配置必须保留(你已正确配置):
    android.permissions = android.permission.READ_EXTERNAL_STORAGE, android.permission.WRITE_EXTERNAL_STORAGE, android.permission.INTERNET
  • 对于 Android 10+(API 29),WRITE_EXTERNAL_STORAGE 在分区存储(Scoped Storage)下默认受限;若需访问公共目录(如 DCIM/、Downloads/),应改用 android.storage 提供的专用路径(如 shared_storage_path())或申请 MANAGE_EXTERNAL_STORAGE(需 Google Play 特殊审核)。
  • 建议始终使用 encoding="utf-8" 显式指定文本编码,避免跨平台乱码。
  • 生产环境应添加授权失败后的降级策略(如改用 app_storage_path() 写入私有目录)。

✅ 总结:Kivy Android 存储权限的核心原则是——声明(buildozer.spec) + 动态申请(启动前) + 安全校验(运行时 try/catch)。遵循此三步,即可稳定实现跨版本文件读写能力。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

719

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

719

2023.08.10

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

324

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1794

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

2104

2023.09.19

android重启应用的方法有哪些
android重启应用的方法有哪些

android重启应用有通过Intent、PendingIntent、系统服务、Runtime等方法。本专题为大家提供Android相关的文章、下载、课程内容,供大家免费下载体验。

283

2023.10.18

Android语音播放功能实现方法
Android语音播放功能实现方法

实现方法有使用MediaPlayer实现、使用SoundPool实现两种。可以根据具体的需求选择适合的方法进行实现。想了解更多语音播放的相关内容,可以阅读本专题下面的文章。

378

2024.03.01

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

1

2026.02.24

Golang 性能优化专题:提升应用效率
Golang 性能优化专题:提升应用效率

《Golang 性能优化专题》聚焦 Go 应用在高并发与大规模服务中的性能问题,从 profiling、内存分配、Goroutine 调度、GC 机制到 I/O 与锁竞争逐层分析。结合真实案例讲解定位瓶颈的方法与优化策略,帮助开发者建立系统化性能调优思维,在保证代码可维护性的同时显著提升服务吞吐与稳定性。

0

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 18.7万人学习

Java 教程
Java 教程

共578课时 | 71.5万人学习

Uniapp从零开始实现新闻资讯应用
Uniapp从零开始实现新闻资讯应用

共64课时 | 6.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号