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(转载请说明出处)

 

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • UPX 加壳工具:The Ultimate Packer for eXecutables

    UPX 加壳工具:The Ultimate Packer for eXecutables

  • map怎么转json对象_json怎么获取map

    map怎么转json对象_json怎么获取map如何把JSON对象转为map对象呢?JSON对象保存在大括号内。就像在JavaScript中,对象可以保存多个键/值对。Map对象保存键/值对,是键/值对的集合。任何值(对象或者原始值)都可以作为一个键或一个值。Object结构提供了“字符串—值”的对应,Map结构提供了“值—值”的对应。javascript将JSON对象转为map对象可以利用阿里巴巴封装的FastJSON来转换。有多种…

  • kubernetes ingress更改日志格式

    kubernetes ingress更改日志格式 IngressNginx默认访问日志都输出到/var/log/nginx/access.log文件中,但是对于一般的生产环境来说,不可能把所有日志都输到一个日志文件中,一般情况都是根据域名分别输出到各个文件中。所以这里区分http指令域默认配置以及单独域名的日志的配置方式。1.默认日志格式更改为json  修改mandatory.yaml部署文件nginx-configurationConfigMap配置中log-format-upstream字段,具体修改如下:log-form

  • 全局钩子注入

    全局钩子注入全局钩子介绍hook,指利用api来提前拦截并处理windows消息的一种技术。如键盘钩子,许多木马都有这东西,监视你的键盘操作。全局钩子是系统钩子的一种,当指定的一些消息被系统中任

    2021年12月13日
  • Spark存储体系底层架构剖析-Spark商业环境实战

    Spark存储体系底层架构剖析-Spark商业环境实战

  • Cydia中文源_最新cydia源地址大全

    Cydia中文源_最新cydia源地址大全Cydia中文源大全cydia.hackulo.us大名鼎鼎的Hackulo源,资源不多,但都几乎是必须的,我的appsync,Installous等一般就在这里面进行安装如果你要装googlemap补丁,就要加/julio-skype/macanavari//omkff//iPhone-I//suik/无语资源仓iphone.**.com/cydia/电玩扒屎的Cydia源,资源丰…

发表回复

您的电子邮箱地址不会被公开。

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