在ionic中使用cordova-plugin-wechat插件完成微信分享功能。
問題:在華爲p9上可以顯示文字,描述,就是圖片一直是默認圖片。
問題原因:查看插件源碼,發現在分享時會在手機本地創建cache文件夾以及文件,當手機沒有打開存儲權限時就會導致文件找不到,從而使用默認分享圖片。
源碼代碼如下
if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
cacheDir = new File(Environment.getExternalStorageDirectory(), "cache");
if (!cacheDir.isDirectory()) {
cacheDir.mkdirs();
}
}
日誌報錯:
05-23 13:47:09.147 W/System.err(17767): java.io.FileNotFoundException: /storage/emulated/0/cache/DDHX3wB2Q4rxRZXiZEMMxebMb7NT2XNm2DG8.png@300w_1o (Permission denied)
05-23 13:47:09.147 W/System.err(17767): at java.io.FileOutputStream.open(Native Method)
05-23 13:47:09.147 W/System.err(17767): at java.io.FileOutputStream.<init>(FileOutputStream.java:221)
05-23 13:47:09.147 W/System.err(17767): at java.io.FileOutputStream.<init>(FileOutputStream.java:169)
05-23 13:47:09.147 W/System.err(17767): at xu.li.cordova.wechat.Util.downloadAndCacheFile(Util.java:80)
05-23 13:47:09.147 W/System.err(17767): at xu.li.cordova.wechat.Wechat.getFileInputStream(Wechat.java:482)
05-23 13:47:09.147 W/System.err(17767): at xu.li.cordova.wechat.Wechat.getBitmap(Wechat.java:422)
05-23 13:47:09.147 W/System.err(17767): at xu.li.cordova.wechat.Wechat.getThumbnail(Wechat.java:407)
05-23 13:47:09.147 W/System.err(17767): at xu.li.cordova.wechat.Wechat.buildSharingMessage(Wechat.java:327)
05-23 13:47:09.147 W/System.err(17767): at xu.li.cordova.wechat.Wechat$1.run(Wechat.java:189)
05-23 13:47:09.147 W/System.err(17767): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
05-23 13:47:09.147 W/System.err(17767): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
05-23 13:47:09.147 W/System.err(17767): at java.lang.Thread.run(Thread.java:776)