基于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;
        }

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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 什么是RESTful API

    什么是RESTful API

  • vbs远程木马_vbs 访问webservice

    vbs远程木马_vbs 访问webservicexp、2003开3389+非net创建管理用户+Shift后门+自删除脚本+提权VBS整理收集2010年12月07日  xp、2003开3389+非net创建管理用户+Shift后门+自删除脚本  vbsonerrorresumenext  constHKEY_LOCAL_MACHINE=&H80000002  strComputer="."  Se…

  • cts测试套件下载(4V)

    目录概述组织caseCTS框架配置文件测试case配置文件启动框架CtsConsoletest组件CtsTest测试类型执行命令总结1概述CTS测试框架是有两个版本的,Android6.0以及之前的版本都统称为V1版本,7.0以及之后的版本为V2(目前Android版本已经迭代到AndroidO了,目前还是用的V2框架),其实两者都是基于基础框架Trade-Federat

  • 虚函数详解[通俗易懂]

    虚函数详解[通俗易懂]文章目录一、虚函数实例二、虚函数的实现(内存布局)1、无继承情况2、单继承情况(无虚函数覆盖)3、单继承情况(有虚函数覆盖)4、多重继承情况(无虚函数覆盖)5、多重继承情况(有虚函数覆盖)三、虚函数的相关问题1、构造函数为什么不能定义为虚函数2、析构函数为什么要定义为虚函数?3、如何去验证虚函数表的存在  面向对象的语言有三大特性:继承、封装、多态。虚函数作为多态的实现方式,重要性毋庸置疑。 …

  • navicat15的激活码[免费获取]

    (navicat15的激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.htmlMLZPB5EL5Q-eyJsaWN…

  • Swift 值类型和引用类型

    Swift中的类型分为两类:一,值类型(valuetypes),每个值类型的实例都拥有各自唯一的数据,通常它们是结构体,枚举或元组;二,引用类型(referencetypes),引用类型的实例共享

    2021年12月26日

发表回复

您的电子邮箱地址不会被公开。

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