// TODO Auto-generated method stub Looper.prepare(); long bitmapTime = System.currentTimeMillis(); String bitmapDate = new SimpleDateFormat("yyyy-MM-dd-HH-mm-ss") .format(new Date(bitmapTime)); String bitmapDir = "/mnt/usb/sda1" + "/" + "Pictures"; String bitmapFileName = String.format("Screenshot_%s.png", bitmapDate); File mScreenshotDir = new File(bitmapDir); mScreenshotDir.mkdirs(); String bitmapFilePath = String.format("%s/%s", bitmapDir, bitmapFileName); File f = new File(bitmapFilePath); try { FileOutputStream out = new FileOutputStream(f); cacheBitmap.compress(Bitmap.CompressFormat.PNG, 90, out); out.flush(); out.close(); Toast.makeText(context, "WhiteBoard has saved!", Toast.LENGTH_SHORT).show(); Log.i(TAG, "whiteboard has saved!"); } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); Toast.makeText(context, "File not found!", Toast.LENGTH_SHORT) .show(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); Looper.loop(); };但是执行完后,查看U盘,发现根本就没有保存图片!!! W/System.err( 2371): java.io.FileNotFoundException: /mnt/usb/sda1/Pictures/Screenshot_2016-04-25-19-53-41.png: open failed:
EACCES (Permission denied)
W/System.err( 2371):    at libcore.io.IoBridge.open(IoBridge.java:409)
W/System.err( 2371):    at java.io.FileOutputStream.<init>(FileOutputStream.java:88)
W/System.err( 2371):    at java.io.FileOutputStream.<init>(FileOutputStream.java:73)
W/System.err( 2371):    at com.svt.whiteboard.ui.DrawView$1.run(DrawView.java:251)
W/System.err( 2371):    at java.lang.Thread.run(Thread.java:841)
W/System.err( 2371): Caused by: libcore.io.ErrnoException: open failed: EACCES (Permission denied)
W/System.err( 2371):    at libcore.io.Posix.open(Native Method)
W/System.err( 2371):    at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
W/System.err( 2371):    at libcore.io.IoBridge.open(IoBridge.java:393)
W/System.err( 2371):    ... 4 more
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />

在网上找了好久,也没有找到能够解决的方法。 然后请教了一位资深工程师同事。他说怀疑是我的应用的权限不够,看作为系统app能不能保存。然后我在AndroidManifest.xml中加入:
android:sharedUserId="android.uid.system"
 加进去后,然后系统编译,运行再次点击保存,果然能够保存成功!!! 
  看来真是由于权限的问题了。 
  其实系统中也有一些apk会去操作U盘护士sdcard,如Launcher、TV,我也对比了其操作U盘和sdcard的方式,没有发现不同的地方。但是由于 
 Launcher、TV其实也是写了: 
 
android:sharedUserId="android.uid.system"
导致我完全没有想到会是系统权限的问题。其实还是自己了解的太少,水平有限,还是需要多学习。 我们现在使用的SELinux,Android即是SEAndroid,SEAndroid的目在于降低恶意应用程序攻击带来的损害。它通过强化Android操作系统对应用程序的访问控制,增强应用程序之间的隔离效果,确保每个应用程序之间的独立运作,建立类似于沙盒的隔离效果,从而阻止恶意应用程序对系统或其他应用程序的攻击。
而SELinux安全访问机制,APP及framework层默认情况下再无权限访问设备节点。 最近在做画板项目,需要把当前的画板中所画的内容作为图片保存在U盘中。实现起来也不难:Runnable save = new Runnable() { @Override public void run() { // TODO Auto-generated method stub Looper.prepare(); long bitmapTime = Sy 最近在将文件拷贝到U盘时总是 写入失败(Permission denied) 程序清单已经加入了权限 <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:... open failed: EACCES (Permission denied) Caused by: libcore.io.ErrnoException: open failed: EACCES (Permission denied) 解决办法: ①在AndroidManifest.xml文件增加相关读取权限: (只写一个就行,Android会默认添加其相对的另外一个权限)
最近接到一个问题反馈,一个几年前的APP,之前USB热插拔读写备份正常,现在居然不能正常备份。log显示: System.err: java.io.IOException: open failed: EACCES (Permission denied) 但确认权限都有,targetSdkVersion为22,因此不存在动态申请权限的问题。之后用同样的APP在低版本手机上测试正常(有些是需要手...
如果是Android6.0之后,加上权限后再动态申请权限 if (Build.VERSION.SDK_INT > Build.VERSION_CODES.LOLLIPOP) { if (ActivityCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(th
Android extsd open failed: EACCES (Permission denied)其实按照资料,就是在Android6.0之后的手机会,手机各种权限除了在Manifest申明还需要在代码里头申请。还是那句话,注意看log。// Storage Permissions private static final int REQUEST_EXTERNAL_STORAGE ...
Android实现对当前界面截屏,并将截图文件存放至本地文件夹 首先需要动态申请两项权限(Android6.0后危险权限之类的都需要动态申请),在AndroidManifest.xml静态添加 &lt;uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/&gt; &lt;uses-permissi...
Android9.0开发过程,我们想往TF卡里面写入数据的时候,我们在代码和资源文件都申请了权限,但是一直会报如下权限问题 一、错误日志 saveBytes Exception e /storage/A466-13E5/DCIM/test/1627287905384.yuv (Permission denied) 解决办法: 代码路径:system\vold\model\PublicVolume.cpp if (!(mFusePid = fork())) { if (getMo