在我的应用程序中,我正在向移动设备发送端口短信。 收到消息后,我需要在我的活动中执行一些任务并更新UI。
接收者宣言声明
<receiver android:name="com.vfi.BinarySMSReceiver" >
<intent-filter android:priority="10" >
<action android:name="android.intent.action.DATA_SMS_RECEIVED" />
<data
android:host="*"
android:port="9512"
android:scheme="sms" />
</intent-filter>
</receiver>
接收者类
public class BinarySMSReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Bundle bundle = intent.getExtras();
SmsMessage[] msgs = null;
if (null != bundle) {
String info = "SMS from ";
String sender = "";
String msg = "";
Object[] pdus = (Object[]) bundle.get("pdus");
msgs = new SmsMessage[pdus.length];
byte[] data = null;
for (int i = 0; i < msgs.length; i++) {
msgs[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
sender += msgs[i].getOriginatingAddress();
info += msgs[i].getOriginatingAddress() + "\n";
data = msgs[i].getUserData();
for (int index = 0; index < data.length; ++index) {
info += Character.toString((char) data[index]);
msg += Character.toString((char) data[index]);
}
}
Log.e("SakjsdMS", "akjsdhkas" + msg);
Log.e("sender", "asdasdasdasdasdasd" + info);
((VerifyActivity)context).msgReceived(msg);
}
}
}
活动中的方法
public void msgReceived(String msgContent)
{
if(msgContent.equalsIgnoreCase(etMobile.getText().toString().trim())){
showToast("Number Verified");
}else{
showToast("Sorry wrong number. Input your number again.");
}
}
我得到的例外
java.lang.RuntimeException: Unable to start receiver com.vfi.BinarySMSReceiver: java.lang.ClassCastException: android.app.ReceiverRestrictedContext cannot be cast to com.vfi.VerifyActivity
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2467)
at android.app.ActivityThread.access$1700(ActivityThread.java:145)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1319)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5127)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:825)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:641)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassCastException: android.app.ReceiverRestrictedContext cannot be cast to com.vfi.VerifyActivity
at com.vfi.BinarySMSReceiver.onReceive(BinarySMSReceiver.java:46)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2460)
在android.app.ActivityThread.access $ 1700(ActivityThread.java:145)
如何在接收器中获取活动上下文以调用我的方法?
答案 0 :(得分:2)
我能够通过编程方式声明接收器来解决它:
在发送消息的活动中
private void sendSMS() {
BinarySMSReceiver smsReceiver = null;
smsReceiver = new BinarySMSReceiver();
smsReceiver.setActivityHandler(this);
IntentFilter portIntentFilter = new IntentFilter("android.intent.action.DATA_SMS_RECEIVED");
portIntentFilter.addDataAuthority("*", "9512");
portIntentFilter.addDataScheme("sms");
registerReceiver(smsReceiver, portIntentFilter);
String messageText = etMobile.getText().toString().trim();
short SMS_PORT = 9512;
SmsManager smsManager = SmsManager.getDefault();
smsManager.sendDataMessage(etMobile.getText().toString().trim(), null, SMS_PORT, messageText.getBytes(), null, null);
}
在接收器类
中public class BinarySMSReceiver extends BroadcastReceiver {
VerifyActivity vAct = null;
void setActivityHandler(VerifyActivity main) {
vAct = main;
}
@Override
public void onReceive(Context context, Intent intent) {
Bundle bundle = intent.getExtras();
SmsMessage[] msgs = null;
if (null != bundle) {
String info = "SMS from ";
String sender = "";
String msg = "";
Object[] pdus = (Object[]) bundle.get("pdus");
msgs = new SmsMessage[pdus.length];
byte[] data = null;
for (int i = 0; i < msgs.length; i++) {
msgs[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
sender += msgs[i].getOriginatingAddress();
info += msgs[i].getOriginatingAddress() + "\n";
data = msgs[i].getUserData();
for (int index = 0; index < data.length; ++index) {
info += Character.toString((char) data[index]);
msg += Character.toString((char) data[index]);
}
}
Log.e("message", "receiver " + msg);
Log.e("sender", "from " + info);
vAct.msgReceived(msg); //activity method
}
}
}
取消注册接收器
@Override
protected void onPause() {
super.onPause();
unregisterReceiver(smsReceiver);
}
答案 1 :(得分:1)
您得到的错误是您错误地将CL_MEM_ALLOC_HOST_PTR
投射到pinned_buffer_input
。
如果您希望实现您想要的目标,只需通过提供一些额外信息开始您的活动。
android.app.ReceiverRestrictedContext
在您的其他课程中,只需以这种方式检索您的信息:
com.vfi.VerifyActivity
那就是它。
希望这有帮助!
答案 2 :(得分:0)
Context
BinarySMSReceiver
传递的onReceive
不是活动 - 它是Context in which the receiver is running。要启动活动,您需要使用context.startActivity(Intent)
并使用Intent将任何其他数据传递给Activity。
答案 3 :(得分:-1)
extension=php_sqlsrv_55_ts.dll
extension=php_pdo_sqlsrv_55_ts.dll
这是你的错误。
你为什么假设这个背景是你的活动?
执行此操作的最佳方式(没有第三方库)是发送本地广播。
在另一个答案中,我就如何使用((VerifyActivity)context).msgReceived(msg);
Best practice to launch AsyncTask from custom view
如果您使用第三方库,我建议您从LocalBroadcast
Otto
答案 4 :(得分:-3)
默认情况下,您的BroadcastReceiver对任何活动一无所知。您必须为其提供上下文,例如在创建broadcastReceiver时在构造函数中。
private Activity activity;
public BroadcastReceiver(Activity activity) {
super();
this.activity = activity;
}
在on onceceive方法中,您现在可以以任何您喜欢的方式使用您的活动。