Получение исключения: java.net.SocketTimeoutException - PullRequest
0 голосов
/ 01 июня 2018

Ранее я написал код для использования веб-сервисов с устройства Android на Android Studio.

Ссылка на веб-службу - http://202.54.216.49/logs/test.asmx

Сначала я использовал код, чтобы использовать метод расчета, и онработал отлично.Теперь я использую тот же код для использования метода loginauth, и он дает исключение: java.net.SocketTimeoutException и получает NULL-результат.Я использовал следующий код -

package com.example.abhimanyu.devicecontrol;

import android.content.Context;
import android.os.AsyncTask;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

import org.ksoap2.SoapEnvelope;
import org.ksoap2.serialization.PropertyInfo;
import org.ksoap2.serialization.SoapObject;
import org.ksoap2.serialization.SoapPrimitive;
import org.ksoap2.serialization.SoapSerializationEnvelope;
import org.ksoap2.transport.HttpTransportSE;

public class MainActivity extends AppCompatActivity {
    EditText textBox, textBox2;
    Button button;
    TextView ans;


    String URL = "http://202.54.216.49/logs/test.asmx";
    String NAMESPACE = "http://tempuri.org/";
    String SOAP_ACTION = "http://tempuri.org/loginauth";
    String METHOD_NAME = "loginauth";
    String PARAMETER_NAME1 = "username";
    String PARAMETER_NAME2 = "password";

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

        textBox = (EditText) findViewById(R.id.txtBox);
        textBox2 = (EditText) findViewById(R.id.txtBox2);
        button = (Button) findViewById(R.id.btn);
        ans = (TextView) findViewById(R.id.answer);
        final Context context;
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                new CallWebService().execute(textBox.getText().toString(), textBox2.getText().toString());
            }
        });
    }

    class CallWebService extends AsyncTask<String, Void, String> {
        @Override
        protected void onPostExecute(String s) {
            ans.setText(s);
        }

        @Override
        protected void onPreExecute() {
            Log.i("onPreexecute","running");
            super.onPreExecute();
        }

        @Override
        protected String doInBackground(String... params) {
            String result = null;

            SoapObject soapObject = new SoapObject(NAMESPACE, METHOD_NAME);

            PropertyInfo propertyInfo1 = new PropertyInfo();
            propertyInfo1.setName(PARAMETER_NAME1);
            propertyInfo1.setValue(params[0]);
            propertyInfo1.setType(String.class);
            soapObject.addProperty(propertyInfo1);

            PropertyInfo propertyInfo2 = new PropertyInfo();
            propertyInfo2.setName(PARAMETER_NAME2);
            propertyInfo2.setValue(params[1]);
            propertyInfo2.setType(String.class);
            soapObject.addProperty(propertyInfo2);

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

            HttpTransportSE httpTransportSE =  new HttpTransportSE(URL);

            try {
                httpTransportSE.call(SOAP_ACTION, envelope);
                SoapPrimitive soapPrimitive = (SoapPrimitive)envelope.getResponse();
                result = soapPrimitive.toString();
            } catch (Exception e) {
                e.printStackTrace();
            }

            return result;

        }
    }
}

Пожалуйста, помогите.Я видел другие решения относительно этого типа исключения, но ничего не помогло.И что я не понимаю, так это то, что один и тот же код отлично работает для «расчета», но не для «логинаута».Почему?

1 Ответ

0 голосов
/ 04 июня 2018

Установить время ожидания повторной попытки с помощью запроса HttpTransportSE

HttpTransportSE http = new HttpTransportSE(URL, 30000);
...