Android中手机号码归属地查询实现
来源: 阅读:1137 次 日期:2015-02-10 10:25:39
温馨提示: 小编为您整理了“Android中手机号码归属地查询实现”,方便广大网友查阅!

这部分是昨天学习的,但是因为眼睛超负荷所以拖到现在,以后要合理规划时间。

目前手机里面的号码归属地查询主要是通过两种方式:1.联网查询,2.匹配本机归属地数据库。

我认为两种结合方式最好,在本地数据库中匹配不到的在进行联网查询,能大大增加匹配效果,并且不用过于增加本地数据库容量而增大安装包大小。

步骤:1.开启软件的时候把数据库从assets目录拷贝到files目录下,如果已存在,则不用重新拷贝。

2.实现界面。

3.实现工具类PhoneAddressUtils的getPhoneAddress()方法

4.在界面类activity里调用工具类方法得到地址兵显示出来。

首先是复制数据库的操作:

private void copyDB() {

File file = new File(getFilesDir(), "address.db");

if(file.exists()&&file.length()>0) {

Toast.makeText(this, "已经复制数据库", 0).show();

} else {

try {

AssetManager am = getAssets();

byte[] buffer = new byte[1024];

InputStream is = am.open("address.db");

FileOutputStream fis = new FileOutputStream(file);

int len = 0;

while((len=is.read(buffer))>0) {

fis.write(buffer, 0, len);

}

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

因为运行中工具类得不到assets目录下的文件,所以要在在开机启动的SplashActivity中把数据库拷贝到files目录下。

获得assert目录下的文件要用AssetManager对象的open()方法,打开文件返回输入流。

实现界面:就一个简单的输入框,按钮,显示框就行。

工具类:

package com.itheima.mobilesafe.db.dao;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

public class AddressDao {

private static String path = "data/data/com.itheima.mobilesafe/files/address.db";

public static String getAddress(String number) {

String address = number;

if(number.matches("^1[34568]\d{9}$")) {

String sql = "select location from data2 where id = (select outkey from data1 where id= ?)";

SQLiteDatabase database = SQLiteDatabase.openDatabase(path, null, SQLiteDatabase.OPEN_READONLY);

Cursor cursor = database.rawQuery(sql, new String[] {number.substring(0, 7)});

while(cursor.moveToNext()) {

address = cursor.getString(0);

}

cursor.close();

database.close();

} else {

address = "不是手机号码";

}

return address;

}

}

调用显示:

点击按钮时:

public void queryAddress(View view) {

String number = et_phone.getText().toString();

String address = AddressDao.getAddress(number);

et_address.setText(address);

}

但是我们要动态的显示位置,所以要对输入框加一个TextChangedListener,当输入字符串大于3的时候,自动调用进行匹配显示出来。

et_phone.addTextChangedListener(new TextWatcher() {

@Override

public void onTextChanged(CharSequence s, int start, int before, int count) {

// TODO Auto-generated method stub

if(s.length()>3) {

String address = AddressDao.getAddress(s.toString());

et_address.setText(address);

}

}

@Override

public void beforeTextChanged(CharSequence s, int start, int count,

int after) {

// TODO Auto-generated method stub

}

@Override

public void afterTextChanged(Editable s) {

// TODO Auto-generated method stub

}

});

更多信息请查看IT技术专栏

更多信息请查看数据库
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map