news 2026/4/16 14:05:57

如何使用豆包手机的READ_FRAME_BUFFER权限截图密码画面

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何使用豆包手机的READ_FRAME_BUFFER权限截图密码画面

背景:

针对READ_FRAME_BUFFER的权限原理剖析前面文章已经进行了详细讲解,具体文章如下:

但是文章也给大家留下了一个疑问,那就是具有READ_FRAME_BUFFER权限到底是否可以截图到手机上secure画面,比如银行等密码手势画面。

针对这个疑问也进行了直播讲解和验证,答案就是READ_FRAME_BUFFER权限确实可以实现对这些敏感隐私画面进行截图。
下面给大家展示相关的源码,大家也可以自行用下面源码进行验证你的设备是否可以截图成果。

直播代码分享:

要进行截图secure layer的接口分享:
frameworks/base/core/java/android/window/ScreenCapture.java

/** * Whether to allow the screenshot of secure layers. Warning: This should only be done * if the content will be placed in a secure SurfaceControl. * * @see ScreenshotHardwareBuffer#containsSecureLayers() */publicTsetCaptureSecureLayers(boolean captureSecureLayers){mCaptureSecureLayers=captureSecureLayers;returngetThis();}

注释可以看出是可以截图安全的layer到sc。
不使用setCaptureSecureLayers截图代码如下:

publicstaticBitmapcaptureScreenshot(){try{final ScreenCapture.CaptureArgs captureArgs=newScreenCapture.CaptureArgs.Builder<>().setSourceCrop(newRect(0,0,2960,1440)).build();ScreenCapture.SynchronousScreenCaptureListener syncScreenCapture=ScreenCapture.createSyncCaptureListener();try{WindowManagerGlobal.getWindowManagerService().captureDisplay(0,captureArgs,syncScreenCapture);}catch(RemoteException e){e.rethrowAsRuntimeException();}final ScreenCapture.ScreenshotHardwareBuffer screenshotHardwareBuffer=syncScreenCapture.getBuffer();returnscreenshotHardwareBuffer.asBitmap();}finally{}}

保存图片到sdcard私有目录方法:

publicstaticStringsaveBitmap(Context context,Bitmap bitmap,String subDir,String fileName){File baseDir=context.getExternalFilesDir(Environment.DIRECTORY_PICTURES);if(baseDir==null)returnnull;File targetDir=newFile(baseDir,subDir);if(!targetDir.exists())targetDir.mkdirs();File imageFile=newFile(targetDir,fileName+".jpg");try(FileOutputStream fos=newFileOutputStream(imageFile)){bitmap.compress(Bitmap.CompressFormat.JPEG,90,fos);fos.flush();returnimageFile.getAbsolutePath();}catch(Exception e){e.printStackTrace();returnnull;}}

调用方式:

CaptureScreenshotUtil.saveBitmap(MainActivity.this,CaptureScreenshotUtil.captureScreenshot(),"aaa","test");

权限声明:

<uses-permission android:name="android.permission.READ_FRAME_BUFFER"></uses-permission>

注意需要基于源码编译apk,系统签名安装。

验证得到的结果
原设备画面展示:

截图到图片展示如下

明显看到手势密码部分的Activity是无法被截图到的,这块与豆包官方声明基本上一致。
但是真的是这样吗?

使用setCaptureSecureLayers后截图情况
代码上只是在原来基础上加入setCaptureSecureLayers(true)

try{final ScreenCapture.CaptureArgs captureArgs=newScreenCapture.CaptureArgs.Builder<>().setSourceCrop(newRect(0,0,2960,1440))//重点差异.setCaptureSecureLayers(true).build();ScreenCapture.SynchronousScreenCaptureListener syncScreenCapture=ScreenCapture.createSyncCaptureListener();try{WindowManagerGlobal.getWindowManagerService().captureDisplay(0,captureArgs,syncScreenCapture);}catch(RemoteException e){Log.e("lsm666888","Failed to request screencapture for display");e.rethrowAsRuntimeException();}final ScreenCapture.ScreenshotHardwareBuffer screenshotHardwareBuffer=syncScreenCapture.getBuffer();returnscreenshotHardwareBuffer.asBitmap();}finally{}

运行后进行截图,效果如下:

可以看出明显这次截图是可以截图到手势密码的画面了,所以最后的结论就是如下:
READ_FRAME_BUFFER权限确实是需要系统签名才可以使用的,默认不设置setCaptureSecureLayers(true)那确实无法截图到手势密码等secure画面,但是如果设置了setCaptureSecureLayers(true)就可以截图到各个secure的内容。

所以READ_FRAME_BUFFER权限是可以截图到各个手势密码等高度隐私的画面。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 14:02:57

Flutter Admin后台管理系统:5大核心模块构建企业级管理平台

Flutter Admin后台管理系统&#xff1a;5大核心模块构建企业级管理平台 【免费下载链接】flutter_admin Flutter Admin: 一个基于 Flutter 的后台管理系统、开发模板。A backend management system and development template based on Flutter 项目地址: https://gitcode.com…

作者头像 李华
网站建设 2026/4/16 12:20:56

思屋电气承接千万级配电项目,以安全用电守护民生教育工程

近日&#xff0c;思屋电气依托在电力建设领域的深厚积淀与丰富实践经验&#xff0c;成功中标并正式承接“北投印象项目Ⅰ标段、配套小学、幼儿园供配电工程”施工项目&#xff0c;合同金额超千万元。目前&#xff0c;该项目已全面展开施工建设。此次成功中标与承建&#xff0c;…

作者头像 李华
网站建设 2026/4/15 17:44:39

GitStats完全指南:快速生成专业级Git仓库分析报告

GitStats完全指南&#xff1a;快速生成专业级Git仓库分析报告 【免费下载链接】git_stats GitStats is a git repository statistics generator. 项目地址: https://gitcode.com/gh_mirrors/gi/git_stats 在软件开发团队中&#xff0c;GitStats作为一款强大的Git统计工具…

作者头像 李华
网站建设 2026/4/16 12:22:29

AutoHotkey终极入门指南:从零开始掌握Windows自动化

AutoHotkey终极入门指南&#xff1a;从零开始掌握Windows自动化 【免费下载链接】AutoHotkey-v1.0 AutoHotkey is a powerful and easy to use scripting language for desktop automation on Windows. 项目地址: https://gitcode.com/gh_mirrors/au/AutoHotkey-v1.0 Au…

作者头像 李华
网站建设 2026/4/16 14:02:01

LOOT模组排序工具:3步解决天际模组冲突的终极指南

LOOT模组排序工具&#xff1a;3步解决天际模组冲突的终极指南 【免费下载链接】skyrimse The TES V: Skyrim Special Edition masterlist. 项目地址: https://gitcode.com/gh_mirrors/sk/skyrimse LOOT模组排序工具是《上古卷轴V&#xff1a;天际 特别版》玩家必备的模组…

作者头像 李华
网站建设 2026/4/16 12:48:28

终极指南:用P3音频格式为ESP32打造高效语音交互系统

终极指南&#xff1a;用P3音频格式为ESP32打造高效语音交互系统 【免费下载链接】xiaozhi-esp32 Build your own AI friend 项目地址: https://gitcode.com/GitHub_Trending/xia/xiaozhi-esp32 你是否在为ESP32设备的语音交互性能而苦恼&#xff1f;传统音频格式在资源受…

作者头像 李华