java.net.SocketException : 소켓 실패 : EPERM (허용되지 않는 작업)


143

여러 활동이있는 Android Studio 프로젝트에서 작업 중입니다. 현재 localhost의 Java Servlet에서 출력을 읽으려고하지만 소켓 권한으로 인해 충돌하는 것 같습니다.

새 프로젝트를 만들고 똑같은 코드를 사용했고 완벽하게 작동했습니다. 그래서 나는 왜 내 프로젝트에서 기꺼이 일하지 않는지 이해하지 못합니다.

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)

답변:


393

해결됨 : 에뮬레이터에서 앱을 제거하고 다시 실행하기 만하면되었습니다.


8
그것은 나에게도 효과가 있었는데, 왜 그것이 처음에 일어나고 있었는지 발견 한 적이 있습니까?
Vikas Pandey

9
제 경우에는 ACCESS_NETWORK_STATE 권한을 제공해야했습니다. 매니페스트에 <uses-permission android : name = "android.permission.ACCESS_NETWORK_STATE"/>를 추가합니다. 그리고 제거도
SK MD가

3
여기도 마찬가지입니다. 질문이 너무 어려서 이상합니다. 아마도 이것은 버그 일 것입니다.
user1511417

1
에뮬레이터에서 응용 프로그램을 제거하고 다시 설치하면 문제가 해결되었습니다. firebase가 파일 시스템에 무언가를 캐시하고 재사용하는 것 같습니다. 명확한 애플리케이션 데이터도 문제를 해결할 것이라고 생각합니다.
Onregs

1
권한이 이미 캐시되어 있고 계속해서 망치는 것은 권한을 업데이트하지 않고 src 파일 만 업데이트하는 것입니다.? 다시 설치가 도움이되었습니다.
Atif AbbAsi

38

에뮬레이터에서 앱을 제거한 다음 다시 실행하면 동일한 문제가 발생했습니다.

"애플리케이션이 중지되었습니다"라는 메시지가 나타날 때 앱을 제거하려면 프로젝트를 실행하고 "앱 정보"를 클릭 한 다음 제거하십시오.


1
방법은 모르지만 작동합니다. 2019 년 12 월에 게시 중입니다. 작동하지만 이유를 알고 싶습니다.
Rajkiran

30

우선 안드로이드 매니페스트 .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
사실, 이미 설정되어 있지만 여전히 동일한 오류가 발생하면 위에서 제안한대로 수행하십시오. 장치에서 앱을 삭제하고 다시 설치하십시오.
Vladislav Varslavans

11

에뮬레이터에서 앱을 제거해야하고 모든 것이 작동하기 시작했습니다. AndroidManifest.xml에 대한 다음 권한이 필요했습니다.

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


2

android:usesCleartextTraffic="true"매니페스트 파일에서 설정 합니다. 권한을 추가하십시오 INTERNET. 앱을 제거한 다음 다시 설치하십시오.


0

누군가 여전히이 문제가 있으면 VPN을 사용하고 셀룰러가 켜져있는 동안 Wi-Fi에 연결하려고 할 때 발생했습니다. Anyconnect VPN 클라이언트를 사용하고있었습니다. 해결책은 소켓을 특정 네트워크에 바인딩 할 수있는 허용 우회를 활성화하는 것입니다.

AnyConnect는 vpn_connection_allow_bypass 키를 통해 관리 형 제한 (EMM에 의해)에 구성된 경우에만 allowBypass를 사용합니다.

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.