news 2026/3/31 6:58:02

如何使用豆包手机的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/3/13 3:31:13

DataHub数据质量监控:从入门到精通的终极指南

DataHub数据质量监控&#xff1a;从入门到精通的终极指南 【免费下载链接】datahub 项目地址: https://gitcode.com/gh_mirrors/datahub/datahub 你正在为数据质量问题而苦恼吗&#xff1f;报表频繁出错、业务决策失误、数据可信度低&#xff1f;别担心&#xff01;本文…

作者头像 李华
网站建设 2026/3/30 10:51:43

Kotaemon宏观经济数据分析:智库研究辅助工具

Kotaemon宏观经济数据分析&#xff1a;智库研究辅助工具 在当今政策节奏日益加快、经济数据瞬息万变的背景下&#xff0c;智库研究人员面临着前所未有的信息处理压力。一份关于房地产调控影响的报告&#xff0c;可能需要整合几十份部委文件、上百个城市的价格指数和多个国际机构…

作者头像 李华
网站建设 2026/3/21 17:42:06

YOLOv11n轻量化革命:如何在边缘设备上实现工业级检测精度?

YOLOv11n轻量化革命&#xff1a;如何在边缘设备上实现工业级检测精度&#xff1f; 【免费下载链接】ultralytics ultralytics - 提供 YOLOv8 模型&#xff0c;用于目标检测、图像分割、姿态估计和图像分类&#xff0c;适合机器学习和计算机视觉领域的开发者。 项目地址: http…

作者头像 李华
网站建设 2026/3/26 4:14:08

UI-TARS桌面版:用自然语言重新定义GUI自动化体验

UI-TARS桌面版&#xff1a;用自然语言重新定义GUI自动化体验 【免费下载链接】UI-TARS-desktop A GUI Agent application based on UI-TARS(Vision-Lanuage Model) that allows you to control your computer using natural language. 项目地址: https://gitcode.com/GitHub_…

作者头像 李华
网站建设 2026/3/24 2:59:54

35、信息深度挖掘与硬件配置优化指南

信息深度挖掘与硬件配置优化指南 在当今信息爆炸的时代,如何高效地从各种信息源中提取有价值的知识,并合理配置硬件环境以提升工作效率,成为了许多人关注的焦点。本文将为你详细介绍音频、电子书及其他媒体资源的深度挖掘方法,以及计算机硬件的优化配置建议。 音频资源深…

作者头像 李华
网站建设 2026/3/18 10:16:29

44、态度改变与元效能框架:心理成长的有效途径

态度改变与元效能框架:心理成长的有效途径 一、态度改变的挑战与方法 (一)态度改变的必要性与困难 人们大多满足于自己现有的态度,包括喜好和厌恶。然而,态度会深刻影响行为,有时可能与自身的最佳利益相冲突,因此,善于反思的人有时会想要改变自己的一些态度。但改变…

作者头像 李华