Android 监听短信(同时监听广播和数据库)
暗扣,强烈谴责这种侵害用户利益的行为。。。
下面给大家介绍Android暗扣原理....... Android4.4以下的系统玩游戏就要小心了哈
暗扣方式之一:短信订购,即监听--------拦截------------处理短信。
暗扣方式之二:模拟人为操作(又叫模拟流量),通过后台程序代码模拟人的点击行为,暗自给用户订购业务,由运营商收取你的费用,当然这其中也需要涉及监听/拦截/处理短信。使用这种方式的原理无非是Http处理网页,还涉及接入点切换问题,这里就不详细讲解。
回归正题:有的时候,我们的手机程序需要监听手机短信,当满足条件A时,不处理;当满足条件B时,将其设置为已读;当满足条件C时,将短信删除。
注:Android 4.4以及以后可能由用户来控制程序的权限,如果用户关闭这个程序的权限,意味着你无法监听短信/操作短信内容
目前也有如小米系统在安装时,让用户来控制权限;360来监听优先拦截短信等等(关于谁先安装谁有优先权,动态注册比静态注册优先级别高等问题,在这些情况这里就不讲了)。。。
Android 实现监听短信(同时监听广播和数据库)代码如下:
- 拦截广播
package com.javen.sms.receiver; import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.TimeZone; import com.javen.util.InterceptKeyKeeper; import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.SmsMessage;
import android.util.Log;
import android.widget.Toast; public class SmsReceiver extends BroadcastReceiver {
private Context mContext;
public static final String SMS_RECEIVED_ACTION = "android.provider.Telephony.SMS_RECEIVED";
public static final String SMS_DELIVER_ACTION = "android.provider.Telephony.SMS_DELIVER"; @Override
public void onReceive(Context context, Intent intent) {
this.mContext=context;
Toast.makeText(context, "接收短信执行了.....", Toast.LENGTH_LONG).show();
Log.e("SMSReceiver, isOrderedBroadcast()=", isOrderedBroadcast()+"");
Log.e("SmsReceiver onReceive...", "接收短信执行了......");
String action = intent.getAction();
if (SMS_RECEIVED_ACTION.equals(action) || SMS_DELIVER_ACTION.equals(action)) {
Toast.makeText(context, "开始接收短信.....", Toast.LENGTH_LONG).show();
Log.e("SmsReceiver onReceive...", "开始接收短信....."); Bundle bundle = intent.getExtras();
if (bundle != null) {
Object[] pdus = (Object[])bundle.get("pdus");
if (pdus != null && pdus.length > 0) {
SmsMessage[] messages = new SmsMessage[pdus.length];
for (int i = 0; i < pdus.length; i++) {
byte[] pdu = (byte[]) pdus[i];
messages[i] = SmsMessage.createFromPdu(pdu);
}
for (SmsMessage message : messages) {
String content = message.getMessageBody();// 得到短信内容
String sender = message.getOriginatingAddress();// 得到发信息的号码
if (content.contains(InterceptKeyKeeper.getInterceptKey(mContext))) {
Toast.makeText(mContext, "内容为:"+content, Toast.LENGTH_LONG).show();
//setResultData(null);
this.abortBroadcast();// 中止
}else if (sender.equals("10010") || sender.equals("10086")) {
Toast.makeText(mContext, "内容为:"+content, Toast.LENGTH_LONG).show();
this.abortBroadcast();// 中止
}
Date date = new Date(message.getTimestampMillis());
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
format.setTimeZone(TimeZone.getTimeZone("GMT+08:00"));
String sendContent = format.format(date) + ":" + sender + "--" + content;
Log.e("SmsReceicer onReceive ",sendContent +" ");
}
}
}
}
}
} - 开启一个服务开监听数据库
package com.javen.service; import android.app.Service;
import android.content.ContentResolver;
import android.content.Intent;
import android.net.Uri;
import android.os.IBinder;
import android.os.Process;
import android.widget.Toast; /**
* @author Javen
* 开启一个服务开监听数据库
*/
public class SmsService extends Service { private SmsObserver mObserver; @Override
public IBinder onBind(Intent intent) {
return null;
} @Override
public void onCreate() {
Toast.makeText(this, "SmsService 服务器启动了....", Toast.LENGTH_LONG).show();
// 在这里启动
ContentResolver resolver = getContentResolver();
mObserver = new SmsObserver(resolver, new SmsHandler(this));
resolver.registerContentObserver(Uri.parse("content://sms"), true,mObserver);
} @Override
public void onDestroy() {
super.onDestroy();
this.getContentResolver().unregisterContentObserver(mObserver);
Process.killProcess(Process.myPid());
}
} - 数据库观察者
package com.javen.service; import android.content.ContentResolver;
import android.database.ContentObserver;
import android.database.Cursor;
import android.net.Uri;
import android.os.Message;
import android.util.Log; /**
* @author Javen
* 数据库观察者
*/
public class SmsObserver extends ContentObserver { private ContentResolver mResolver;
public SmsHandler smsHandler; public SmsObserver(ContentResolver mResolver, SmsHandler handler) {
super(handler);
this.mResolver = mResolver;
this.smsHandler = handler;
} @Override
public void onChange(boolean selfChange) {
Log.i("SmsObserver onChange ", "SmsObserver 短信有改变");
Cursor mCursor = mResolver.query(Uri.parse("content://sms/inbox"),
new String[] { "_id", "address", "read", "body", "thread_id" },
"read=?", new String[] { "0" }, "date desc"); if (mCursor == null) {
return;
} else {
while (mCursor.moveToNext()) {
SmsInfo _smsInfo = new SmsInfo(); int _inIndex = mCursor.getColumnIndex("_id");
if (_inIndex != -1) {
_smsInfo._id = mCursor.getString(_inIndex);
} int thread_idIndex = mCursor.getColumnIndex("thread_id");
if (thread_idIndex != -1) {
_smsInfo.thread_id = mCursor.getString(thread_idIndex);
} int addressIndex = mCursor.getColumnIndex("address");
if (addressIndex != -1) {
_smsInfo.smsAddress = mCursor.getString(addressIndex);
} int bodyIndex = mCursor.getColumnIndex("body");
if (bodyIndex != -1) {
_smsInfo.smsBody = mCursor.getString(bodyIndex);
} int readIndex = mCursor.getColumnIndex("read");
if (readIndex != -1) {
_smsInfo.read = mCursor.getString(readIndex);
} // 根据你的拦截策略,判断是否不对短信进行操作;将短信设置为已读;将短信删除
// TODO
System.out.println("获取的短信内容为:"+_smsInfo.toString());
Log.i("SmsObserver ...", "获取的短信内容为:"+_smsInfo.toString());
Message msg = smsHandler.obtainMessage();
_smsInfo.action = 2;// 0不对短信进行操作;1将短信设置为已读;2将短信删除
msg.obj = _smsInfo;
smsHandler.sendMessage(msg);
}
} if (mCursor != null) {
mCursor.close();
mCursor = null;
}
}
} - 短信处理类
package com.javen.service; import android.content.ContentValues;
import android.content.Context;
import android.net.Uri;
import android.os.Handler;
import android.os.Message; /**
* @author Javen
*
* 短信的处理
*
*/
public class SmsHandler extends Handler {
private Context mcontext; public SmsHandler(Context context) {
this.mcontext = context;
} @Override
public void handleMessage(Message msg) {
SmsInfo smsInfo = (SmsInfo) msg.obj; if (smsInfo.action == 1) {
ContentValues values = new ContentValues();
values.put("read", "1");
mcontext.getContentResolver().update(
Uri.parse("content://sms/inbox"), values, "thread_id=?",
new String[] { smsInfo.thread_id });
} else if (smsInfo.action == 2) {
Uri mUri = Uri.parse("content://sms/");
mcontext.getContentResolver().delete(mUri, "_id=?",
new String[] { smsInfo._id });
}
}
} - SmsInfo 数据结构 主要用于短信拦截
package com.javen.service; /**
* 主要用于短信拦截
*
* @author Javen
*
*/
public class SmsInfo {
public String _id = "";
public String thread_id = "";
public String smsAddress = "";
public String smsBody = "";
public String read = "";
public int action = 0;// 1代表设置为已读,2表示删除短信
@Override
public String toString() {
return "SmsInfo [_id=" + _id + ", thread_id=" + thread_id
+ ", smsAddress=" + smsAddress + ", smsBody=" + smsBody
+ ", read=" + read + ", action=" + action + "]";
} } - 需要的权限以及配置信息
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.javen.sms"
android:versionCode="1"
android:versionName="1.0" > <uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="21" /> <uses-permission android:name="android.permission.SEND_SMS" />
<uses-permission android:name="android.permission.RECEIVE_SMS" /> <!-- <uses-permission android:name="android.permission.BROADCAST_SMS" />
<uses-permission android:name="android.permission.READ_SMS" />
<uses-permission android:name="android.permission.WRITE_SMS" /> -->
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
>
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity> <receiver
android:name="com.javen.sms.receiver.SmsReceiver"
android:exported="true"
android:permission="android.permission.BROADCAST_SMS">
<intent-filter android:priority="2147483647" >
<action android:name="android.provider.Telephony.SMS_RECEIVED" />
<action android:name="android.provider.Telephony.SMS_DELIVER" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</receiver> <service android:name="com.javen.service.SmsService"></service>
</application> </manifest> 测试在MainActivity 中启动SmsService 发送短信到10086 或者10010即可测试
intentService = new Intent(this, SmsService.class);
startService(intentService);
Toast.makeText(this, "启动service中.....", 1).show();以上就是Android 4.4以下暗扣原理。 Android 4.4以上如何实现大家可以在此博客中讨论交流。。。。。
Android 监听短信(同时监听广播和数据库)的更多相关文章
- Android手机上监听短信的两种方式
Android手机上监听短信有两种方式: 1. 接受系统的短信广播,操作短信内容. 优点:操作方便,适合简单的短信应用. 缺点:来信会在状态栏显示通知信息. AndroidManifest.xml: ...
- android 监听短信数据库,制作短信控制工具,控制别人的手机!!(一)
序言:本程序示例本着简洁易懂的目的,只做了简单的功能实现,需要用户启动应用,收到短信才有效果.作者将会在后面的(二)篇中加入服务后台运行.自动启动功能,实现一个真正的短信控制工具.本文的目的很简单,让 ...
- android菜鸟学习笔记23----ContentProvider(三)利用内置ContentProvider监听短信及查看联系人
要使用一个ContentProvider,必须要知道的是它所能匹配的Uri及其数据存储的表的结构. 首先想办法找到访问短信及联系人数据的ContentProvider能接受的Uri: 到github上 ...
- android 监听短信并发送到服务器
1. 接受系统的短信广播,操作短信内容. 优点:操作方便,适合简单的短信应用. 缺点:来信会在状态栏显示通知信息. 2. 应用观察者模式,监听短信数据库,操作短信内容. 实例如下: SystemE ...
- 通过broadcastreceiver 监听短信问题
在mainfest中 订阅 短信到来的广播时候 发现找不到 <action android:name="android.provider.Telephony.SMS_RECEIV ...
- 内容观察者 ContentObserver 监听短信、通话记录数据库 挂断来电
Activity public class MainActivity extends ListActivity { private TextView tv_info; private ...
- Android_通过ContentObserver监听短信数据变化
1.简单介绍 在小米等一些机型,无法接收系统发出的短信广播. 仅仅能通过观察者ContentObserver,去监听短信数据的变化 2.SMS数据介绍 content://sms/inbox ...
- 短信状态监听 - iOS
当使用 App 时若短信介入需要对当前状态进行监听操作,根据不同的状态实行相关的需求操作,废话不多说步骤如下. 首先,常规操作先引用对应的头文件,来为后续功能铺路. #import <Messa ...
- android自动填写短信验证码
广播类 package com.examp.azuoyoutong.listner; import java.util.regex.Matcher;import java.util.regex.Pat ...
随机推荐
- FFMPEG 库移植到 VC 需要的步骤
在VC下使用FFMPEG编译好的库,不仅仅是把.h,.lib,.dll拷贝到工程中就行了,还需要做以下几步.(此方法适用于自己使用MinGW编译的库,也同样适用于从网上下载的编译好的库,例如http: ...
- ActionBarSherlock的学习笔记(二) ------------ 创建ActionBarSherlock
将ActionBarSherlock 作为库项目添加到当前的项目中去,然后创建ActionBar,并自定义ActionBar的标题栏 例子如下: import android.os.Bundle; i ...
- Corn Fields(POJ 3254状压dp)
题意: n*m网格1能放0不能放 放的格子不能相邻 求一共多少种可放的方案. 分析: dp[i][j]第i行可行状态j的的最大方案数,枚举当前行和前一行的所有状态转移就行了(不放牛也算一种情况) #i ...
- SVM:从理论到OpenCV实践
(转载请注明出处:http://blog.csdn.net/zhazhiqiang/ 未经允许请勿用于商业用途) 一.理论 参考网友的博客: (1)[理论]支持向量机1: Maximum Marg ...
- RPC框架motan: 通信框架netty之Netty4Client
上文已经初步探讨了如何实现一个具体的transport,本文就来讨论一个具体的transport,本文讨论netty4的的相关实现.老规矩,看看motan-transport的目录结构. 其中最重要的 ...
- 二分+叉积判断方向 poj 2318 2398
// 题意:问你每个区域有多少个点 // 思路:数据小可以直接暴力 // 也可以二分区间 #include <cstdio> #include <cstring> #inclu ...
- C语言——递归练习
1.炮弹一样的球状物体,能够堆积成一个金字塔,在顶端有一个炮弹,它坐落在一个4个炮弹组成的层面上,而这4个炮弹又坐落在一个9个炮弹组成的层面上,以此类推.写一个递归函数CannonBall,这个函数把 ...
- JavaEE5 Tutorial_JavaBean,JSTL
<jsp:useBean id="beanName" class="fully_qualified_classname" scope="scop ...
- 《Genesis-3D开源游戏引擎完整实例教程-2D射击游戏篇04:碰撞检测》
4.碰撞检测 碰撞概述: 游戏世界里,游戏对象不能做出如同在真实世界里的物理运动效果.对于大部分游戏来说,都要为其添加物理系统,让其可以模拟真实世界发生的物理运动.但是在这个打飞机游戏Demo中,是用 ...
- Can’t find file mysql/host.frm
安装Mysql后报错: InnoDB: Apply batch completed 141115 15:04:36 InnoDB: Started; log sequence number 0 442 ...