1. 程式人生 > >Android 監聽簡訊(同時監聽廣播和資料庫)

Android 監聽簡訊(同時監聽廣播和資料庫)

暗釦,強烈譴責這種侵害使用者利益的行為。。。

下面給大家介紹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 簡訊(同時廣播資料庫)

    暗釦,強烈譴責這種侵害使用者利益的行為。。。 下面給大家介紹Android暗釦原理.......  Android4.4以下的系統玩遊戲就要小心了哈 暗釦方式之一:簡訊訂購,即監聽--------攔截------------處理簡訊。 暗釦方式之二:模擬人為操作(又叫模擬流

    android 實現簡訊接收並將當前位置傳送出去

    1、獲取定位地址,這裡使用高德定位,從官網下載定位的jar包AMap_Location_V3.50_20170731.jar包然後在build.gradlecompile files('libs/AMap_Location_V3.5.0_20170731.jar')然後在許

    Android 6.0簡訊(有Git真好,簡單方便+輕鬆愉快)

    最近在最後的任職期還被榨了一頓忙的飛起,不過今天是最後一天了,幫著處理個BUG就功德圓滿了。然後最近在做一個手機間通訊+XX監聽的Demo,其中一部分是關於簡訊監聽的,然後正好6.0授權的一些因素,那就把這部分的實現單獨拆出來做這麼個Demo,順道把這幾天覺

    Android學習日記】(七) 簡訊接收例項

    /* 自定義繼承自BroadcastReceiver類,監聽系統服務廣播的資訊 */ public class EX06_01_SMSreceiver extends BroadcastReceiver  {     /*宣告靜態字串,並使用android.provider

    android傳送簡訊以及傳送狀態

     自定義ACTION常數,作為廣播的Intent Filter識別常數 private String SMS_SEND_ACTIOIN = "SMS_SEND_ACTIOIN"; private String SMS_DELIVERED_ACTION = "SMS_D

    Android系統廣播 自定義廣播遇到的問題

    現在有一個專案需要做一個開機自啟動的功能,這個怎麼實現呢?一頓咔咔咔百度,發現很多推薦 使用監聽系統開機廣播BOOT_COMPLETED,CONNECTIVITY_CHANGE 來實現。那好吧  我也這麼來做。先寫一個RootReceiver  extends Broadc

    Android如何開機廣播關機廣播

    專案背景:在錄影過程中,遇到關機事件,想要監聽關機操作,從而停止錄影,退出程式。 一、監聽開機廣播 Android系統啟動完成後會發出啟動完成廣播(android.intent.action.BOOT_COMPLETED),所有註冊了接收啟動完成廣播的接收器(Broadca

    Android開發入門之實現動態註冊廣播網路變化

    最近在學習Android開發中廣播的相關內容。 註冊廣播的方式有兩種,在程式碼中註冊和在AndroidManifest.xml中註冊,其中前者也被稱為動態註冊,後者被稱為靜態註冊。以註冊廣播監聽網路變化為例,附上實現動態註冊的步驟: 1、 class Netwo

    Android獲取手機號碼,後臺傳送簡訊以及簡訊傳送結果。

    TelephonyManager tm = (TelephonyManager) this.getSystemService(this.TELEPHONY_SERVICE); phoneNumber1 = tm.getLine1Number(); Log.w("Teleph

    Android之switch控制元件

    mSwith.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { @Override public void onCheckedChanged(Comp

    vue watch怎樣同時兩個值的變化並執行方法?

    用computed定義一個address物件吧,然後再去watch addres data() { return { city: '', country: '' } }, computed: { address() { const { city, countr

    Android 設定軟鍵盤右下角鍵盤樣式右下角點選回撥

    文章目錄 設定軟鍵盤右下角按鍵顯示樣式 監聽右下角點選回撥 設定軟鍵盤右下角按鍵顯示樣式 在EditText中使用android:imeOptions設定右下角顯示樣式(需要搭配 android

    android Data Binding 資料變化

    本文參考databinding官方文件整理。官方文件連結地址https://developer.Android.com/topic/libraries/data-binding/index.html#data_binding_layout_files Data Objects

    提高Android開發效率的一款自動findViewById設定的實用外掛

    今天來講一個外掛LayoutCreator,有了這個外掛,無疑,在開發中效率會大大提升... 下載後,重啟AS即可 介紹使用方法: 1.選中Activity所在的佈局右鍵; 選中LyoutCreator 點選後,可以發現,該外掛已經為我們找到控制元件id了(可以

    springboot整合mq同時queuetopic

    前言:springboot和mq整合的時候,預設情況下,要麼只能監聽queue要麼只能監聽topic,而不能二者兼得。 在application.properties檔案中通過如下配置項,切換監聽訊息的型別。 1 2 #為true時是topic模式,為

    Android開發20——單個監聽器多個按鈕點選事件

    分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow 也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!        

    C#實現Socket通訊(同時多客戶端)

    //建立socket物件 //第一個引數:設定網路定址的協議、第二引數設定資料傳輸的方式、第三個引數設定通訊協議 Socket serverSocket = new Socket(AddressFamily.InterNetwork, SocketT

    Nginx同時IPV6+IPV4,實現正向反向

    nginx.conf 配置如下 user root; worker_processes 8; #error_log /opt/server/department/nginx/logs/error.log warn; error_log /opt/server/department

    Android View的onClick事件

    點選事件 Android中Touch事件相關內容都被封裝到 MotionEvent 中,MotionEvent 中的時間型別有按下、擡起、滑動和結束事件。這些事件都是人機互動的一個過程,按下動作指的是人手指按在手機螢幕上這個動作,擡起動作指的是人手指按下手機後擡起來這個動作

    單執行緒實現同時多個埠(windows平臺c++程式碼)

    前言   多年前開發了一套網路庫,底層實現採用IOCP(完成埠)。該庫已在公司多個程式中應用;經過多次修改,長時間檢驗,已經非常穩定高效。 最近把以前的程式碼梳理了一下,又加進了一些新的思路。程式碼結構更加合理,效能也有所提升。打算將該庫一些的知識點寫出來,以供參考。 服務端要在多個埠監聽,這種場合並不多見。