Closed. This question needs debugging details。它当前不接受答案。












想改善这个问题吗?更新问题,以使为on-topic

5年前关闭。



Improve this question





我有一个MainActivity可以连接到webService以便login正常工作,但是当我使用Logins.Class方法时会崩溃:

public class MainActivity extends Activity {
    EditText UserName;
    EditText PassWord;
    Button Login;
    String mUserName;
    String mPassWord;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        UserName = (EditText) findViewById(R.id.edtUserName);
        PassWord = (EditText) findViewById(R.id.edtPasswprd);
        Login = (Button) findViewById(R.id.btnLogin);

        Login.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View arg0) {
                mUserName = UserName.getText().toString().trim();
                mPassWord = PassWord.getText().toString().trim();
                if (mUserName.length() > 0 && mPassWord.length() > 0) {
                    Logins LG = new Logins().UsernameValue(mUserName)
                            .PasswordValue(mPassWord).LOGINS();
            ------> Log.i("OK", LG.getWebresponse());<--- Crash Here
                } else {
                    Toast.makeText(
                            G.context,
                            G.context.getResources().getString(
                                    R.string.btn_LoginError), Toast.LENGTH_LONG)
                            .show();
                }
            }
        });
    }
}


我有一个Logins.Class可以登录:

public class Logins {
    private String UsernameValues;
    private String PasswordValues;

    String NAMESPACE = "http://tempuri.org/";
    String METHOD_NAME = "Login";
    String SOAP_ACTION = "http://tempuri.org/Login";
    String URL = "http://test.com/MobileWebService/Related.asmx";
    private String Webresponse;

    public Logins LOGINS() {
        Thread thread = new Thread(new Runnable() {
            //"xxssxx"
            //123456789
            @Override
            public void run() {
                SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
                request.addProperty("username", UsernameValues);
                request.addProperty("pass", PasswordValues);
                request.addProperty("device", "0");
                request.addProperty("security", 128110);

                SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(
                        SoapEnvelope.VER11);
                envelope.dotNet = true;
                envelope.setAddAdornments(false);
                envelope.implicitTypes = true;
                envelope.setOutputSoapObject(request);
                HttpTransportSE conn = new HttpTransportSE(URL);
                conn.setXmlVersionTag("<?xml version=\"1.0\" encoding=\"UTF-8\"?>");
                try {
                    conn.call(SOAP_ACTION, envelope);
                    SoapPrimitive response = (SoapPrimitive) envelope
                            .getResponse();
                    Webresponse = response.toString();

                    Log.i("LOG", Webresponse);
                }
                catch (Exception e) {
                    e.printStackTrace();
                    Log.i("xxx", e.toString());
                }
            }
        });
        thread.start();
        return this;
    }

    public Logins UsernameValue(String value) {
        UsernameValues = value;
        return this;
    }

    public Logins PasswordValue(String value) {
        PasswordValues = value;
        return this;
    }

    public String getWebresponse() {
        return Webresponse;
    }

}


所有代码都工作良好,但是当我使用getWebresponse Method来获取MainActivity结果时,我会崩溃吗?

我的崩溃是:

by log Tag :AndroidRuntime
by Log Message :at com.test.MainActivity$1$1.onClick(MainActivity.java:53)
by PID : 9145

最佳答案

问题是您直接获取了仍为空的Webresponse。对Web请求的响应完成后,将对其进行初始化。

现在LG.getWebresponse()将返回null,您需要等待Web响应完成,然后才能在日志中使用Webresponse

解:

您需要使用asyntask而不是thread并将其记录在onPostExecute()方法中,该方法将确保Webresponse初始化为Web请求的响应。

10-07 12:16