Android應(yīng)用開(kāi)發(fā)之將SQLite和APK一起打包的方法
在 Eclipse 里新建好工程后,默認(rèn)會(huì)有一個(gè)assets目錄,在 Eclipse 中直接將準(zhǔn)備好的 SQLite 數(shù)據(jù)庫(kù)復(fù)制到該目錄中,然后在主 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 是程序的包名,請(qǐng)根據(jù)自己的程序調(diào)整 // /data/data/com.test.db/ // databases 目錄是準(zhǔn)備放 SQLite 數(shù)據(jù)庫(kù)的地方,也是 Android 程序默認(rèn)的數(shù)據(jù)庫(kù)存儲(chǔ)目錄 // 數(shù)據(jù)庫(kù)名為 test.db String DB_PATH = "/data/data/com.test.db/databases/"; String DB_NAME = "test.db"; // 檢查 SQLite 數(shù)據(jù)庫(kù)文件是否存在 if ((new File(DB_PATH + DB_NAME)).exists() == false) { // 如 SQLite 數(shù)據(jù)庫(kù)文件不存在,再檢查一下 database 目錄是否存在 File f = new File(DB_PATH); // 如 database 目錄不存在,新建該目錄 if (!f.exists()) { f.mkdir(); } try { // 得到 assets 目錄下我們實(shí)現(xiàn)準(zhǔn)備好的 SQLite 數(shù)據(jù)庫(kù)作為輸入流 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); } // 關(guān)閉文件流 os.flush(); os.close(); is.close(); } catch (Exception e) { e.printStackTrace(); } } // 下面測(cè)試 /data/data/com.test.db/databases/ 下的數(shù)據(jù)庫(kù)是否能正常工作 SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null); Cursor cursor = database.rawQuery("select * from test", null); if (cursor.getCount() > 0) { cursor.moveToFirst(); try { // 解決中文亂碼問(wèn)題 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(); } }
程序啟動(dòng)時(shí)候回去檢查數(shù)據(jù)庫(kù)文件在不在,如果不存在,就會(huì)把我們準(zhǔn)備好的數(shù)據(jù)庫(kù)復(fù)制到哪個(gè) databases 目錄下,而且如果用戶卸載了這個(gè)程序,那么這個(gè)目錄和數(shù)據(jù)庫(kù)也將隨之卸載。
再來(lái)一個(gè)示例。
正常的應(yīng)用數(shù)據(jù)庫(kù)放在/data/data/包名/database/test.db,應(yīng)用發(fā)布時(shí),這個(gè)數(shù)據(jù)庫(kù)不會(huì)隨著應(yīng)用一起發(fā)布,
所以為了讓我們已經(jīng)準(zhǔn)備好的數(shù)據(jù)正常使用,必須能實(shí)現(xiàn)數(shù)據(jù)庫(kù)自身復(fù)制到sd卡下面,
實(shí)現(xiàn)拷貝res/raw/test.db下資源拷貝到SD卡下的/mnt/sdcard/test/test.db
代碼如下:
package zcping.syan.DBDefinition; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import zcping.syan.DragonBaby.R; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.util.Log; public class ReleaseDataBaseActivity{ /** Called when the activity is first created. */ //SD卡下的目錄 private final String DATABASE_PATH = android.os.Environment .getExternalStorageDirectory().getAbsolutePath() + "/db_exam"; //數(shù)據(jù)庫(kù)名 private final String DATABASE_FILENAME = "db_exam.db"; //這個(gè)context是必需的,沒(méi)有context,怎么都不能實(shí)現(xiàn)數(shù)據(jù)庫(kù)的拷貝操作; private Context context; //構(gòu)造函數(shù)必需傳入Context,數(shù)據(jù)庫(kù)的操作都帶有這個(gè)參數(shù)的傳入 public ReleaseDataBaseActivity(Context ctx) { this.context = ctx; } public SQLiteDatabase OpenDataBase() { try { String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME; File dir = new File(DATABASE_PATH); //判斷SD卡下是否存在存放數(shù)據(jù)庫(kù)的目錄,如果不存在,新建目錄 if (!dir.exists()) { dir.mkdir(); Log.i("ReleaseDataBaseActivity", "dir made:" + DATABASE_PATH); } else { Log.i("ReleaseDataBaseActivity", "dir exist:" + DATABASE_PATH); } try { //如果數(shù)據(jù)庫(kù)已經(jīng)在SD卡的目錄下存在,那么不需要重新創(chuàng)建,否則創(chuàng)建文件,并拷貝/res/raw下面的數(shù)據(jù)庫(kù)文件 if (!(new File(databaseFilename)).exists()) { Log.i("ReleaseDataBaseActivity", "file not exist:" + databaseFilename); ///res/raw數(shù)據(jù)庫(kù)作為輸出流 InputStream is = this.context.getResources().openRawResource( R.raw.db_exam); //測(cè)試用 int size = is.available(); Log.i( "ReleaseDataBaseActivity", "DATABASE_SIZE:" + 1 ); Log.i("ReleaseDataBaseActivity", "count:" + 0); //用于存放數(shù)據(jù)庫(kù)信息的數(shù)據(jù)流 FileOutputStream fos = new FileOutputStream( databaseFilename); byte[] buffer = new byte[8192]; int count = 0; Log.i("ReleaseDataBaseActivity", "count:" + count); //把數(shù)據(jù)寫入SD卡目錄下 while ((count = is.read(buffer)) > 0) { fos.write(buffer, 0, count); } fos.flush(); fos.close(); is.close(); } } catch (FileNotFoundException e) { Log.e("Database", "File not found"); e.printStackTrace(); } catch (IOException e) { Log.e("Database", "IO exception"); e.printStackTrace(); } //實(shí)例化sd卡上得數(shù)據(jù)庫(kù),database作為返回值,是后面所有插入,刪除,查詢操作的借口。 SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase( databaseFilename, null); return database; } catch (Exception e) { } return null; } }
經(jīng)過(guò)測(cè)試,絕對(duì)好使,希望對(duì)大家有幫助。
- Android APK使用Debug簽名重新打包 Eclipse更改默認(rèn)Debug簽名
- Android開(kāi)發(fā)apk反編譯和二次打包教程
- Android獲取apk簽名指紋的md5值(防止重新被打包)的實(shí)現(xiàn)方法
- Android 數(shù)據(jù)庫(kù)打包隨APK發(fā)布的實(shí)例代碼
- Android應(yīng)用程序(APK)的編譯打包過(guò)程
- Android Studio打包.so庫(kù)到apk中實(shí)例詳解
- android WebView加載html5介紹
- android中webview控件和javascript交互實(shí)例
- 解析Android中webview和js之間的交互
- Android使用WebView播放flash的方法
- Android編程實(shí)現(xiàn)webview將網(wǎng)頁(yè)打包成apk的方法
相關(guān)文章
Spring IOC創(chuàng)建對(duì)象的兩種方式
這篇文章主要給大家介紹了關(guān)于Spring IOC創(chuàng)建對(duì)象的兩種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03Java中二叉樹(shù)的先序、中序、后序遍歷以及代碼實(shí)現(xiàn)
這篇文章主要介紹了Java中二叉樹(shù)的先序、中序、后序遍歷以及代碼實(shí)現(xiàn),一棵二叉樹(shù)是結(jié)點(diǎn)的一個(gè)有限集合,該集合或者為空,或者是由一個(gè)根節(jié)點(diǎn)加上兩棵別稱為左子樹(shù)和右子樹(shù)的二叉樹(shù)組成,需要的朋友可以參考下2023-11-11SSH框架網(wǎng)上商城項(xiàng)目第1戰(zhàn)之整合Struts2、Hibernate4.3和Spring4.2
SSH框架網(wǎng)上商城項(xiàng)目第1戰(zhàn)之整合Struts2、Hibernate4.3和Spring4.2,感興趣的小伙伴們可以參考一下2016-05-05Java基于虹軟實(shí)現(xiàn)人臉識(shí)別、人臉比對(duì)、活性檢測(cè)等
本文主要介紹了Java基于虹軟實(shí)現(xiàn)人臉識(shí)別、人臉比對(duì)、活性檢測(cè)等,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02Struts2源碼分析之ParametersInterceptor攔截器
這篇文章主要介紹了Struts2源碼分析之ParametersInterceptor攔截器,ParametersInterceptor攔截器其主要功能是把ActionContext中的請(qǐng)求參數(shù)設(shè)置到ValueStack中,,需要的朋友可以參考下2019-06-06