Sms ContentObserver onChange()会多次触发

r2D*_*Inc 7 java android contentobserver

我知道这个问题已被多次询问,但没有人能够从我所看到的那里得到一个有效的答案.

我正在开发一个应用程序拦截短信,并根据发送#,弹出一个自定义提醒.我让它与广播接收器完美配合,但是如果用户安装了goSms,那么onReceive()方法永远不会被调用,因为goSms在它到达我的应用程序之前就会中止它.

为了解决这个问题,我尝试了一个关于content://sms/ 它的内容观察者工作得很好,但是它onChange()被调用两次,具有完全相同的参数.我试过检查时间戳,但它们是相同的,就像我设置的类型和其他所有参数一样.

从我所看到的情况来看,这是一个常见的问题,但不是我见过的任何一个问题.

    @Override
public void onChange(boolean selfChange) {
    super.onChange(selfChange);
    querySMS();
}

protected void querySMS() {
    Cursor cur = getContentResolver().query(u, null, null, null, null);
    cur.moveToNext(); // this will make it point to the first record, which is the last SMS sent
    String type = cur.getString(cur.getColumnIndex("type"));
    String body = cur.getString(cur.getColumnIndex("body")); //content of sms
    String add = cur.getString(cur.getColumnIndex("address")); //phone num
    if (type.equals("1")) {
        if (add.equals(Test.SENDER)) {              
            String[] bodys = body.split(" ", 7);
            if (bodys[0].equals("test")) {
                test = true;
            }
            cat = bodys[1];
            level = bodys[2];
            urgency = bodys[3];
            certainty = bodys[4];
            carrier = bodys[5];
            message = bodys[6];
            final Intent intent = new Intent(context, AlertActivity.class);
            Bundle b = new Bundle();
            b.putString("title", cat);
            b.putString("certainty", certainty);
            b.putString("urgency", urgency);
            b.putString("level", level);
            b.putString("message", message);
            b.putBoolean("test", test);
            intent.putExtras(b);
            intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
            TelephonyManager manager = (TelephonyManager)context.getSystemService(Context.TELEPHONY_SERVICE);
            carrierName = manager.getNetworkOperatorName();
            if (carrierName.replaceAll(" ", "").equals(carrier)) {

                context.startActivity(intent);
            } else {
                //testing
                Toast.makeText(context, carrierName.replaceAll(" ", ""), Toast.LENGTH_LONG).show();
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

由于onChange()被解雇两次,我也得到两个警报.我无法为我的生活找到解决这个问题的方法.

Kev*_*imm 4

如果两者相同:
存储每个消息recv'd
将其与先前的消息recv'd
如果未找到,处理
如果找到,丢弃该消息

存储的消息的寿命应该是无穷小的,5 个消息的小型循环缓冲区应该没问题。

  • 啊。将你的想法与http://stackoverflow.com/questions/7012703/android-detect-sms-outgoing-in Correct-count结合起来,我让它工作了。我想我第一次读到它时误解了你的意思。我创建了一个静态“arrayList”并用它来检查。`if (!ids.contains(id)) { ids.add(id);context.startActivity(intent);}` (2认同)