基于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)
上一篇 2022年1月11日 上午8:00
下一篇 2022年1月11日 上午9:00


相关推荐

  • 从源码探究双亲委派机制

    从源码探究双亲委派机制首先我们要知道双亲委派机制是为了解决什么问题 有关类加载器 可以参考我的这篇博客 所谓的双亲委派 就是先让父亲加载器试图加载该 Class 只有在父亲加载器无法加载该类时才尝试从自己的类路径中加载该类 通俗的讲 就是某个特定的类加载器在接到加载类的请求时 首先将加载任务委托给父亲加载器 依次递归 如果父亲加载器可以完成类加载任务 就成功返回 只有父亲加载器无法完成此加载任务时 才自己去加载 我们通过这张图来理解一下 在被动的情况下 当一个类加载器收到加载请求 他不会首先自己去加载 而是传递

    2026年3月19日
    1
  • Eclipse安装android插件

    Eclipse安装android插件1.安装ADT:help中的Installnewsoftware中addadt:https://dl-ssl.google.com/android/eclipse/2.安装好SDK,建立虚拟机3.window–preferences–android中选取配置SDK4。编译android项目,runas中选择android项目

    2022年10月4日
    7
  • Java虚拟机:对象的创建过程

    Java虚拟机:对象的创建过程

    2021年4月10日
    157
  • macbook电脑上怎么使用npm安装yarn

    macbook电脑上怎么使用npm安装yarnMac 电脑用 npm 安装 yarn 先获取权限 sudo s 下载并安装 yarn 注意确保 npm 源能用 可手动配置淘宝源 npminstall gyarn

    2026年3月26日
    3
  • 什么是AOP对AOP的面试题

    什么是AOP对AOP的面试题我是属于那种你让我写代码我能写出来 而且底层原理大概我也都知道的那种 但是你要我说各种概念我就不行了 而且我只喜欢代码 但是奈何面试的时候不可能让你你这做吧 所以为了应付面试只能做做总结了 索性就写博客来巩固了 来吧 什么是 AOP 首先告诉面试官 aop 就是面向切面编程 那什么是面向切面编程呢 就是指在运行期动态的将代码切入到制定类的指定位置这种思想就是面向切面编程 举个例子 如果我们要在执行哪

    2026年3月18日
    3
  • 创建和调用动态链接库方法

    创建和调用动态链接库方法

    2021年9月3日
    57

发表回复

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

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