32号码归属地代码的实现

在SplashActivity中拷贝数据库到data/data/包名/files/address.db,并且第一次拷贝完成之后,后面启动应用不需要再次拷贝。

/**
	 * 拷贝号码归属地数据库
	 * 把数据库拷贝到data/data/包名/files/address.db
	 */
	private void copyDB() {
		//第一次拷贝之后  后面启动不再需要拷贝
		try {
			
			File file = new File(getFilesDir(),"address.db");
			
			if (file.exists() && file.length()>0) {
				//不需要拷贝了
				Log.i(TAG, "不需要拷贝了");
			}else {
				InputStream is  = getAssets().open("address.db");
				
				FileOutputStream fos = new FileOutputStream(file);
				
				byte[] buffer = new byte[1024];
				
				int len = 0;
				
				while ((len = is.read(buffer)) != -1) {
					fos.write(buffer, 0, len);
				}
				is.close();
				fos.close();
			}
			
			
		} catch (IOException e) {
			e.printStackTrace();
		}
		
	}



注意API:getFileDir的用法。以及复制asset目录下的文件的方法。

然后使用去查询:

package com.ustc.mobilemanager.db.dao;

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

public class NumberAddressQueryUtils {

	private static String path = "data/data/com.ustc.mobilemanager/files/address.db";

	/**
	 * 
	 * 传一个号码进来,查询号码的归属地
	 * 
	 * @param number
	 * @return
	 */
	public static String queryNumber(String number) {
		String address = number;

		// path 把数据库拷贝到data/data/包名/files/address.db
		SQLiteDatabase database = SQLiteDatabase.openDatabase(path, null,
				SQLiteDatabase.OPEN_READONLY);

		Cursor cursor = database.rawQuery(
				"select location from data2 where id = (select outkey from data1 where id = ?)",
				new String[] { number.substring(0, 7) });
		while (cursor.moveToNext()) {
			String location = cursor.getString(0);
			address  = location;
		}
		cursor.close();
		return address;
	}

}

最后是调用:

/**
	 * 
	 * 查询号码归属地的按钮的点击事件
	 * 
	 * 
	 * @param view
	 */
	public void query(View view){
		String phoneNumber = ed_phone.getText().toString().trim();
		if (TextUtils.isEmpty(phoneNumber)) {
			//
			Toast.makeText(this, "号码为空!", Toast.LENGTH_LONG).show();
			return;
		}else {
			//数据库查询号码归属地
			
			//写一个工具类,去查询数据库
			String address  = NumberAddressQueryUtils.queryNumber(phoneNumber);
			Log.i(TAG, "查询的号码为:" + phoneNumber);
			address_result.setText(address);
		}
		
	}
	
	

查询的结果:




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值