加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

sqlite和apk一起打包分析

发布时间:2020-12-12 20:32:31 所属栏目:百科 来源:网络整理
导读:在 Eclipse 里新建好工程后,默认会有一个 assets 目录,在 Eclipse 中直接将准备好的 SQLite 数据库复制到该目录中,然后在主 Activity 里面编码: package com . test . db ; import java . io . File ; import java . io . FileOutputStream ; import jav

在 Eclipse 里新建好工程后,默认会有一个 assets 目录,在 Eclipse 中直接将准备好的 SQLite 数据库复制到该目录中,然后在主 Activity 里面编码:

package com.test.db;

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;

import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;

public class DbtestActivity extends Activity {
	/** Called when the activity is first created. */
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);

		// com.test.db 是程序的包名,请根据自己的程序调整
		// /data/data/com.test.db/
		// databases 目录是准备放 SQLite 数据库的地方,也是 Android 程序默认的数据库存储目录
		// 数据库名为 test.db
		String DB_PATH = "/data/data/com.test.db/databases/";
		String DB_NAME = "test.db";

		// 检查 SQLite 数据库文件是否存在
		if ((new File(DB_PATH + DB_NAME)).exists() == false) {
			// 如 SQLite 数据库文件不存在,再检查一下 database 目录是否存在
			File f = new File(DB_PATH);
			// 如 database 目录不存在,新建该目录
			if (!f.exists()) {
				f.mkdir();
			}

			try {
				// 得到 assets 目录下我们实现准备好的 SQLite 数据库作为输入流
				InputStream is = getBaseContext().getAssets().open(DB_NAME);
				// 输出流
				OutputStream os = new FileOutputStream(DB_PATH + DB_NAME);

				// 文件写入
				byte[] buffer = new byte[1024];
				int length;
				while ((length = is.read(buffer)) > 0) {
					os.write(buffer, 0, length);
				}

				// 关闭文件流
				os.flush();
				os.close();
				is.close();
			} catch (Exception e) {
				e.printStackTrace();
			}
		}

		// 下面测试 /data/data/com.test.db/databases/ 下的数据库是否能正常工作
		SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null);
		Cursor cursor = database.rawQuery("select * from test", null);

		if (cursor.getCount() > 0) {
			cursor.moveToFirst();
			try {
				// 解决中文乱码问题
				byte test[] = cursor.getBlob(0);
				String strtest = new String(test, "utf-8").trim();

				// 看输出的信息是否正确
				System.out.println(strtest);
			} catch (UnsupportedEncodingException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		cursor.close();
	}
}

程序启动时候回去检查数据库文件在不在,如果不存在,就会把我们准备好的数据库复制到哪个 databases 目录下,而且如果用户卸载了这个程序,那么这个目录和数据库也将随之卸载。

该程序可以提供中国大陆及香港、澳门、台湾各城市实时天气,所有数据来源于中国国家气象局,准确率相当高。

程序代码比较乱,没来得及整理,如果你对此有兴趣,可参见项目地址 https://github.com/libuchao/KWeather

参考文章:
Using your own SQLite database in Android applications

Embed a database in the .apk of a distributed application [Android]

解决这个问题后,花了几天找了一下天气预报的实现方式,其实最主要的是寻找数据源,靠谱的数据源很少很少。

最终决定用 weather.com.cn 这个比较权威的数据源,其提供的数据格式是 JSON,并参考了 通过 weather.com.cn 获取全国天气数据 这篇文章,最终简单实现了天气预报功能

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读