3

Web サービスは整数を返す必要がありますが、コードを実行するたびに NullPointerException エラーが発生します。どんなアイデアや助けも大歓迎です

これが私のコードです:

public class CGCountTest extends Activity {

    TextView testTV;

    private static final String NAMESPACE = "http://passport-america.com/webservices/";
    private static final String URL = "http://localhost:11746/Service1.asmx";
    private static final String SOAP_ACTION = "http://www.passport-america.com/webservices/getCGCount";
    private static final String METHOD_NAME = "getCGCount";

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.soap_test);

          SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
            SoapSerializationEnvelope envelope =
                new SoapSerializationEnvelope(SoapEnvelope.VER11);
                envelope.dotNet = true;
                envelope.setOutputSoapObject(request);
                HttpTransportSE androidHttpTransport = new HttpTransportSE(URL);

                try {
                    androidHttpTransport.call(SOAP_ACTION, envelope);
                    java.lang.Integer result = (Integer)envelope.getResponse();
                    TextView testTV = (TextView)findViewById(R.id.testTV);
                    result.toString();
                    testTV.setText(result);
                }
                catch(Exception e)
                {
                    testTV.setText(e.getMessage());
                }
    }

ここにログキャットがあります

06-02 15:13:36.557: WARN/dalvikvm(326): threadid=3: thread exiting with uncaught exception (group=0x4001aa28)
06-02 15:13:36.557: ERROR/AndroidRuntime(326): Uncaught handler: thread main exiting due to uncaught exception
06-02 15:13:36.876: ERROR/AndroidRuntime(326): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.pa.passammain/com.pa.passammain.CGCountTest}: java.lang.NullPointerException
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2401)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2417)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.app.ActivityThread.access$2100(ActivityThread.java:116)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1794)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.os.Handler.dispatchMessage(Handler.java:99)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.os.Looper.loop(Looper.java:123)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.app.ActivityThread.main(ActivityThread.java:4203)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at java.lang.reflect.Method.invokeNative(Native Method)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at java.lang.reflect.Method.invoke(Method.java:521)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:549)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at dalvik.system.NativeStart.main(Native Method)
06-02 15:13:36.876: ERROR/AndroidRuntime(326): Caused by: java.lang.NullPointerException
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at com.pa.passammain.CGCountTest.onCreate(CGCountTest.java:46)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1123)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2364)
06-02 15:13:36.876: ERROR/AndroidRuntime(326):     ... 11 more

私のURL文字列が問題かもしれないと思いますが、私のIPを使ってみましたがうまくいきませんでした

4

2 に答える 2

0

私は同様の状況で作業しましたが、以下のコードはエラーなしで機能しています。

        String NAMESPACE = "http://tempuri.org/";
        String METHOD_NAME = "getOutletCount";
        String SOAP_ACTION = "http://tempuri.org/getOutletCount";
        String URL = "http://10.20.10.80/dinotawebsrv/GetDataWebService.asmx";

        SoapObject Request = new SoapObject(NAMESPACE, METHOD_NAME);

        SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(
                SoapEnvelope.VER11);
        envelope.dotNet = true;
        envelope.setOutputSoapObject(Request);

        AndroidHttpTransport androidHttpTransport = new AndroidHttpTransport(
                URL);

        androidHttpTransport.call(SOAP_ACTION, envelope);
        System.out.println("web service call completed......");
        SoapPrimitive response = (SoapPrimitive) envelope.getResponse();

        return Integer.parseInt(response.toString());

デバッグしてみてください。応答で結果が得られるかどうかを確認してください。また、応答を整数に直接キャストすることはできないと思います。幸運を..

于 2011-06-12T18:27:54.977 に答える
0

URL 文字列ではありません (正しくない可能性がありますが、有効な文字列です)。使用している関数呼び出しの 1 つに、入力パラメーターの 1 つとして null が含まれています。ほとんどの場合、null を返す何かを実行しようとして、その値を別のメソッド呼び出しで使用したことが原因です。

コードの 326 行目に何があるかわかりませんが、そこにあるオブジェクトの 1 つが null であることは間違いないので、最初にそれをチェックし始めます。

326 行目を貼り付けたい場合は、さらにお手伝いします。

于 2010-06-02T15:51:32.240 に答える