利用小米数据库查找手机归属地

本文介绍了如何将assets中的address.db文件拷贝到Android应用的指定目录,并利用SQLite数据库进行手机归属地的查询操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

知识点:

1 数据库文件拷贝

2 使用SQLlite完成手机归属地查找


1 数据库文件拷贝

/**
	 * 将数据库拷贝到getFilesDir()中
	 * 
	 * @param dbName
	 */
	public void copyDB(String dbName) {
		InputStream in = null;
		FileOutputStream out = null;
		File file = new File(getFilesDir(), dbName);

		if (file.exists()) { //如果数据已经存在,不进行更新数据库
			return;
		}
		try {
			in = getAssets().open(dbName);
			out = new FileOutputStream(file);

			int len = 0;
			byte[] buffer = new byte[1024];
			while ((len = in.read(buffer)) != -1) {
				out.write(buffer, 0, len);
			}

		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} finally {
			try {
				in.close();
				out.close();
			} catch (Exception e) {
				e.printStackTrace();
			}
		}
	}

address.db放在assets中:


经过拷贝后,address.db放入在getFilesDir()+dbName(文件名address.db)中。


2 使用SQLlite完成手机归属地查找

package com.example.mobliesoft.Activity.DB;

import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

public class AddressDao {

	public static final String PATH = "data/data/com.example.mobliesoft/files/address.db";

	public String getAddress(String phonenum) {

		String address = "未知号码";

		//打开数据库
		SQLiteDatabase database = SQLiteDatabase.openDatabase(PATH, null, SQLiteDatabase.OPEN_READONLY);

		if (phonenum.matches("^1[3-8]\\d{9}$")) {
			//数据库中查找数据
			Cursor cursor = database.rawQuery(
					"select location from data2 where id=(select outkey from data1 where id=?)",
					new String[] { phonenum.substring(0, 7) });
			if (cursor.moveToNext()) {
				address = cursor.getString(0);
			}
			else
			{
				address="未知号码";
			}
			cursor.close();
		} else {
			address="请输入正确号码";
		}
		database.close();
		return address;
	}

}

卧槽,先这样吧,这块儿真心不给力啊~

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值