先贴一段错误代码上来:
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: Callback failure for call to http://192.168.1.100:8080/...
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: java.io.IOException: open failed: EACCES (Permission denied)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at java.io.File.createNewFile(File.java:939)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at com.bighuan.okhttpsimple.MainActivity$1.onResponse(MainActivity.java:186)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at okhttp3.RealCall$AsyncCall.execute(RealCall.java:135)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at java.lang.Thread.run(Thread.java:818)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: Caused by: android.system.ErrnoException: open failed: EACCES (Permission denied)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at libcore.io.Posix.open(Native Method)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at libcore.io.BlockGuardOs.open(BlockGuardOs.java:186)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: at java.io.File.createNewFile(File.java:932)
02-26 09:31:46.124 23366-23998/com.bighuan.okhttpsimple D/OkHttp: ... 6 more
今天在学习okhttp这个超级好用的框架,自己跟着老师的步伐码代码,写一个下载文件的小功能,主要就是实现将一张图片下载到 这个file, 在运行前也添加了这三个必要的权限.
final File file = new File(Environment.getExternalStorageDirectory(), "bighuan.jpg"),
但是,无论我怎么运行,都报了上面我贴出来的那个错误,我就检查代码,检查权限,运行来运行去,百度来百度去,终于发<uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
现了在Android API23+以上,除了在AndroidManifest.xml添加权限外,还要在程序中动态添加权限,最终找到了解决
方法.只要在我们执行读写操作的方法前面添加如下代码即可.
之前一直没遇见过这种问题,突然遇见还真是花了我一些时间,以后遇见类似的问题时,就可以有解决思路了.// 读写权限 private static final int REQUEST_EXTERNAL_STORAGE = 1; private static String[] PERMISSIONS_STORAGE = { Manifest.permission.READ_EXTERNAL_STORAGE, Manifest.permission.WRITE_EXTERNAL_STORAGE}; public static void verifyStoragePermissions(Activity activity) { int permission = ActivityCompat.checkSelfPermission(activity, Manifest.permission.WRITE_EXTERNAL_STORAGE); if (permission != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(activity, PERMISSIONS_STORAGE, REQUEST_EXTERNAL_STORAGE); } }