2013-05-17 104 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,这就是我一直在做:)谢谢 –