连接到 Web 服务以 SocketTimeoutException 结束

Connecting to web service ends with SocketTimeoutException

我有连接到 Web 服务的代码段。我的应用程序有一个按钮,按下时会从服务器获取一些数据并显示给用户。这很简单,但永远行不通。我已经阅读了 post 篇关于我的问题的所有文章,但是 none 篇都解决了它。代码使用自codeproject sample:

public void onClick(View v) {
    SoapObject request = new SoapObject("http://tempuri.org/", "Add");
    PropertyInfo pi=new PropertyInfo();
    pi.setName("a");
    pi.setValue(10);
    pi.setType(Integer.class);
    request.addProperty(pi);
    pi=new PropertyInfo();
    pi.setName("b");
    pi.setValue(15);
    pi.setType(Integer.class);
    request.addProperty(pi);

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

    envelope.setOutputSoapObject(request);

    HttpTransportSE httpTransport = new HttpTransportSE("http://grasshoppernetwork.com/NewFile.asmx");
    String response="";
    try
    {
        httpTransport.call("http://tempuri.org/Add", envelope);
        response = (envelope.getResponse()).toString();
    }
    catch (Exception exception)
    {
        response=exception.toString();
    }


    onSoapRequestFinished(response.toString());
}

我添加了 2 个权限:Network_Access 和互联网。令人惊讶的是,可以从 AVD 的浏览器访问 Web 服务。

错误是:

java.net.MalformedURLException: no protocol: java.net.SocketTimeoutException
    at java.net.URL.<init>(URL.java:589)
    at java.net.URL.<init>(URL.java:486)
    at java.net.URL.<init>(URL.java:435)
    at org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:115)
    at javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:155)
    at ir.dana.sharif.testxml.MainActivity.onSoapRequestFinished(MainActivity.java:103)
    at ir.dana.sharif.testxml.MainActivity.onClick(MainActivity.java:84)
    at android.view.View.performClick(View.java:5610)
    at android.view.View$PerformClick.run(View.java:22265)
    at android.os.Handler.handleCallback(Handler.java:751)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:154)
    at android.app.ActivityThread.main(ActivityThread.java:6077)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)

我 post 为未来的读者提供答案。在调查了很多方法后,我发现为 KSoap 导入的库是错误的。我为无法连接到服务器的应用程序使用了 ksoap.jar。我将其替换为 ksoap2-android-assembly-2.6.0-jar-with-dependencies 并且一切顺利。

另外,volley 库很有魅力。