服务器没有';无法从客户端(android)接收消息
我在neatbeans中尝试了我的客户机(客户机和服务器)代码,一切正常。然后我在EclipseSDK中编写了它,并试图在emulator中运行它,服务器不再接收消息 客户:服务器没有';无法从客户端(android)接收消息,android,client,Android,Client,我在neatbeans中尝试了我的客户机(客户机和服务器)代码,一切正常。然后我在EclipseSDK中编写了它,并试图在emulator中运行它,服务器不再接收消息 客户: package com.aaa.udep; import com.aaa.udep.Client; import com.aaa.udep.R; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import
package com.aaa.udep;
import com.aaa.udep.Client;
import com.aaa.udep.R;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
public class MainActivity extends Activity {
Button button;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button=(Button) findViewById(R.id.button1);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Thread thread=new Thread (new Client());
thread.start();
}
});
}
@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;
}
}
package com.aaa.udep;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketTimeoutException;
import java.net.UnknownHostException;
import android.util.Log;
public class Client implements Runnable {
Client()
{
run();
}
@Override
public void run() {
// TODO Auto-generated method stub
try {
Log.i("MyApp", "starting");
String messageStr = "Hello Android dolwno rabotatj, nado testirovatj na teelefone!";
String serverHostname = new String ("127.0.0.1");
DatagramSocket clientSocket = new DatagramSocket();
InetAddress IPAddress = InetAddress.getByName(serverHostname);
Log.i("MyApp", "Atempting to connect");
byte[] sendData = new byte[1024];
byte[] receiveData = new byte[1024];
sendData = messageStr.getBytes();
Log.d ("MyAPp","Sending data to server");
DatagramPacket sendPacket =
new DatagramPacket(sendData, sendData.length, IPAddress, 9879);
clientSocket.send(sendPacket);
Log.d ("MyAPp","Sent");
DatagramPacket receivePacket =
new DatagramPacket(receiveData, receiveData.length);
Log.d ("MyApp","Waiting for return packet");
clientSocket.setSoTimeout(10000);
try {
clientSocket.receive(receivePacket);
String modifiedSentence =
new String(receivePacket.getData());
InetAddress returnIPAddress = receivePacket.getAddress();
int port = receivePacket.getPort();
Log.d ("From server at get reply: ", serverHostname);
Log.d("Message: ", modifiedSentence );
}
catch (SocketTimeoutException ste)
{
ste.printStackTrace();
Log.e("Timeout Occurred: Packet assumed lost", ste+"");
}
clientSocket.close();
}
catch (UnknownHostException ex) {
ex.printStackTrace();
Log.e("UnknownHostException", ex+"");
}
catch (IOException ex) {
ex.printStackTrace();
Log.e("IO Expeption", ex+"");
}
}
}
manifest:
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.CHANGE_WIFI_MULTICAST_STATE" />
Android emulator与您的电脑不共享相同的IP地址,这意味着您不能使用环回IP 127.0.0.1并期望它连接到您的电脑。 Android emulator实例运行在一个虚拟LAN上,该LAN有自己的防火墙和子网,它可以通过该子网上的IP与您的PC进行通信 这是:
10.0.2.2
有关emulator网络的更多信息,请访问
希望这对您有所帮助它清楚地说明了连接超时。请确保您的网络连接可用,并且您的服务器正在大量响应请求sthx!这有助于:)
03-28 00:53:37.159: I/MyApp(337): starting
03-28 00:53:37.159: I/MyApp(337): Atempting to connect
03-28 00:53:37.220: D/MyAPp(337): Sending data to server
03-28 00:53:37.220: D/MyAPp(337): Sent
03-28 00:53:37.220: D/MyApp(337): Waiting for return packet
03-28 00:53:47.254: W/System.err(337): java.net.SocketTimeoutException: Connection timed out
03-28 00:53:47.860: W/System.err(337): at org.apache.harmony.luni.net.PlainDatagramSocketImpl.receive(PlainDatagramSocketImpl.java:263)
03-28 00:53:47.860: W/System.err(337): at java.net.DatagramSocket.receive(DatagramSocket.java:414)
03-28 00:53:47.870: W/System.err(337): at com.aaa.udep.Client.run(Client.java:51)
03-28 00:53:47.870: W/System.err(337): at java.lang.Thread.run(Thread.java:1096)
03-28 00:53:47.870: E/Timeout Occurred: Packet assumed lost(337): java.net.SocketTimeoutException: Connection timed out