亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

android H5本地緩存加載優(yōu)化的實戰(zhàn)

瀏覽:3日期:2022-09-19 18:51:55

2020年最后一周,正準備摸摸魚回家過年,須不知“驚天陰謀”已在領導層醞釀。豎日,組長帶著詭異的微笑向我走來:

組長: “快過年了,你回家路途遙遠,要不要請兩天假?”

我: “組長,你真是我的知己,想我所想,思我所思,你這么一說我就不客氣了,那我就請兩天”

組長:“行,請假肯定沒問題,我一向很照顧兄弟們??!”(那一刻,一股暖流心中而過,早已將這一年他對我的“壓榨”拋之腦后)

“不過我還有個事跟你說下,回家前有個需求你得完成”

我:“what??? ,,,, TMD......”

組長:“需求是這樣的:最近客戶反應HTML加載有點慢,需要優(yōu)化下,最好能做到秒開,,,,加油,我相信你”。

我:“不是這H5,加載慢那你前端的原因呀,你找我。。。我。。?!保ńM長已經(jīng)遠去)

帶著沉重的心情開始研究優(yōu)化,開始在webView 層做文章,開啟緩存,預加載,一頓操作效果微乎其微。

然后開始打前端文件的注意,一般本地Html文件加載速度比通過Url的加載速度會快很多。于是去找前端要了一個本地文件放到項目里進行本地加載。果不其然,速度嗖嗖的,此時,尷尬的事情發(fā)生了,前端功能經(jīng)常更新,如果放到項目里豈不是H5更新,我就得升級版本。且不說我得累死,估計這方案提到組長那,他得提刀來見了。 于是另辟蹊徑,將通過接口下載HTMl文件,存在到手機本地,這樣webView去加載手機本地文件即可。一弧詭異的微笑在臉上散開。

動手: 1.偷了懶,用 filedownloader 去下載了Html壓縮文件

implementation ’com.liulishuo.filedownloader:library:1.7.7’

封裝下載工具類:

