2013-05-17 187 views
1

對我的Android應用程序使用MYSQL:Android Java應用程序 - java.net.SocketException:權限被拒絕

MainActivity。

public class MainActivity extends Activity implements OnClickListener { 

Button login; 
EditText username, password; 
TextView status; 
HttpPost httppost; 
StringBuffer buffer; 
HttpResponse response; 
HttpClient httpclient; 
List<NameValuePair> nameValuePair; 


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

    setup(); 
} 

private void setup() { 
    // TODO Auto-generated method stub 

    username = (EditText) findViewById(R.id.username); 
    password = (EditText) findViewById(R.id.password); 
    login = (Button) findViewById(R.id.login); 
    status = (TextView) findViewById(R.id.status); 
    login.setOnClickListener(this); 
} 

@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.main, menu); 
    return true; 
} 

@Override 
public void onClick(View v) { 
    // TODO Auto-generated method stub 

    switch(v.getId()) { 
    case R.id.login: 

     login(); 

     break; 
    } 
    } 

private void login() { 
    // TODO Auto-generated method stub 
    try { 
     httpclient= new DefaultHttpClient(); 
     httppost= new HttpPost("http://109.74.245.109/~profiled/android/index.php"); 
    // Adding Data: 
     nameValuePair = new ArrayList<NameValuePair>(1); 
    // Always use the same variable name for posting i.e the android side variable name and php side variable name should be similar, 
     nameValuePair.add(new BasicNameValuePair("username",username.getText().toString().trim())); 
     nameValuePair.add(new BasicNameValuePair("password",password.getText().toString().trim())); 
     httppost.setEntity(new UrlEncodedFormEntity(nameValuePair)); 
    // Execute HTTP Post Request 
     response = httpclient.execute(httppost); 



     ResponseHandler<String> responseHandler = new BasicResponseHandler(); 
     final String response = httpclient.execute(httppost, responseHandler); 
     status.setText(""+response); 
     if(response.equalsIgnoreCase("No user found")) { 

      startActivity(new Intent(MainActivity.this, UserPage.class)); 
     } 


     }catch (Exception e) { 
      e.printStackTrace(); 
     } 
    } 
} 

這是我的錯誤:

05-17 13:39:25.309: W/System.err(292): java.net.SocketException: Permission denied 
05-17 13:39:25.318: W/System.err(292): at org.apache.harmony.luni.platform.OSNetworkSystem.createStreamSocketImpl(Native Method) 
05-17 13:39:25.318: W/System.err(292): at org.apache.harmony.luni.platform.OSNetworkSystem.createStreamSocket(OSNetworkSystem.java:186) 
05-17 13:39:25.318: W/System.err(292): at org.apache.harmony.luni.net.PlainSocketImpl.create(PlainSocketImpl.java:265) 
05-17 13:39:25.318: W/System.err(292): at java.net.Socket.checkClosedAndCreate(Socket.java:873) 
05-17 13:39:25.318: W/System.err(292): at java.net.Socket.connect(Socket.java:1020) 
05-17 13:39:25.333: W/System.err(292): at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119) 
05-17 13:39:25.337: W/System.err(292): at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:143) 
05-17 13:39:25.337: W/System.err(292): at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 
05-17 13:39:25.337: W/System.err(292): at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 
05-17 13:39:25.337: W/System.err(292): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:348) 
05-17 13:39:25.337: W/System.err(292): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 
05-17 13:39:25.337: W/System.err(292): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 
05-17 13:39:25.337: W/System.err(292): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 
05-17 13:39:25.337: W/System.err(292): at com.profiledt.helloworld.MainActivity.login(MainActivity.java:88) 
05-17 13:39:25.337: W/System.err(292): at com.profiledt.helloworld.MainActivity.onClick(MainActivity.java:70) 
05-17 13:39:25.337: W/System.err(292): at android.view.View.performClick(View.java:2408) 
05-17 13:39:25.337: W/System.err(292): at android.view.View$PerformClick.run(View.java:8816) 
05-17 13:39:25.337: W/System.err(292): at android.os.Handler.handleCallback(Handler.java:587) 
05-17 13:39:25.337: W/System.err(292): at android.os.Handler.dispatchMessage(Handler.java:92) 
05-17 13:39:25.357: W/System.err(292): at android.os.Looper.loop(Looper.java:123) 
05-17 13:39:25.357: W/System.err(292): at android.app.ActivityThread.main(ActivityThread.java:4627) 
05-17 13:39:25.357: W/System.err(292): at java.lang.reflect.Method.invokeNative(Native Method) 
05-17 13:39:25.357: W/System.err(292): at java.lang.reflect.Method.invoke(Method.java:521) 
05-17 13:39:25.357: W/System.err(292): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
05-17 13:39:25.357: W/System.err(292): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
05-17 13:39:25.357: W/System.err(292): at dalvik.system.NativeStart.main(Native Method) 

我不完全理解的錯誤,但它是權限,我來了幾個結論:

  • 它無法連接到mysql數據庫
  • 有關IP地址和我的服務器?
+0

您的清單文件中是否設置了INTERNET權限? https://developer.android.com/reference/android/Manifest.permission.html – Mateusz

+0

嗨Mateusz,我已經添加了下面的人建議。仍然不能正常工作 –

+0

[錯誤消息'java.net.SocketException:socket failed:EACCES(Permission denied)']可能重複(http://stackoverflow.com/questions/11273197/error-message-java-net-socketexception- socket-failed-eacces-permission-denie) – William

回答

4

將此添加到您的清單並檢查。

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

爲什麼要訪問網絡狀態?它需要互聯網權限而不是網絡狀態才能訪問內部 – DArkO

+0

更正,謝謝! –

+0

嗨,我添加到activity_main.xml和應用程序不會運行,我得到這個: 很多錯誤:http://pastebin.com/xZSAtnj6 –

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

此外,我寫了一個庫,可以幫助你在不同的線程做到這一點,而不是你正在做的(在UI線程中運行的請求)的東西。

也許你會喜歡它。如果不是有其他的選擇了

https://github.com/darko1002001/android-rest-client

希望這有助於。

編輯

有在作怪通常2個組件。您不直接連接到數據庫,而是在您的案例中創建一個PHP腳本,它將連接到數據庫並充當WebService,它可以接受請求並返回JSON。 Android應用程序充當客戶端,它調用連接到數據庫的PHP Web服務,讀取並返回結果。

所以你必須:

客戶端(安卓)< - > Web服務(PHP)< - > MySQL數據庫

Android不直接進入數據庫。

一個簡單的測試就是PC瀏覽器。如果你輸入完整的url並在瀏覽器中按回車,你應該得到與你在android上一樣的確切響應。

這意味着您已對所有瀏覽器輸入操作執行GET請求到您的Web服務。

在你的情況看起來你正在做一個POST請求。

閱讀REST Web服務上的一些技巧,以獲得關於如何設置它的更多信息。

希望這會有所幫助。

+0

嗨DArkO,我還是有點新,所有這一切,這將允許我連接到一個MySQL數據庫並回顯出所有的信息? 謝謝 –

+0

編輯我的答案。 – DArkO

+0

嘿DArkO,這就是我一直在做:)謝謝 –