1

ワイヤレス アドホック ネットワーク上のコンピューターで C で実行しているサーバーに接続しようとしています。問題は、telnet を使用してネットワーク上の別のコンピューターから接続しようとすると、機能しないことです。IPアドレス(192.168.0.1)にpingを実行できますが、次を使用します:

 telnet 192.168.0.1 8889

「接続が拒否されました」というエラーが発生します(サーバーは確認済みのポート8889でリッスンしています)。

さらに調査したところ、ネットワーク マネージャーを使用してアドホック ネットワークを設定すると、この問題が解決することがわかりました。現在、ターミナル経由でアドホック ネットワークをセットアップしていますが、この方法を維持したいと考えています。アドホック ネットワークは、次のコマンドでセットアップされています。

 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;
}
4

1 に答える 1

0

正しい順序で物事を行う必要があると思います。

まず、ネットワーク インターフェイスをセットアップする必要があります。完了したら、ネットワーク インターフェイスに ping できること、およびファイアウォールがある場合はポート 8889 での着信接続を許可することを確認する必要があります。ファイアウォールが有効になっていることを確認するiptables -Lには、ルールがある場合はファイアウォールがあります。 . さらに、各ネットワーク インターフェイスに予想される IP アドレスがあることを確認してくださいifconfig

テスト目的で、安全なネットワークを使用している場合は、ファイアウォールを一時的に無効にすることができますiptables -F(スーパー ユーザー権限が必要な場合は、前に sudo を付けます)。

次に、サーバーを起動できます。( 経由でps wux)稼働していることを確認し、 経由でリスニング モードであることを確認しますnetstat -tlpen

を介して telnet で接続してみてくださいtelnet 192.168.0.1 8889

PS: もちろん、アドホック ネットワークは、ローカル ネットワークとは異なるサブネット上にある必要があります。そのため、イーサネット (ケーブル) ネットワークとアドホック Wi-Fi ネットワークの両方を使用している場合、それぞれが異なるサブネット上にある必要があります (例: 192.168.0.1/24 と 192.168.1.1/24)。

于 2013-03-03T08:06:22.710 に答える