public class FileDownloadUtils {public static FileDownloadUtils instance = null;public FileDownloadUtils() {}public static FileDownloadUtils getInstance() { if (null == instance) { instance = new FileDownloadUtils(); } return instance;}/** * 單任務下載 * * @param downLoadUri 文件下載網(wǎng)絡地址 * @param destinationUri 下載文件的存儲絕對路徑 */public void startDownLoadFileSingle(String downLoadUri, String destinationUri,FileDownLoaderCallBack callBack) { FileDownloader.getImpl().create(downLoadUri).setPath(destinationUri).setListener(fileDownloadListener(callBack)).start();}// 下載方法private FileDownloadListener fileDownloadListener(final FileDownLoaderCallBack callBack) { return new FileDownloadListener() { @Override protected void pending(BaseDownloadTask task, int soFarBytes, int totalBytes) { //等待,已經(jīng)進入下載隊列 } @Override protected void progress(BaseDownloadTask task, int soFarBytes, int totalBytes) { //下載進度回調(diào) if (callBack != null){callBack.downLoadProgress(task,soFarBytes,totalBytes); } } @Override protected void completed(BaseDownloadTask task) { //完成整個下載過程 if (callBack != null){callBack.downLoadCompleted(task); } } @Override protected void paused(BaseDownloadTask task, int soFarBytes, int totalBytes) { //暫停下載 } @Override protected void error(BaseDownloadTask task, Throwable e) { //下載出現(xiàn)錯誤 if (callBack != null){callBack.downLoadError(task,e); } } @Override protected void warn(BaseDownloadTask task) { //在下載隊列中(正在等待/正在下載)已經(jīng)存在相同下載連接與相同存儲路徑的任務 } };} public interface FileDownLoaderCallBack { //文件是否下載完成 void downLoadCompleted(BaseDownloadTask task); //文件是否下載失敗 void downLoadError(BaseDownloadTask task, Throwable e); //文件下載進度 void downLoadProgress(BaseDownloadTask task, int soFarBytes, int totalBytes); }}

解壓Zip文件

public class ZipUtils { public static final String TAG = 'ZIP'; public ZipUtils() { }/** * 解壓zip到指定的路徑 * * @param zipFileString ZIP的名稱 * @param outPathString 要解壓縮路徑 * @throws Exception */public static void UnZipFolder(String zipFileString, String outPathString) throws Exception { ZipInputStream inZip = new ZipInputStream(new FileInputStream(zipFileString)); ZipEntry zipEntry; String szName = ''; while ((zipEntry = inZip.getNextEntry()) != null) { szName = zipEntry.getName(); if (zipEntry.isDirectory()) { szName = szName.substring(0, szName.length() - 1); File folder = new File(outPathString + File.separator + szName); folder.mkdirs(); } else { Log.e(TAG, outPathString + File.separator + szName); File file = new File(outPathString + File.separator + szName); if (!file.exists()) {Log.e(TAG, 'Create the file:' + outPathString + File.separator + szName);file.getParentFile().mkdirs();file.createNewFile(); } // 獲取文件的輸出流 FileOutputStream out = new FileOutputStream(file); int len; byte[] buffer = new byte[1024]; // 讀?。ㄗ止?jié))字節(jié)到緩沖區(qū) while ((len = inZip.read(buffer)) != -1) {// 從緩沖區(qū)(0)位置寫入(字節(jié))字節(jié)out.write(buffer, 0, len);out.flush(); } out.close(); } } inZip.close();}public static void UnZipFolder(String zipFileString, String outPathString, String szName) throws Exception { ZipInputStream inZip = new ZipInputStream(new FileInputStream(zipFileString)); ZipEntry zipEntry; while ((zipEntry = inZip.getNextEntry()) != null) { //szName = zipEntry.getName(); if (zipEntry.isDirectory()) { //獲取部件的文件夾名 szName = szName.substring(0, szName.length() - 1); File folder = new File(outPathString + File.separator + szName); folder.mkdirs(); } else { Log.e(TAG, outPathString + File.separator + szName); File file = new File(outPathString + File.separator + szName); if (!file.exists()) {Log.e(TAG, 'Create the file:' + outPathString + File.separator + szName);file.getParentFile().mkdirs();file.createNewFile(); } // 獲取文件的輸出流 FileOutputStream out = new FileOutputStream(file); int len; byte[] buffer = new byte[1024]; // 讀?。ㄗ止?jié))字節(jié)到緩沖區(qū) while ((len = inZip.read(buffer)) != -1) {// 從緩沖區(qū)(0)位置寫入(字節(jié))字節(jié)out.write(buffer, 0, len);out.flush(); } out.close(); } } inZip.close();}/** * 壓縮文件和文件夾 * * @param srcFileString 要壓縮的文件或文件夾 * @param zipFileString 解壓完成的Zip路徑 * @throws Exception */public static void ZipFolder(String srcFileString, String zipFileString) throws Exception { //創(chuàng)建ZIP ZipOutputStream outZip = new ZipOutputStream(new FileOutputStream(zipFileString)); //創(chuàng)建文件 File file = new File(srcFileString); //壓縮 // LogUtils.LOGE('---->'+file.getParent()+'==='+file.getAbsolutePath()); ZipFiles(file.getParent()+ File.separator, file.getName(), outZip); //完成和關閉 outZip.finish(); outZip.close();}/** * 壓縮文件 * * @param folderString * @param fileString * @param zipOutputSteam * @throws Exception */private static void ZipFiles(String folderString, String fileString, ZipOutputStream zipOutputSteam) throws Exception { // LogUtils.LOGE('folderString:' + folderString + 'n' +'fileString:' + fileString + 'n=========================='); if (zipOutputSteam == null) return; File file = new File(folderString + fileString); if (file.isFile()) { ZipEntry zipEntry = new ZipEntry(fileString); FileInputStream inputStream = new FileInputStream(file); zipOutputSteam.putNextEntry(zipEntry); int len; byte[] buffer = new byte[4096]; while ((len = inputStream.read(buffer)) != -1) { zipOutputSteam.write(buffer, 0, len); } zipOutputSteam.closeEntry(); } else { //文件夾 String fileList[] = file.list(); //沒有子文件和壓縮 if (fileList.length <= 0) { ZipEntry zipEntry = new ZipEntry(fileString + File.separator); zipOutputSteam.putNextEntry(zipEntry); zipOutputSteam.closeEntry(); } //子文件和遞歸 for (int i = 0; i < fileList.length; i++) { ZipFiles(folderString+fileString+'/', fileList[i], zipOutputSteam); } }}/** * 返回zip的文件輸入流 * * @param zipFileString zip的名稱 * @param fileString ZIP的文件名 * @return InputStream * @throws Exception */public static InputStream UpZip(String zipFileString, String fileString) throws Exception { ZipFile zipFile = new ZipFile(zipFileString); ZipEntry zipEntry = zipFile.getEntry(fileString); return zipFile.getInputStream(zipEntry);}/** * 返回ZIP中的文件列表(文件和文件夾) * * @param zipFileString ZIP的名稱 * @param bContainFolder 是否包含文件夾 * @param bContainFile 是否包含文件 * @return * @throws Exception */public static List<File> GetFileList(String zipFileString, boolean bContainFolder, boolean bContainFile) throws Exception { List<File> fileList = new ArrayList<File>(); ZipInputStream inZip = new ZipInputStream(new FileInputStream(zipFileString)); ZipEntry zipEntry; String szName = ''; while ((zipEntry = inZip.getNextEntry()) != null) { szName = zipEntry.getName(); if (zipEntry.isDirectory()) { // 獲取部件的文件夾名 szName = szName.substring(0, szName.length() - 1); File folder = new File(szName); if (bContainFolder) {fileList.add(folder); } } else { File file = new File(szName); if (bContainFile) {fileList.add(file); } } } inZip.close(); return fileList;}}

下載:

File file = new File(Constants.saveH5FilePath); if (file.exists()) { file.delete(); } //開始下載ZIP壓縮包 FileDownloadUtils.getInstance().startDownLoadFileSingle(bean.getUrl(), Constants.saveH5FilePath,new FileDownloadUtils.FileDownLoaderCallBack() { @Override public void downLoadCompleted(BaseDownloadTask task) { try { //解壓ZIP壓縮包 ZipUtils.UnZipFolder(Constants.saveH5FilePath, Constants.unH5ZipPath); PreferencesUtil.getInstance().saveParam('H5VersionName', H5VersionName); } catch (Exception e) { e.printStackTrace(); } } @Override public void downLoadError(BaseDownloadTask task, Throwable e) { } @Override public void downLoadProgress(BaseDownloadTask task, int soFarBytes, int totalBytes) { }});

webView 加載:

mWebSe.loadUrl('file:'+ Constants.unH5ZipPath+'/index.html');

此時,心如止水 ,,回家,搜噶。。。。

以上就是android H5本地緩存加載優(yōu)化的實戰(zhàn)的詳細內(nèi)容,更多關于android H5本地緩存加載優(yōu)化的資料請關注好吧啦網(wǎng)其它相關文章!

標簽: Android
相關文章:
主站蜘蛛池模板: 一级国产视频 | 亚洲欧美色综合一区二区在线 | 中国大陆一级毛片 免费 | 久久熟 | 91高清在线成人免费观看 | 欧美日韩一区二区三区在线视频 | 人人草人人干 | 免费成年人在线观看视频 | 性生活免费网站 | 亚洲综合美腿丝国产一区 | 欧美久草在线 | 国产毛片一区二区三区精品 | 国产免费观看网站 | chinese国产在线视频 | 国产乱理伦片在线观看 | 亚洲欧美中日韩 | aa国产| 日本老年人精品久久中文字幕 | 南京巨根无套操到你窒息 | 亚洲色图日韩精品 | 成人在线观看国产 | 国产日产欧产精品 | 污91视频 | 伊人久久在线观看 | 日本精品一区二区三本中文 | 污视频网站免费 | 亚洲激情综合网 | 久久婷婷国产综合精品 | 国产成人一区二区三区高清 | 日韩亚洲欧美综合一区二区三区 | 亚洲综合国产一区在线 | 成人毛片免费免费 | 国产精品综合视频 | 久久久久久a亚洲欧洲aⅴ | www.黄色网址.com | 天天综合天天色 | 91tv最新永久在线地址 | 国产欧美精品一区二区三区-老狼 | 国产精品日日做人人爱 | 亚洲视频一区网站 | 久久综合九色综合欧美9v777 |