Android开发之监听发出的短信
执行效果图:
预备知识:
为了监听指定的ContentProvider的数据的改变,须要通过ContentResolver向指定Uri注冊CotentObserver监听器。ContentResolver提供了例如以下方法来注冊监听器:
publicfinal void registerContentObserver(Uriuri, boolean notifyForDescendents, ContentObserver observer)
參数:uri :该监听器所监听的ContentProvider的Uri。
notifyForDescendents :为false 表示精确匹配。即仅仅匹配该Uri,为true 表示能够同一时候匹配其派生的Uri。
observer:ContentObserver派生的监听器实例。
取消注冊监听器:
public finalvoid unregisterContentObserver(ContentObserver observer)
功能:取消对给定Uri的观察
參数: observer ContentObserver的派生类实例。
ContentObserver——内容观察者,目的是观察(捕捉)特定Uri引起的数据库的变化,继而做一些对应的处理,它类似于数据库技术中的触发器(Trigger)。当ContentObserver所观察的Uri发生变化时,便会触发它。触发器分为表触发器、行触发器。对应地ContentObserver也分为“表“ContentObserver、“行”ContentObserver,当然这是与它所监听的Uri MIME Type有
关的。
ContentObserver类介绍:
接收回调的更改内容。
必须由被加入到一个ContentObservable对象实现。
构造方法:
|
Public Constructors |
|
|
ContentObserver(Handler handler) onChange() will happen on the provider Handler. |
|
说明:全部 ContentObserver的派生类都须要调用该构造方法
參数:handler Handler对象。能够是主线程Handler(这时候能够更新UI 了),也能够是不论什么Handler对象。
经常用法:
|
Public Methods |
|
|
boolean |
deliverSelfNotifications() Returns true if this observer is interested in notifications for changes made through the cursor the observer is registered with. |
|
final void |
dispatchChange(boolean selfChange) |
|
void |
onChange(boolean selfChange) This method is called when a change occurs to the cursor that is being observed. |
说明:
void onChange(booleanselfChange)
功能:当观察到的Uri发生变化时,回调该方法去处理。全部ContentObserver的派生类都须要重载该方法去处理逻辑。
參数:selfChange 回调后。其值一般为false,该參数意义不大(我也不懂。理解方法最重要)。
观察特定Uri的过程例如以下:
1、 创建我们特定的ContentObserver派生类。必须重载父类构造方法。必须重载onChange()方法去处理回调后的功能实现
2、 利用context.getContentResolover()获得ContentResolove对象。接着调用registerContentObserver()方法去注冊内容观察者
如://为content://sms的数据改变注冊监听器getContentResolver().registerContentObserver(Uri.parse
("content://sms"), true,
new SmsObserver(new Handler()));
3、 因为ContentObserver的生命周期不同步于Activity和Service等。因此,在不须要时,须要手动的调用unregisterContentObserver()去取消注冊。
短信相关权限:
<!-- 发送消息-->
<uses-permission android:name="android.permission.SEND_SMS"/>
<!-- 阅读消息-->
<uses-permission android:name="android.permission.READ_SMS"/>
<!-- 写入消息-->
<uses-permission android:name="android.permission.WRITE_SMS" />
<!-- 接收消息 -->
<uses-permission android:name="android.permission.RECEIVE_SMS"/>
相关的协议:
content://sms/inbox 收件箱
content://sms/sent 已发送
content://sms/draft 草稿
content://sms/outbox 发件箱
content://sms/failed 发送失败
content://sms/queued 待发送列表
数据库中sms相关的字段及说明:
|
字段 |
说明 |
|
_id |
短信序号,如100 |
|
thread_id |
对话的序号,如100,与同一个手机号互发的短信。其序号是同样的 |
|
address |
发件人地址,即手机号。如+86138138000 |
|
person |
发件人,假设发件人在通讯录中则为详细姓名。陌生人为null |
|
date |
日期。long型,如1346988516。能够对日期显示格式进行设置 |
|
protocol |
协议0SMS_RPOTO短信,1MMS_PROTO彩信 |
|
read |
是否阅读0未读,1已读 |
|
status |
短信状态-1接收,0complete,64pending,128failed |
|
type |
短信类型1是接收到的,2是已发出 |
|
body |
短信详细内容 |
|
service_center |
短信服务中心号码编号。如+8613800755500 |
应用实例:
package com.jph.monitorsms;
import java.text.SimpleDateFormat;
import java.util.Date;
import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;
import android.widget.TextView;
import android.widget.Toast;
import android.app.Activity;
import android.database.ContentObserver;
import android.database.Cursor;
/**
* Describe:</br>
* 获取用户正在发送的短信
* 本实例通过为content://sms的数据改变注冊监听器来
* 获取手机正在发送的消息。 * @author JPH
* Date:2014.07.20
* */
public class MonitorSms extends Activity {
TextView txtView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
txtView=(TextView)findViewById(R.id.txtView);
//为content://sms的数据改变注冊监听器
getContentResolver().registerContentObserver(Uri.parse
("content://sms"), true, new SmsObserver(new Handler()));
}
//一个继承自ContentObserver的监听器类
class SmsObserver extends ContentObserver{ public SmsObserver(Handler handler) {
super(handler);
// TODO Auto-generated constructor stub
}
@Override
public void onChange(boolean selfChange) {
// TODO Auto-generated method stub
//查询发送向箱中的短信
Cursor cursor=getContentResolver().query(Uri.parse(
"content://sms/outbox"), null, null, null, null);
//遍历查询结果获取用户正在发送的短信
while (cursor.moveToNext()) {
StringBuffer sb=new StringBuffer();
//获取短信的发送地址
sb.append("发送地址:"+cursor.getString(cursor.getColumnIndex("address")));
//获取短信的标题
sb.append("\n标题:"+cursor.getString(cursor.getColumnIndex("subject")));
//获取短信的内容
sb.append("\n内容:"+cursor.getString(cursor.getColumnIndex("body")));
//获取短信的发送时间
Date date=new Date(cursor.getLong(cursor.getColumnIndex("date")));
//格式化以秒为单位的日期
SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日 hh时mm分ss秒");
sb.append("\n时间:"+sdf.format(date));
System.out.println("查询到的正在发送的短信:"+sb.toString());
Toast.makeText(MonitorSms.this, sb.toString(), Toast.LENGTH_LONG).show();
txtView.setText(sb.toString());
}
super.onChange(selfChange);
} } }
Android开发之监听发出的短信的更多相关文章
- Android开发-之监听button点击事件
一.实现button点击事件的方法 实现button点击事件的监听方法有很多种,这里总结了常用的四种方法: 1.匿名内部类 2.外部类(独立类) 3.实现OnClickListener接口 4.添加X ...
- Android开发14——监听内容提供者ContentProvider的数据变化
一.提出需求 有A,B,C三个应用,B中的数据需要被共享,所以B中定义了内容提供者ContentProvider:A应用修改了B应用的数据,插入了一条数据.有这样一个需求,此时C应用需要得到数据被修改 ...
- android开发事件监听
第一种:匿名内部类作为事件监听器类 大部分时候,事件处理器都没有什么利用价值(可利用代码通常都被抽象成了业务逻辑方法),因此大部分事件监听器只是临时使用一次,所以使用匿名内部类形式的事件监听器更合适, ...
- delphi xe5 android 开发实现手机打电话和发短信
转载自 http://www.raysoftware.cn/ 其实都可以通过intent和URI调用系统功能.Windows程序员可以理解成是ShellExecute.这个是万金油.可以有调用各种功 ...
- XE5 Android 开发实现手机打电话和发短信 [转]
其实都可以通过intent和URI调用系统功能.Windows程序员可以理解成是ShellExecute.这个是万金油.可以有调用各种功能.后面会介绍. 1.短信息.很简单 方法a.不使用Intent ...
- android开发学习:打电话和发短信
1.新建一个android项目 File--New--Other--android application project 填写application name(就是应用的名字.比方:天天酷跑) 填写 ...
- adnroid 监听收到的短信并根据短信内容进行回复短信
定义一个广播接收器 public class SMSReceiver extends BroadcastReceiver { private SmsManager smsManager; @Overr ...
- 【Android开发】监听图库数据库的变化
步骤一: 保存图片或者删除之前,初始化ContentObserver ScreenshotContentObserver mScreenObserver = new ScreenshotContent ...
- android 开发,视频群聊引发短信异常
说到 NDK 开发,其实是为了有些时候为了项目需求需要调用底层的一些 C/C++ 的一些东西:另外就是为了效率更加高些. 但是很多时候能不用就不用:这个是啥原因?个人感觉有些时候是觉得麻烦,首先要配置 ...
随机推荐
- mac android apk反编译
在mac os系统上反编译android apk,首先需要准备好以下3个文件: 1.apktool:https://ibotpeaches.github.io/Apktool/install/ 2.d ...
- JAVAscript学习笔记 js条件语句 第三节 (原创) 参考js使用表 (2017-09-14 15:55)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- NHibernate Criteria中 Restriction与Expression的差别
http://stackoverflow.com/questions/5483393/nhibernate-criteria-restriction-vs-expression 据说是Restrict ...
- Js的闭包,这篇写的是比较清晰明了的
一.变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域. 变量的作用域无非就是两种:全局变量和局部变量. Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量 ...
- 全球领先的redis客户端:SFedis
零.背景 这个客户端起源于我们一个系统的生产问题. 一.问题的发生 在我们的生产环境上发生了两次redis服务端连接数达到上限(我们配置的单节点连接数上限为8000)导致无法创建连接的情况.由于这个系 ...
- 前端html 中jQuery实现对文本的搜索并把搜索相关内容显示出来
做项目的时候有这么一个需求,客户信息显示出来后我要搜索查找相关的客户,并把相关的客户信息全部显示出来,因为一个客户全部信息我写在一个div里面 所以显示的时候就是显示整个div.先看看实现的效果: ...
- SQL命令语句小技巧
1.[ ]的使用 当我们所要查的表是系统关键字或者表名中含有空格时,需要用[]括起来,例如新建了两个表,分别为user,user info,那么select * from user和select * ...
- C#提取字符串中的数字字符串
1 }
- RabbitMQ的简单应用
虽然后台使用了读写分离技术,能够在一定程度上抗击高并发,但是如果并发量特别巨大时,主数据库不能同时处理高并发的请求,这时数据库容易宕机. 问题: 现在的问题是如何既能保证数据库正常运行,又能实现用户数 ...
- Linux系列教程(二十)——Linux的shell概述以及如何执行脚本
从这篇博客开始,我们将进入Linux的shell脚本的学习,这对于Linux学习爱好者而言是特别重要的一节,也是特别有意思的一节,shell 脚本就像我们知道的Java,php类似的编程语言一样,通过 ...
