暗扣,强烈谴责这种侵害用户利益的行为。。。

下面给大家介绍Android暗扣原理.......  Android4.4以下的系统玩游戏就要小心了哈

暗扣方式之一:短信订购,即监听--------拦截------------处理短信。

暗扣方式之二:模拟人为操作(又叫模拟流量),通过后台程序代码模拟人的点击行为,暗自给用户订购业务,由运营商收取你的费用,当然这其中也需要涉及监听/拦截/处理短信。使用这种方式的原理无非是Http处理网页,还涉及接入点切换问题,这里就不详细讲解。

回归正题:有的时候,我们的手机程序需要监听手机短信,当满足条件A时,不处理;当满足条件B时,将其设置为已读;当满足条件C时,将短信删除。

注:Android 4.4以及以后可能由用户来控制程序的权限,如果用户关闭这个程序的权限,意味着你无法监听短信/操作短信内容

目前也有如小米系统在安装时,让用户来控制权限;360来监听优先拦截短信等等(关于谁先安装谁有优先权,动态注册比静态注册优先级别高等问题,在这些情况这里就不讲了)。。。

Android 实现监听短信(同时监听广播和数据库)代码如下:

  1. 拦截广播

    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 +" ");
    }
    }
    }
    }
    }
    }


  2. 开启一个服务开监听数据库
    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());
    }
    }


  3. 数据库观察者
    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;
    }
    }
    }


  4. 短信处理类
    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 });
    }
    }
    }


  5. 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 + "]";
    } }


  6. 需要的权限以及配置信息
    <?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>
  7. 测试在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 监听短信(同时监听广播和数据库)的更多相关文章

  1. Android手机上监听短信的两种方式

    Android手机上监听短信有两种方式: 1. 接受系统的短信广播,操作短信内容. 优点:操作方便,适合简单的短信应用. 缺点:来信会在状态栏显示通知信息. AndroidManifest.xml: ...

  2. android 监听短信数据库,制作短信控制工具,控制别人的手机!!(一)

    序言:本程序示例本着简洁易懂的目的,只做了简单的功能实现,需要用户启动应用,收到短信才有效果.作者将会在后面的(二)篇中加入服务后台运行.自动启动功能,实现一个真正的短信控制工具.本文的目的很简单,让 ...

  3. android菜鸟学习笔记23----ContentProvider(三)利用内置ContentProvider监听短信及查看联系人

    要使用一个ContentProvider,必须要知道的是它所能匹配的Uri及其数据存储的表的结构. 首先想办法找到访问短信及联系人数据的ContentProvider能接受的Uri: 到github上 ...

  4. android 监听短信并发送到服务器

    1. 接受系统的短信广播,操作短信内容. 优点:操作方便,适合简单的短信应用. 缺点:来信会在状态栏显示通知信息. 2. 应用观察者模式,监听短信数据库,操作短信内容.   实例如下: SystemE ...

  5. 通过broadcastreceiver 监听短信问题

    在mainfest中 订阅   短信到来的广播时候  发现找不到 <action android:name="android.provider.Telephony.SMS_RECEIV ...

  6. 内容观察者 ContentObserver 监听短信、通话记录数据库 挂断来电

    Activity public class MainActivity extends ListActivity {     private TextView tv_info;     private  ...

  7. Android_通过ContentObserver监听短信数据变化

    1.简单介绍 在小米等一些机型,无法接收系统发出的短信广播. 仅仅能通过观察者ContentObserver,去监听短信数据的变化 2.SMS数据介绍 content://sms/inbox     ...

  8. 短信状态监听 - iOS

    当使用 App 时若短信介入需要对当前状态进行监听操作,根据不同的状态实行相关的需求操作,废话不多说步骤如下. 首先,常规操作先引用对应的头文件,来为后续功能铺路. #import <Messa ...

  9. android自动填写短信验证码

    广播类 package com.examp.azuoyoutong.listner; import java.util.regex.Matcher;import java.util.regex.Pat ...

随机推荐

  1. 【C#学习笔记】结构体使用

    using System; namespace ConsoleApplication { struct _st { public string name; public int age; } clas ...

  2. 使用源代码安装lnmp

    一.安装nginx前,安装pcre. # tar zxvf pcre-8.12.tar.gz# ./configure# make# make install 二.安装nginx # tar zxvf ...

  3. [转](多实例)mysql-mmm集群

    一.需求说明 最近一直在学习mysql-mmm,想以后这个架构也能用在我们公司的业务上,我们公司的业务是单机多实例部署,所以也想把mysql-mmm部署成这样,功夫不负有心人,我成功了,和大家分享一下 ...

  4. 【转】cocos2d-x 3x Sprite3D

    Sprite3D Sprite3D works in many ways like a normal Sprite. Sprite3D is a three-dimensional model tha ...

  5. 【转】错误日志ID8021来源BROWSER导致电脑死机

    现场工控机死机,网上查了篇文章,具体原因还有待分析,下面是图 在这里有必要介绍两个ID号:6006和6005.在事件查看器里ID号为6006的事件表示事件日志服务已停止,如果你没有在当天的事件查看器中 ...

  6. [Everyday Mathematics]20150116

    设 $\al_n\geq 0$ 且 $\dps{\vlm{n}\al_n=0}$, 试求 $$\bex \vlm{n}\frac{1}{n}\sum_{k=1}^n \ln\sex{\frac{k}{ ...

  7. IOS UIScrollView中 使用 touch 无法响应的问题

    添加一个 Category  然后在使用到 UIScrollView 的文件里面 导入这个头文件 就可以 // //  UIScrollView+UITouch.m //  alarm // //  ...

  8. AppServ的安装与配置

    AppServ是一个软件集合,包括Apache(HTTP服务器软件).PHP(网页程序设计语言).MySQL(数据库管理系统软件).phpMyAdmin(图形界面的数据库管理软件)四个组成部分.App ...

  9. 【原】Storm 入门教程目录

    Storm入门教程 1. Storm基础 Storm Storm主要特点 Storm基本概念 Storm调度器 Storm配置 Guaranteeing Message Processing(消息处理 ...

  10. netty的入门

    netty是什么? netty是一个基于NIO的通信框架,对于传统计算机,系统的瓶颈一直在输入输出设备上,计算速度超过IO速度,所以对于i o的性能提高异常重要. 什么是NIO? 非阻塞IO,N表示n ...