java.net.SocketException: сбой сокета: EPERM (операция не разрешена)

144

Я работаю над проектом Android Studio с несколькими видами деятельности. В настоящее время я пытаюсь прочитать вывод сервлета Java на локальном хосте, но, похоже, он дает сбой из-за разрешения сокета.

Я создал новый проект, использовал тот же код и отлично работал. Поэтому я не понимаю, почему не хочу работать над моим проектом.

public class LoginActivity extends AppCompatActivity {


String apiUrl = "http://10.0.2.2:8080/ProyectService/Servlet?action=login";
EditText username;
EditText password;
AlertDialog dialog;
Usuario session;

@Override
public void onCreate(Bundle savedInstanceState) {
    // Inicializacion de ventana
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_login);
    getSupportActionBar().hide();

    // Inicializacion de componentes
    username = findViewById(R.id.username);
    password = findViewById(R.id.password);

    // Inicializacion de funcionalidad de botones
    Button button= (Button) findViewById(R.id.login);
    button.setOnClickListener(new View.OnClickListener() {
        public void onClick(View v) {
            UserLoginTask mAuthTask = new UserLoginTask();
            mAuthTask.execute();
        }
    });

    password = findViewById(R.id.password);
    createAlertDialog("Usuario o Contraseña Incorrectos");
    }

    private void createAlertDialog(String message){
    AlertDialog.Builder builder = new AlertDialog.Builder(this);
    builder.setMessage(message)
            .setTitle("Error");
    dialog = builder.create();
    }



    // ASYNCRONUS NETWORK PROCESS

    public class UserLoginTask extends AsyncTask<String, String, String> {

    @Override
    protected void onPreExecute() {
    }


    @Override
    protected String doInBackground(String... params) {

        // implement API in background and store the response in current variable
        String current = "";
        try {
            URL url;
            HttpURLConnection urlConnection = null;
            try {
                url = new URL(apiUrl);
                System.out.println(apiUrl);
                urlConnection = (HttpURLConnection) url
                        .openConnection();

                InputStream in = urlConnection.getInputStream();

                InputStreamReader isw = new InputStreamReader(in);

                int data = isw.read();
                while (data != -1) {
                    current += (char) data;
                    data = isw.read();
                    //System.out.print(current);

                }
                System.out.print(current);
                // return the data to onPostExecute method
                return current;

            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                if (urlConnection != null) {
                    urlConnection.disconnect();
                }
            }

        } catch (Exception e) {
            e.printStackTrace();
            return "Exception: " + e.getMessage();
        }
        return current;
        }
    }

    protected void onPostExecute(String success) {
        Log.i(success, "");
       //attemptLogin();
    }
}

Я ожидаю, что он прочитает данные, но он вылетает в этой строке:

InputStream in = urlConnection.getInputStream();

Это вывод ошибки:

java.net.SocketException: socket failed: EPERM (Operation not permitted)
at java.net.Socket.createImpl(Socket.java:492)
at java.net.Socket.getImpl(Socket.java:552)
at java.net.Socket.setSoTimeout(Socket.java:1180)
at com.android.okhttp.internal.io.RealConnection.connectSocket(RealConnection.java:143)
at com.android.okhttp.internal.io.RealConnection.connect(RealConnection.java:116)
at com.android.okhttp.internal.http.StreamAllocation.findConnection(StreamAllocation.java:186)
at com.android.okhttp.internal.http.StreamAllocation.findHealthyConnection(StreamAllocation.java:128)
at com.android.okhttp.internal.http.StreamAllocation.newStream(StreamAllocation.java:97)
at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:289)
at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:232)
at com.android.okhttp.internal.huc.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:465)
at com.android.okhttp.internal.huc.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:411)
at com.android.okhttp.internal.huc.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:248)
at com.example.controller.LoginActivity$UserLoginTask.doInBackground(LoginActivity.java:114)
at com.example.controller.LoginActivity$UserLoginTask.doInBackground(LoginActivity.java:93)
at android.os.AsyncTask$3.call(AsyncTask.java:378)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:289)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:919)
Аарон Вильялобос
источник

Ответы:

395

Решено: все, что мне нужно было сделать, это удалить приложение из эмулятора и запустить его снова.

Аарон Вильялобос
источник
8
это сработало и для меня, когда-нибудь выяснилось, почему это вообще происходит?
Викас Панди
9
В моем случае мне пришлось предоставить разрешение ACCESS_NETWORK_STATE. Добавьте в манифест <uses-permission android: name = "android.permission.ACCESS_NETWORK_STATE" />. И удалить тоже
sk md
3
Тоже самое. Странно, что вопрос такой молодой. Может это ошибка.
user1511417 01
1
Удаление приложения из эмулятора и повторная установка решила мою проблему, спасибо. Кажется, что firebase кеширует что-то в файловой системе и повторно использует это, я полагаю, что чистые данные приложения также решат проблему.
Onregs
1
возможно, разрешения уже кэшированы и разрушают его снова и снова, а не обновляют разрешение, а не обновляют только файлы src.? вот и помогла переустановка.
Atif AbbAsi
38

просто удалите приложение из эмулятора, затем запустите снова, и оно будет работать, у меня была такая же проблема

чтобы удалить приложение, запустите проект, когда появится сообщение «приложение остановлено» нажмите «информация о приложении», затем удалите

Джон Александр
источник
1
Не знаю как, но это работает. Публикация в декабре 2019 года. Хотя это работает, любопытно узнать, почему.
Rajkiran
30

Прежде всего вам нужно изменить свой манифест Android .xml. Но после этого действия вы должны удалить приложение и запустить его снова. https://developer.android.com/training/basics/network-ops/connecting

и код здесь:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

в AndroidManifest.xml

Арчил Лабадзе
источник
2
Верно, но если это уже установлено и по-прежнему возникает та же ошибка - сделайте, как было предложено выше, - удалите приложение на устройстве и установите его снова.
Владислав Варславанс
11

Мне пришлось удалить приложение из эмулятора, и все заработало. Мне просто нужно было следующее разрешение на AndroidManifest.xml

<uses-permission android:name="android.permission.INTERNET" />
Хуан Кабельо
источник
9
  1. Добавить разрешение ACCESS_NETWORK_STATE в манифест
  2. Эмулятор переустановки
Хабиб Аднан
источник
2

Устанавливается android:usesCleartextTraffic="true"в файле манифеста. Добавьте разрешение INTERNET. Удалите приложение, а затем установите его снова.

Ssenyonjo
источник
0

Если у кого-то все еще есть эта проблема, я столкнулся с ней, когда использовал VPN и пытался подключиться к Wi-Fi при включенной сотовой сети. Я использовал VPN-клиент Anyconnect. Решение состоит в том, чтобы включить разрешающий обход, который позволит вам привязать сокет к определенной сети, если это то, что вы ищете.

AnyConnect использует allowBypass, только если он настроен в своих управляемых ограничениях (с помощью EMM) с помощью этого ключа: vpn_connection_allow_bypass.

ovidiur
источник