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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Oracle 根据dbf文件的数据恢复[通俗易懂]

    Oracle 根据dbf文件的数据恢复[通俗易懂]数据丢失真的是很严重的事情,此处记录下一次数据恢复的历程。背景:服务器上,Oracle数据库数据丢失,开发机上,有数据,但是因为系统坏了(太巧了),先进去把dbf文件备份出来,然后重做了系统(全盘格式化的,不要问我为什么不是只有c盘,售后做的,所以才有了后面数据恢复困难的事情)。数据恢复方法:1.闪回2.根据dbf恢复3.使用工具prm-dul方案一:数据闪回。…

    2022年7月17日
    12
  • iPhone 抓包工具Charles使用[通俗易懂]

    iPhone 抓包工具Charles使用[通俗易懂]Charles是在Mac下常用的截取网络封包的工具,在做iOS开发时,我们为了调试与服务器端的网络通讯协议,常常需要截取网络封包来分析。Charles通过将自己设置成系统的网络访问代理服务器,使得所有的网络访问请求都通过它来完成,从而实现了网络封包的截取和分析。Charles主要的功能包括:支持SSL代理。可以截取分析SSL的请求。支持流量控制。可以模拟慢速网络

    2022年5月16日
    545
  • ip addr 和 ifconfig「建议收藏」

    ip addr 和 ifconfig「建议收藏」你知道怎么查看IP地址吗?当面试听到这个问题的时候,面试者常常会觉得走错了房间。我面试的是技术岗位啊,怎么问这么简单的问题?的确,即便没有专业学过计算机的人,只要倒腾过电脑,重装过系统,大多也会知道这个问题的答案:在Windows上是ipconfig,在Linux上是ifconfig。那你知道在Linux上还有什么其他命令可以查看IP地址吗?答案是ipad…

    2022年7月28日
    21
  • 常用的css文件_css常用的三种选择器

    常用的css文件_css常用的三种选择器reset.css(几乎每个项目都要引入的css)@charset"utf-8";html{background-color:#fff;color:#000;font-size

    2022年8月1日
    6
  • IGMP协议原理与配置[通俗易懂]

    IGMP协议原理与配置[通俗易懂]组播通信中,发送者将组播数据数据发送到特定的组播地址。

    2025年11月17日
    2
  • 独立成分分析 ( ICA )

    独立成分分析 ( ICA )PCA是一个降维的过程,ICA则是帮助你从多个维度分离有用数据的过程。1.概念独立成分分析是从多元(多维)统计数据中寻找潜在因子或成分的一种方法.ICA与其它的方法重要的区别在于,它寻找满足统计独立和非高斯的成分。这里我们简要介绍ICA的基本概念、应用和估计原理。1.1多元数据的线性表示统计数据处理及相关领域中的一个重要和需要长期研究的问题就是,寻

    2022年5月17日
    60

发表回复

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

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