无法从终端设置Ad-hoc网络

时间:2013-03-01 18:05:49

标签: c linux sockets networking adhoc

我正在尝试连接到我在无线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;
}

1 个答案:

答案 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。