news 2026/6/10 14:53:31

如何使用豆包手机的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/10 15:03:51

LeetDown:macOS平台A6/A7设备降级工具完全指南

LeetDown&#xff1a;macOS平台A6/A7设备降级工具完全指南 【免费下载链接】LeetDown a GUI macOS Downgrade Tool for A6 and A7 iDevices 项目地址: https://gitcode.com/gh_mirrors/le/LeetDown 对于拥有iPhone 5s、iPad 4等A6/A7芯片设备的用户来说&#xff0c;系统…

作者头像 李华
网站建设 2026/6/10 13:44:11

38、高效练习:记忆与学习的秘诀

高效练习:记忆与学习的秘诀 在学习和成长的道路上,高效的记忆方法和练习策略至关重要。今天,我们将深入探讨一些实用的记忆系统和练习设计规则,帮助你提升学习效率,实现知识的有效吸收和应用。 1. 记忆系统的重要性与常见问题 记忆系统在信息的编码、存储和检索中起着关…

作者头像 李华
网站建设 2026/6/10 15:08:43

Windows Terminal插件系统终极指南:从新手到高手的完整教程

Windows Terminal插件系统终极指南&#xff1a;从新手到高手的完整教程 【免费下载链接】terminal The new Windows Terminal and the original Windows console host, all in the same place! 项目地址: https://gitcode.com/GitHub_Trending/term/terminal 你是否厌倦…

作者头像 李华
网站建设 2026/6/10 11:43:25

fre:ac音频转换终极指南:免费开源工具的创意应用全解析

在数字音乐时代&#xff0c;拥有一款得心应手的音频转换工具就像拥有了一把多功能的音频处理工具。fre:ac作为一款完全免费的开源音频转换软件&#xff0c;以其强大的功能和简洁的界面赢得了全球用户的青睐。今天&#xff0c;就让我们一起探索这款音频处理利器的独特魅力&#…

作者头像 李华
网站建设 2026/6/10 6:24:24

Godot引擎骨骼动画终极指南:Spine Runtime完整解决方案

Godot引擎骨骼动画终极指南&#xff1a;Spine Runtime完整解决方案 【免费下载链接】spine-runtime-for-godot This project is a module for godot that allows it to load/play Spine skeleton animation. 项目地址: https://gitcode.com/gh_mirrors/sp/spine-runtime-for-…

作者头像 李华