基于android 社会的app短信分享 发送回调事件的实现

基于android 社会的app短信分享 发送回调事件的实现

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

摘要

前一段时间。由于项目的需要,采用ShareSDK该共享功能。其中包含 短信股吧。和呼叫系统,以分享要与成功处理服务器交互的消息后,(我不在乎在这里,收到。仅仅关心发出去了)。可是ShareSDk并不支持短信分享的回调功能,咨询了技术客服,也没有讨论出解决方式来。于是自己尝试粗略实现了一下。

方法

在调用系统短信发送后,通过内容观察者监听 短信发件箱的改变,假设监听到有内容改变的短信ID,那么获取当前的内容并检測当中是否含有某些关键字( 当然,这个关键字是我们自定义的。比如:“jarlen”);假设找到则说明已发送了(我这里不关心,对方是否能收到)。

核心 Code


/** * Created by jarlen on 2015/6/4. */
public class SMSContentObserver extends ContentObserver {
    private Context mContext;

    private boolean isGoing = false;
    private Handler mHandler;
    private String targetAddress = null;
    private String observerContent = null;

    /** * 短信息发送监听者构造器 * * @param context * @param handler 监听回调 * @param address 监听的目标手机号 * @param content 监听的内容关键字 */
    public SMSContentObserver(Context context, Handler handler, String address, String content) {
        super(handler);
        this.mContext = context;
        this.mHandler = handler;
        if (address != null) {
            //去掉手机号中的所有空格
            this.targetAddress = address.replaceAll(" ", "");
        }
        this.observerContent = content;
    }

    Object obj = new Object();

    @Override
    public void onChange(boolean selfChange) {

        synchronized (obj) {
            if (!isGoing) {
                isGoing = true;
                Cursor cursor = mContext.getContentResolver().query(
                        Uri.parse("content://sms/outbox"), null, null, null,
                        null);

                String address = null;
                String smsContent = null;
                // 遍历查询结果获取用户正在发送的短信
                while (cursor.moveToNext()) {
                    StringBuffer sb = new StringBuffer();
                    // 获取短信的发送地址
                    address = cursor
                            .getString(cursor.getColumnIndex("address"));
                    smsContent = cursor
                            .getString(cursor.getColumnIndex("body"));
                }
                if (address != null && smsContent != null) {
                    // 找到一个正在发送的短信
                    Log.e("===", "找到一个正在发送的短信");
                    if (targetAddress != null) {
                        // 事先指定的收件人不为空
                        if (address.contains(targetAddress)
                                && smsContent.contains(observerContent)) {
                            // 正好是事先指定的收件人,而且信息内容含有某种关键字
                            Log.e("===", "信息内容含有某种关键字");
                            Message msg = mHandler.obtainMessage();
                            msg.obj = address;
                            msg.what = 1;
                            msg.sendToTarget();
                        } else {
                            Message msg = mHandler.obtainMessage();
                            msg.what = 0;
                            msg.sendToTarget();
                        }
                    } else {
                        // 事先没有指定的收件人
                        if (smsContent.contains(observerContent)) {
                            // 信息内容含有某种关键字
                            Log.e("===", "信息内容含有某种关键字");
                            Message msg = mHandler.obtainMessage();
                            msg.obj = address;
                            msg.what = 1;
                            msg.sendToTarget();
                        } else {
                            Message msg = mHandler.obtainMessage();
                            msg.what = 0;
                            msg.sendToTarget();
                        }
                    }
                }
            }
        }
    }
}

创建监听


    /** * 监听 */
    private SMSContentObserver smsContentObserver;

    private boolean smsContentObserverFind = false;

    private Handler mHandler = new Handler() {
    public void handleMessage(Message msg) {

            if (msg.what == 1 && !smsContentObserverFind) {

                ........// 相关处理

                smsContentObserverFind = true;
            }
        }
    };
smsContentObserver = new SMSContentObserver(this, mHandler, usernumber,"某关键词");

getContentResolver().registerContentObserver(
Uri.parse("content://sms"), true, smsContentObserver);

/** *监听解绑 */
if (smsContentObserver != null) {
            getContentResolver().unregisterContentObserver(smsContentObserver);
            smsContentObserver = null;
        }

版权声明:本文博主原创文章。博客,未经同意不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117070.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 首选DNS服务器地址不显示,首选dns服务器如何设置?如何设置DNS地址

    首选DNS服务器地址不显示,首选dns服务器如何设置?如何设置DNS地址首选dns服务器如何设置?如何设置DNS地址分类:云服务资讯编辑:聊聊云计算浏览量:1652021-01-2915:18:29现在有很多朋友对于首选dns服务器的设置方法不是很了解,不知道如何操作,今天新网就给大家详细的介绍下首选dns服务器如何设置以及如何设置DNS地址等问题,希望提供些帮助。首选dns服务器怎么设置?在“开始”中找到“运行”或者直接【Win】+【R】,然后输入“cmd”进入管…

    2022年6月13日
    25
  • 计算机网络 | 思科网络 | ACL通配符掩码「建议收藏」

    计算机网络 | 思科网络 | ACL通配符掩码「建议收藏」目录一.什么是通配符掩码二.使用通配符掩码三.通配符掩码示例1.使用通配符掩码匹配IPv4子网2.使用通配符掩码匹配网络范围四.计算通配符掩码1.通配符掩码计算:示例12.通配符掩码计算:示例23.通配符掩码计算:示例3五.通配符掩码关键字1.示例1:匹配单个IPv4地址的通配符掩码过程2.示例2:匹配所有IPv4地址的通配符掩码过程一.什么是通配符掩码通配符掩码是由32个二进制数字组成的字符串,路由器使用它来确定检查地址的

    2022年7月24日
    9
  • ThreadLocal

    ThreadLocal

    2021年9月12日
    42
  • ManagementObject_getsuperclass方法

    ManagementObject_getsuperclass方法原文:http://blog.csdn.net/hardstone1/article/details/5380775网上代码和MSDN帮助中都没有列出 ManagementObject[""]这里到底有哪些属性可以使用,参考了http://www.groupsrv.com/dotnet/about69957.html了之后发现了可以枚举出来所有属性,代码如函数getallprop()。…

    2022年10月2日
    0
  • 树莓派串口调试助手_树莓派4b教程

    树莓派串口调试助手_树莓派4b教程原文链接:https://blog.csdn.net/itisyang/article/details/79968592最新的Raspbian串口连接没有数据输出使用ssh连接树莓派之后-sudoraspi-config-InterfacingOptions-Serial打开串口登录树莓派正常情况串口四根线连接:VCC-5VGND-GNDTX…

    2022年10月10日
    0
  • 4G技术TDD和FDD分别指什么「建议收藏」

    4G技术TDD和FDD分别指什么「建议收藏」TDD和FDD分别指什么;   TDD(Time Division Duplexing)时分双工技术,在移动通信技术使用的双工技术之一,与FDD相对应。   在TDD模式的移动通信系统中,基站到移动台之间的上行和下行通信使用同一频率信道(即载波)的不同时隙,用时间来分离接收和传送信道,某个时间段由基站发送信号给移动

    2022年6月9日
    58

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号