java.net.SocketException: ซ็อกเก็ตล้มเหลว: EPERM (ไม่อนุญาตให้ดำเนินการ)


145

ฉันกำลังทำโปรเจ็กต์ Android Studio ที่มีกิจกรรมมากมาย ขณะนี้ฉันพยายามอ่านผลลัพธ์จาก Java Servlet บน localhost แต่ดูเหมือนว่าจะหยุดทำงานเนื่องจากได้รับอนุญาตจากซ็อกเก็ต

ฉันได้สร้างโปรเจ็กต์ใหม่โดยใช้รหัสเดียวกันและทำงานได้อย่างสมบูรณ์ ดังนั้นฉันไม่เข้าใจว่าทำไมไม่เต็มใจที่จะทำงานในโครงการของฉัน

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)

คำตอบ:


396

แก้ไขแล้ว: สิ่งที่ฉันต้องทำคือถอนการติดตั้งแอปจากโปรแกรมจำลองและเรียกใช้อีกครั้ง


8
มันได้ผลสำหรับฉันเช่นกันเคยพบว่าทำไมมันถึงเกิดขึ้นตั้งแต่แรก?
Vikas Pandey

9
ในกรณีของฉันฉันต้องให้สิทธิ์ ACCESS_NETWORK_STATE เพิ่ม <ใช้สิทธิ์ android: name = "android.permission.ACCESS_NETWORK_STATE" /> ไปยังรายการ และถอนการติดตั้งด้วย
sk md

3
เหมือนกันที่นี่ เป็นเรื่องแปลกที่คำถามนี้เด็กมาก บางทีนี่อาจเป็นจุดบกพร่อง
user1511417

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
จริงแม้ว่าจะตั้งค่าไว้แล้วและยังคงได้รับข้อผิดพลาดเดียวกันให้ทำตามที่แนะนำข้างต้น - ลบแอปบนอุปกรณ์และติดตั้งอีกครั้ง
Vladislav Varslavans

11

ฉันต้องถอนการติดตั้งแอพจากโปรแกรมจำลองจากนั้นทุกอย่างก็เริ่มทำงาน ฉันแค่ต้องได้รับอนุญาตต่อจาก AndroidManifest.xml

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

9
  1. เพิ่มสิทธิ์ ACCESS_NETWORK_STATE ในรายการ
  2. โปรแกรมจำลองการติดตั้งใหม่

3

ตั้งค่า android:usesCleartextTraffic="true"ในไฟล์รายการ INTERNETเพิ่มอนุญาต ถอนการติดตั้งแอพแล้วติดตั้งอีกครั้ง


0

หากใครยังคงมีปัญหานี้ฉันพบเมื่อฉันใช้ VPN และพยายามเชื่อมต่อกับ wifi ในขณะที่เซลลูลาร์เปิดอยู่ ฉันใช้ไคลเอนต์ Anyconnect VPN วิธีแก้ปัญหาคือการเปิดใช้งาน allow bypass ที่จะช่วยให้คุณผูกซ็อกเก็ตกับเครือข่ายเฉพาะหากนี่คือสิ่งที่คุณกำลังมองหา

AnyConnect ใช้ allowBypass ก็ต่อเมื่อมีการกำหนดค่าในข้อ จำกัด ที่มีการจัดการ (โดย EMM) โดยใช้คีย์นี้: vpn_connection_allow_bypass

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.