我想拦截传入的彩信以启用移动数据。为此,我需要在任何其他应用程序之前拦截它们。
我已将我的 Intent 过滤器设置为接收具有最高优先级的 WAP_PUSH_RECEIVED_ACTION 广播。
但是,在 Android 文档 ( https://developer.android.com/reference/android/provider/Telephony.Sms.Intents.html ) 中,有以下两个广播:
WAP_PUSH_DELIVER_ACTION(仅发送至默认短信应用)WAP_PUSH_RECEIVED_ACTION(发送到所有应用)请问,您能告诉我这些广播中的哪一个先发送(WAP_PUSH_DELIVER_ACTION 或 WAP_PUSH_RECEIVED_ACTION)以及您在哪里找到这些信息?
他们从哪里发送 Android 源代码?
是否以尽可能高的优先级监听WAP_PUSH_RECEIVED_ACTION 让我成为第一个接收 WAP PUSH 广播的人?
谢谢
最佳答案
这个话题好像不太热门! 我试着自己回答这个问题,我发现了一些有趣的东西。
SMS 和 MMS 接收主要在文件 InboundSmsHandler.java 中进行管理。
该文件以解释 SMS/MMS 接收状态机的注释 block 开头。
以下是此评论的摘录和解释:
InboundSmsHandler.IdleState 状态启动。SMSDispatcher 从 radio 接收到新的 SMS 时,它会调用 dispatchNormalMessage(com.android.internal.telephony.SmsMessageBase),它会转换为 InboundSmsHandler .DeliveringState 状态。InboundSmsHandler.DeliveringState 状态,调用 processMessagePart(InboundSmsTracker tracker)。在此方法中,如果 SMS 的目标端口号是 SmsHeader.PORT_WAP_PUSH(换言之,如果 SMS 是 MMS),则 WapPushOverSms.dispatchWapPdu(byte[] pdu, BroadcastReceiver receiver , InboundSmsHandler 处理程序) 方法被调用。dispatchWapPdu 方法中,他们调用了 InboundSmsHandler.dispatchIntent(Intent intent, String permission, int appOp, BroadcastReceiver resultReceiver, UserHandle user)。他们检查是否有默认的 MMS 应用程序,如果是,则将 Intent 配置为仅传送到此应用程序。代码:
// Direct the intent to only the default MMS app. If we can't find a default MMS app
// then sent it to all broadcast receivers.
ComponentName componentName = SmsApplication.getDefaultMmsApplication(mContext, true);
if (componentName != null) {
// Deliver MMS message only to this receiver
intent.setComponent(componentName);
if (DBG) Rlog.v(TAG, "Delivering MMS to: " + componentName.getPackageName() +
" " + componentName.getClassName());
}
handler.dispatchIntent(intent, permission, appOp, receiver, UserHandle.OWNER);
dispatchIntent 中,我们有我们正在寻找的东西,调用 Context.sendOrderedBroadcastAsUser(...)。因此,正是这种方法将 WAP_PUSH_DELIVER_ACTION 广播作为有序广播发送。InboundSmsHandler.java< 中的="">SmsBroadcastReceiver.onReceive(Context context, Intent intent) 处理程序处理(默认应用程序和 SmsBroadcastReceiver)/。在此处理程序中,处理 WAP_PUSH_DELIVER_ACTION 情况。 Intent 更改为 WAP_PUSH_RECEIVED_ACTION 并通过 InboundSmsHandler.dispatchIntent(Intent intent, String permission, int appOp, BroadcastReceiver resultReceiver, UserHandle user) 方法再次广播。这一次,不仅关注默认应用,还关注所有感兴趣的应用。代码:
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if (action.equals(Intents.SMS_FILTER_ACTION)) {
// ...
} else if (action.equals(Intents.SMS_DELIVER_ACTION)) {
// ...
} else if (action.equals(Intents.WAP_PUSH_DELIVER_ACTION)) {
// Now dispatch the notification only intent
intent.setAction(Intents.WAP_PUSH_RECEIVED_ACTION);
intent.setComponent(null);
// Only the primary user will receive notification of incoming mms.
// That app will do the actual downloading of the mms.
dispatchIntent(intent, android.Manifest.permission.RECEIVE_SMS,
AppOpsManager.OP_RECEIVE_SMS, this, UserHandle.OWNER);
} else {
// ...
}
}
收到彩信后,WAP_PUSH_DELIVER_ACTION 首先广播到默认应用,然后是 WAP_PUSH_RECEIVED_ACTION。
这两个广播都是有序广播,这意味着可以使用优先级。
嗯,这对我来说是个坏消息,因为这也意味着我不能第一个收到彩信通知,也不能在彩信应用收到通知之前打开调制数据。
啊谷歌,有了 Lollipop,你让我们的事情变得更难了:Android Issue 78084 - setMobileDataEnabled removed
所以,我必须寻找另一种方法才能做到这一点。
关于Android - 如何第一个收到 WAP PUSH(彩信),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28623745/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>