news 2026/6/28 15:34:33

如何使用豆包手机的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/6/26 9:11:17

RDA与IPv6部署的协同:北京主题日活动如何加速数据资产安全流通?

【摘要】IPv6作为新一代网络基石&#xff0c;为真实数据资产&#xff08;RDA&#xff09;提供了原生安全、海量编址与高效传输能力&#xff0c;二者协同构筑了数据要素安全流通与价值释放的“数字高速公路”。引言数字经济时代的核心生产要素是数据。然而&#xff0c;数据要从原…

作者头像 李华
网站建设 2026/6/26 9:10:23

密码重置漏洞挖掘指南:从原理到实战的完整路径

密码重置漏洞挖掘指南&#xff1a;从原理到实战的完整路径 前言&#xff1a; 密码重置功能是Web应用中最常见也最核心的环节之一&#xff0c;它直接关系到用户账户的安全。正因为其普遍性和高敏感性&#xff0c;一个细微的逻辑缺陷都可能导致整个账户体系的沦陷。密码重置漏洞…

作者头像 李华
网站建设 2026/6/27 21:36:30

智能自动化工具套件:dify-tool-service 完整指南

智能自动化工具套件&#xff1a;dify-tool-service 完整指南 【免费下载链接】dify-tool-service 为AI带路党Pro视频准备 项目地址: https://gitcode.com/gh_mirrors/di/dify-tool-service 在数字化时代&#xff0c;内容创作和可视化呈现已成为日常工作的重要组成部分。…

作者头像 李华
网站建设 2026/6/25 21:42:35

终极指南:如何快速解决Home Assistant安卓连接问题

你是否也遇到了这样的困扰&#xff1f;最近升级Home Assistant到2024.10.4版本后&#xff0c;安卓应用突然无法连接服务器&#xff0c;启动后只显示空白界面&#xff0c;然后弹出"无法连接到Home Assistant"的错误提示&#xff1f;&#x1f62b; 别着急&#xff0c;这…

作者头像 李华
网站建设 2026/6/26 12:36:23

41、高效学习概念:从理论到实践

高效学习概念:从理论到实践 1. 词汇与概念学习基础 在学习过程中,我们会接触到各种各样的词汇和概念。对于日常用语中的概念,要明白真正的同义词相对较少。许多新词汇都带有独特的概念细微差别,有助于我们更精准地表达。比如像“bellicose(好战的)”“bumptious(傲慢的…

作者头像 李华