我正在尝试连接到我在无线ad-hoc网络上的计算机上运行的服务器。问题是当我使用telnet从网络上的另一台计算机连接时,它不起作用。我可以ping IP地址(192.168.0.1),但使用:
telnet 192.168.0.1 8889
导致错误“Connection Refused”(服务器正在侦听已验证的端口8889)。
我进一步调查并发现使用网络管理器设置我的ad-hoc网络解决了这个问题。目前我正在通过终端建立我的ad-hoc网络,我想保持这种方式。正在使用以下命令设置ad-hoc网络:
sudo service network-manager stop
sudo iwconfig wlan0 mode ad-hoc essid 'rgd' channel AUTO key OFF
wlan0是我的无线设备。 我不确定为什么会出现这种错误。有人可以帮我吗?
编辑:@Huygens netstat -tlpen显示以下内容
Proto Recv-Q Send-Q Local Address Foreign Address State User Inode PID/Program name
tcp 0 0 0.0.0.0:48727 0.0.0.0:* LISTEN 1000 302920 13098/socket
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN 0 273220 933/cupsd
tcp 0 0 0.0.0.0:54880 0.0.0.0:* LISTEN 1000 304089 13148/socket
tcp 0 0 127.0.1.1:53 0.0.0.0:* LISTEN 0 12886 1606/dnsmasq
tcp6 0 0 ::1:631 :::* LISTEN 0 273219 933/cupsd
tcp6 0 0 ::1:54822 :::* LISTEN 1000 46736 3297/java
由于某种原因,我在这里看不到我的服务器:(
我已经添加了我在这里运行的服务器代码以供进一步参考:
#include<stdio.h>
#include<string.h> //strlen
#include<sys/socket.h>
#include<arpa/inet.h> //inet_addr
#include<unistd.h> //write
int main(int argc , char *argv[])
{
int socket_desc , new_socket , c;
struct sockaddr_in server , client;
char *message;
//Create socket
socket_desc = socket(AF_INET , SOCK_STREAM , 0);
if (socket_desc == -1)
{
printf("Could not create socket");
}
//Prepare the sockaddr_in structure
server.sin_family = AF_INET;
server.sin_addr.s_addr = INADDR_ANY;
server.sin_port = htons( 8889 );
//Bind
if( bind(socket_desc,(struct sockaddr *)&server , sizeof(server)) < 0)
{
puts("bind failed");
return 1;
}
puts("bind done");
//Listen
listen(socket_desc , 3);
//Accept and incoming connection
puts("Waiting for incoming connections...");
c = sizeof(struct sockaddr_in);
new_socket = accept(socket_desc, (struct sockaddr *)&client, (socklen_t*)&c);
if (new_socket<0)
{
perror("accept failed");
return 1;
}
puts("Connection accepted");
//Reply to the client
message = "Hello Client , I have received your connection. But I have to go now, bye\n";
write(new_socket , message , strlen(message));
return 0;
}
答案 0 :(得分:0)
你必须按照我想的正确顺序做事。
首先,您应该设置网络接口。完成后,您应检查是否可以ping网络接口,如果您有防火墙,它将允许端口8889上的传入连接。要查看您已激活防火墙:iptables -L
如果有任何规则,然后你有防火墙。此外,请确保每个网络接口都具有预期的IP地址:ifconfig
。
出于测试目的,如果您在安全的网络上,可以暂时禁用防火墙:iptables -F
(如果您需要超级用户权限,则在sudo之前)。
然后,您可以启动您的服务器。检查它是否已启动并正在运行(通过ps wux
)并通过netstat -tlpen
检查它是否处于聆听模式。
现在尝试通过telnet 192.168.0.1 8889
远程登录。
PS:当然,您的ad-hoc网络应该与本地网络位于不同的子网上。因此,如果您同时使用以太网(有线)网络和ad-hoc wifi网络,则每个网络都应位于不同的子网上:例如192.168.0.1/24和192.168.1.1/24。