zoukankan      html  css  js  c++  java
  • Android接收短信

    Android收到短信时会广播android.provider.Telephony.SMS_RECEIVED消息,因此只要定义一个Receiver,收听该消息,就能接收短信。

            <receiver android:name=".smsReceiver" >  
                <intent-filter>   
                    <action android:name="android.provider.Telephony.SMS_RECEIVED" />  
                </intent-filter>  
            </receiver>
    

    还可以为intent-filter加上一个优先级:

    <intent-filter android:priority="100"> 
    

    这样,由于优先级较高,应用将先于系统接收到android.provider.Telephony.SMS_RECEIVED消息。

    Java文件:

    package com.hzhi.smsReceiver;
    
    import java.text.SimpleDateFormat;
    import java.util.Date;
    
    import android.content.BroadcastReceiver;
    import android.content.Context;
    import android.content.Intent;
    import android.os.Bundle;
    import android.telephony.SmsMessage;
    import android.util.Log;
    
    public class smsReceiver extends BroadcastReceiver {  
        @Override  
        public void onReceive(Context context, Intent intent) {  
              // 短信内容
         StringBuilder strBody = new StringBuilder();
             // 短信时间 
         String strTime = new String(); 
             // 短信发件人
         StringBuilder number = new StringBuilder();
         SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");  
         Bundle bundle = intent.getExtras();  
         if (bundle != null) {  
             Object[] _pdus = (Object[]) bundle.get("pdus");  
             SmsMessage[] message = new SmsMessage[_pdus.length];  
             for (int i = 0; i < _pdus.length; i++) {  
                 message[i] = SmsMessage.createFromPdu((byte[]) _pdus[i]); 
              }  
             for (SmsMessage currentMessage : message) {  
                 strBody.append(currentMessage.getDisplayMessageBody());  
                 number.append(currentMessage.getDisplayOriginatingAddress());  
                 strTime = formatter.format(new Date(currentMessage.getTimestampMillis()));
             }
             String smsBody = strBody.toString();  
             String smsNumber = number.toString();  
             Log.v("NUMBER=", smsNumber);
             Log.v("TIME=", strTime);  
             Log.v("BODY=", smsBody);  
             // 取消消息
             this.abortBroadcast();
            } 
        }      
    }
    

    接收到消息后,通过Intent.getExtras()方法获得Intent的Extras(Bundle变量),再使用Bundle.get("pdus")得到短信数组。为什么是短信数组呢?这是因为有些短信内容比较长,所以需要一个数组来存储。对数组中的每一个元素,再分别取出短信内容、短信来源号码、短信时间。其中,这些元素的短信来源号码和短信时间都是一样的,短信内容不一样,需要拼接起来,构成一条完整的短信的内容。

    最后,this.abortBroadcast()取消android.provider.Telephony.SMS_RECEIVED消息。如果为intent-filter设置了较高的优先级,应用先于系统接收到android.provider.Telephony.SMS_RECEIVED消息,然后再将该消息丢弃,这样,系统就不会收到android.provider.Telephony.SMS_RECEIVED消息,也不会发出短信的提示音、震动等。如果没有设置优先级,系统将首先收到android.provider.Telephony.SMS_RECEIVED消息,发出短信的提示音、震动等,然后应用再收到短信。

  • 相关阅读:
    MySQL 分库分表方案
    MySQL高性能优化实战总结
    MySQL太慢?试试这些诊断思路和工具
    Get MySQL这5个优化技巧
    一次MySQL两千万数据大表的优化过程,三种解决方案
    MySQL 常用30种SQL查询语句优化方法
    掌握 MySQL 这 19 个骚操作,效率至少提高3倍
    分分钟解决 MySQL 查询速度慢与性能差
    总结 | 慢 SQL 问题经验总结
    MySQL主从延时这么长,要怎么优化?
  • 原文地址:https://www.cnblogs.com/mstk/p/3538730.html
Copyright © 2011-2022 走看看