空指针异常 - 无法启动接收器?

时间:2013-04-01 14:55:01

标签: android-intent nullpointerexception broadcastreceiver locationmanager smsmanager

我刚开始我的第一个主要项目 - 一个简单的防盗应用程序,当我的手机被文本编辑时,如果它包含某个字符串,它会将短信发送回原始地址,告诉它手机的位置。但是,我现在只是试图让手机接收短信,检查它是否包含字符串,获取位置,然后在手机上烘烤该位置。我的问题是,因为我非常非常熟悉android编程/ Java(只有15)我将我的位置从我的MainActivity传递到我的广播接收器时遇到了麻烦。我得到一个空指针异常 - 这是我的应用程序设法获取gps位置的时候。还有一点要注意,我使用'Cerberus Anti-theft'作为我的主要防盗,这会导致任何错误吗?

这是我的MainActivity - 我的LocationListener,你可以看到,我在onLocationChanged上注释了Toast.makeText(),如果我取消注释,我会得到正确的坐标。这意味着它必须与我的意图有关 - 对我来说看起来非常好。

package com.SMS;

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;

public class MainActivity extends Activity {

    private LocationManager lm;
    private LocationListener locationListener;


    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        lm = (LocationManager)
            getSystemService(Context.LOCATION_SERVICE);

        locationListener = new MyLocationListener();

        lm.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0,       locationListener);  
    }

    public class MyLocationListener implements LocationListener
    {
        @Override
        public void onLocationChanged(Location loc) 
                {
                if (loc != null) 
                {
                    int Longitude = (int) (loc.getLongitude() * 1E6);
                    int Latitude = (int) (loc.getLatitude() * 1E6);
                    // Toast.makeText(getBaseContext(), "Location Changed : Lat: " + Latitude + " Longitude : " + Longitude, Toast.LENGTH_LONG).show();
                    Intent intent = new Intent(MainActivity.this, SMSReceiver.class);                      intent.setAction("android.provider.Telephony.SMS_RECEIVED");
                intent.putExtra("Longitude", Longitude);
                intent.putExtra("Latitude", Latitude);
                sendBroadcast(intent);
                }
        }

        @Override
        public void onProviderDisabled(String provider) {
            // TODO Auto-generated method stub

        }

        @Override
        public void onProviderEnabled(String provider) {
        // TODO Auto-generated method stub

        }

        @Override
        public void onStatusChanged(String provider, int status, Bundle extras)          
                {
        // TODO Auto-generated method stub

        }
    }
}

这是我的SmsReceiver类,这是检索sms以检查包含字符串的位置。我已经尝试过在这种事情上看到的所有内容(我的历史充满了这些东西),但是我做过的事情,纬度和经度仍然会返回300 - 我设置的默认值。我确信这与我的意图设置和接收意图有关,只是不知道它是什么错。所以,请仔细阅读并告诉我你发现错误的任何反馈。

package com.SMS;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.SmsMessage;
import android.widget.Toast;

public class SMSReceiver extends BroadcastReceiver
{

    @Override
    public void onReceive(Context context, Intent intent) 
    {

        //--get the sms message passed in--
        Bundle bundle = intent.getExtras();
        SmsMessage[] msgs = null;
        String str = "";
        if (bundle != null) 
        {
            //--- retrieve the sms message received
            Object[] pdus = (Object[]) bundle.get("pdus");
            msgs = new SmsMessage[pdus.length];
            for (int i=0; i<msgs.length; i++)
                        {
                msgs[i] = SmsMessage.createFromPdu((byte[])pdus[i]);

                str += "SMS from " + msgs[i].getOriginatingAddress();
                str += " : ";
                str += msgs[i ].getMessageBody().toString(); 
                str += "\n";
                if(str.contains("alfa"))
                { 

                      int Longitude = bundle.getInt("Longitude", 300);
                      int Latitude = bundle.getInt("Latitude", 300);
                      //--display the new sms message
                      Toast.makeText(context, "Location Changed : Latitude : " + Latitude + " Longitude : " + Longitude, Toast.LENGTH_LONG).show();
                }
            }
        }
    }
}

这是我的Manifest,我相当肯定是问题的一部分,如果你看错了或不合适,或者可以简化,请告诉我!

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.SMS"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.SMS.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <receiver android:name=".SMSReceiver" >
            <intent-filter>
                <action android:name="android.provider.Telephony.SMS_RECEIVED" />
            </intent-filter>
        </receiver>
    </application>

    <uses-permission android:name="android.permission.SEND_SMS" />
    <uses-permission android:name="android.permission.RECEIVE_SMS" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_COURSE_LOCATION" />
    <uses-permission android:name="android.permission.INTERNET" />

</manifest>

最后,LogCat会在找到gps时发生错误。

04-01 15:38:41.323: W/dalvikvm(16245): threadid=1: thread exiting with uncaught     exception (group=0x412b7930)
04-01 15:38:41.333: E/AndroidRuntime(16245): FATAL EXCEPTION: main
04-01 15:38:41.333: E/AndroidRuntime(16245): java.lang.RuntimeException: Unable to   start receiver com.SMS.SMSReceiver: java.lang.NullPointerException
04-01 15:38:41.333: E/AndroidRuntime(16245):    at   android.app.ActivityThread.handleReceiver(ActivityThread.java:2383)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at    android.app.ActivityThread.access$1500(ActivityThread.java:141)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at   android.app.ActivityThread$H.handleMessage(ActivityThread.java:1310)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at   android.os.Handler.dispatchMessage(Handler.java:99)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at   android.os.Looper.loop(Looper.java:137)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at   android.app.ActivityThread.main(ActivityThread.java:5041)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at  java.lang.reflect.Method.invokeNative(Native Method)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at java.lang.reflect.Method.invoke(Method.java:511)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at dalvik.system.NativeStart.main(Native Method)
04-01 15:38:41.333: E/AndroidRuntime(16245): Caused by: java.lang.NullPointerException
04-01 15:38:41.333: E/AndroidRuntime(16245):    at com.SMS.SMSReceiver.onReceive(SMSReceiver.java:24)
04-01 15:38:41.333: E/AndroidRuntime(16245):    at    android.app.ActivityThread.handleReceiver(ActivityThread.java:2376)
04-01 15:38:41.333: E/AndroidRuntime(16245):    ... 10 more

拜托,拜托,请帮助我,我现在已经在互联网上搜索了5天,但仍然没有运气。我似乎无法让它工作。因此,如果您可以就错误以及如何更改错误提供反馈,或对此有任何疑问,请回复,因为我花了好几个小时才搜索网页。此外,如果您发现任何“编码错误”,请不要犹豫,告诉我。如果你能解决这个问题,非常感谢你!

1 个答案:

答案 0 :(得分:0)

Object [] pdus =(Object [])bundle.get(“pdus”);

你在哪里插入了pdus意图包?

创建意图时

            intent.putExtra("Longitude", Longitude);
            intent.putExtra("Latitude", Latitude);

你似乎只是放入了这些价值观。你是如何尝试在这里提取pdus的?

我认为当您尝试访问pdus.length时会出现异常,因为该对象为null。您可以尝试将其打印出来进行验证吗?