android之database disk image is malformed (code 11)

做来电显示归属地和查询归属地功能的时候,需要从服务器下载数据库,但是下载之后,查询总是报错database disk image is malformed (code 11)开始以为是查询语句不对,后来意识到,跟之前解析包时出现错误是一样的问题,下载过程中格式损坏了。于是解决方法跟http://blog.csdn.net/jason0539/article/details/2174

大家好,又见面了,我是全栈君。

做来电显示归属地和查询归属地功能的时候,需要从服务器下载数据库,

但是下载之后,查询总是报错database disk image is malformed (code 11)

开始以为是查询语句不对,后来意识到,跟之前解析包时出现错误是一样的问题,

下载过程中格式损坏了。

于是解决方法跟http://blog.csdn.net/jason0539/article/details/21742019采取了一样的策略,

把每次读取的数组缩小,代码如下:

public class DownloadTask {  
      
    /** 
     * @param path下载地址 
     * @param filePath存储路径 
     * @param progressDialog进度条 
     * @return 
     * @throws Exception 
     */  
    public static File getFile(String path,String filePath,ProgressDialog progressDialog) throws Exception{  
          
        URL url = new URL(path);  
        HttpURLConnection connection = (HttpURLConnection) url.openConnection();  
        connection.setConnectTimeout(2000);  
        connection.setRequestMethod("GET");  
        if(connection.getResponseCode() == 200){  
            int total = connection.getContentLength();  
            progressDialog.setMax(total);  
              
            InputStream is = connection.getInputStream();//获得socket输入流  
            File file = new File(filePath);  
            FileOutputStream fos = new FileOutputStream(file);//file输出流  
            byte[] buffer = new byte[1024];  
            int len;  
            int progress = 0;  
            while((len = is.read(buffer)) != -1){  
                fos.write(buffer);  
                progress += len;  
                progressDialog.setProgress(progress);  
            }  
            fos.flush();  
            is.close();  
            fos.close();  
            connection.disconnect();  
            return file;  
        }  
        return null;  
    }  

把里面这行里的1024改小就可以避免损坏了,

 byte[] buffer = new byte[1024];  

由于总是错,我甚至改成了

byte[] buffer = new byte[8];

这样是没错了,但是有个弊端,下载变的很慢,下载的数据库是16M的,奇慢无比,

临时性这样解决了。

 

作者:jason0539

微博:http://weibo.com/2553717707

博客:http://blog.csdn.net/jason0539(转载请说明出处)

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/121361.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 深度学习: RPN (区域候选网络)

    深度学习: RPN (区域候选网络)Overview绿框内为RPN所在的位置:放大之后是这样:庖丁解牛RPN由以下三部分构成:在RPN头部,通过以下结构生成anchor(其实就是一堆有编号有坐标的bbox):论文中的这幅插图对应的就是RPN头部:(曾经以为这张图就是整个RPN,于是百思不得其解,走了不少弯路。。。)在RPN中部,分类分支(cls)和边框回归分支(b…

    2022年6月23日
    101
  • delphi 进程通信_多线程实现java

    delphi 进程通信_多线程实现java多线程总体认识当前程序是一个进程,进程只是一个工作环境,线程是工作者; 每个进程都会有一个启动线程(或叫主线程),也就是说:大量的编码都是写给这个主线程的; ExitThread(0);退出主线程; 系统不允许一个没有线程的进程存在,所以程序就退出了. ExitThread函数的参数是一个退出码,这个退出码是给之后的其他函数用的,这里随便给个无符号整数即可….

    2025年5月24日
    0
  • Mysql怎样控制replace替换的次数?

    Mysql怎样控制replace替换的次数?

    2021年10月21日
    45
  • densenet网络结构详解_网络dea模型

    densenet网络结构详解_网络dea模型网络基本结构 我们放大一下DenseBlockDenseBlock 上图中每一次的输入都是经过Channel-wiseconcatenation后的,如k0+k,k为growthrate。denseblock一个核心的点就是:每一层的输入来自前面所有层的输出。如下,H2的输入=最开始的输入 + H1的输出= k0+kH3的输入=最开始的输入 …

    2022年9月1日
    3
  • 大数据治理包括哪几个方面

    大数据治理包括哪几个方面在数据治理中 涉及到了前端业务系统 后端业务数据库系统再到业务终端的数据分析 从源头到终端再回到源头 形成的一个闭环负反馈系统 同样地 在数据治理中 我们也需要一套标准化的规范来指导数据的采集 传输 储存以及应用 数据治理包括数据规划 数据采集 数据储存管理 数据应用四个方面 根据每一个方面的特点 我们可以将数据治理总结为四个字 即 理 采 存 用 01 理 梳理业务流程 规划数据资源 对于企业来说 每天的实时数据都会超过 TB 级别 需要采集用户的哪些数据 这么多的数据放

    2025年6月2日
    0
  • 开车旅行游戏_开车周游世界

    开车旅行游戏_开车周游世界题目链接这道题最基本的思路是用倍增,但是其实它的难点在预处理部分。倍增的部分此次就不细说了,和之前的最近公共祖先的思想类似。我们主要来探讨一下预处理的部分。我们需要预处理出每个城市小A和小B的选择目标和对应的距离,接下来就可以处理出进行2k轮开车的目的地和距离了。所以前者才是重中之重,而前者如果要用暴力的方法会tle的。有人可能会疑惑,我们找当前点的后面两三个不就可以了?为什么会tle呢?实际上并不是序号相差很远距离就很远,实际上有可能第一个城市和最后一个城市最近,可以举个例子,城市海拔如下:

    2022年8月22日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号