LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 1245|回复: 7

简单socket编程,连接时出错(附详细过程)

[复制链接]
发表于 2006-10-12 18:33:21 | 显示全部楼层 |阅读模式
系统:fedora core 5
防火墙:disabled
SELinux:disabled

服务器端程序

  1. /* server */
  2. #include <stdio.h>
  3. #include <sys/types.h>
  4. #include <netinet/in.h>
  5. #include <sys/socket.h>
  6. #include <netdb.h>
  7. #include <unistd.h>
  8. #include <string.h>
  9. #include <arpa/inet.h>

  10. #define PORT 8848
  11. #define BACKLOG 1

  12. main()
  13. {
  14.         int listenfd,connectfd;
  15.         struct sockaddr_in server;
  16.         struct sockaddr_in client;
  17.         int sin_size;

  18.         if (( listenfd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
  19.         {
  20.                 perror("Creating socket failed.");
  21.                 return 0;
  22.         }

  23.         int opt = SO_REUSEADDR;
  24.         setsockopt(listenfd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));

  25.         bzero(&server,sizeof(server));
  26.         server.sin_family = AF_INET;
  27.         server.sin_port = htons(PORT);
  28.         server.sin_addr.s_addr = htonl(INADDR_ANY);

  29.         printf("binding...\n");
  30.         if(bind(listenfd, (struct sockaddr *)&server, sizeof(struct sockaddr)) == -1) {
  31.                 perror("Bind error");
  32.                 return 0;
  33.         }

  34.         printf("listen...\n");
  35.         if(listen(listenfd,BACKLOG) == -1){
  36.                 perror("listen() error\n");
  37.                 return 0;
  38.         }
  39.         printf("accept....\n");
  40.         sin_size = sizeof(struct sockaddr_in);
  41.         if ((connectfd = accept(listenfd, (struct sockaddr *)&client,(socklen_t *) &sin_size)) == -1) {
  42.                 perror("accept() error\n");
  43.                 return 0;
  44.         }
  45.         printf("you got a connection from %s\n",inet_ntoa(client.sin_addr) );
  46.         send(connectfd,"welcome to my server.\n",22,0);
  47.         close(connectfd);
  48.         close(listenfd);
  49. }

复制代码


客户端程序

  1. /* client */
  2. #include <stdio.h>
  3. #include <sys/types.h>
  4. #include <netinet/in.h>
  5. #include <sys/socket.h>
  6. #include <netdb.h>
  7. #include <unistd.h>
  8. #include <string.h>
  9. #include <arpa/inet.h>

  10. #define PORT 8848
  11. #define MAXDATASIZE 100

  12. int main(int argc, char *argv[])
  13. {
  14.         int fd, numbytes;
  15.         char buf[MAXDATASIZE];
  16.         struct hostent *he;
  17.         int errno;
  18.         struct sockaddr_in server;

  19.         if(argc != 2) {
  20.                 printf("usage: %s <ip address>\n",argv[0]);
  21.                 return 0;
  22.         }
  23.         printf("gethostbynem....\n");
  24.         if ((he = gethostbyname(argv[1]))==NULL){
  25.                 printf("gethostbyname() error\n");
  26.                 return 0;
  27.         }
  28.         printf("code changed\n");
  29.         bzero(&server,sizeof(server));
  30.         server.sin_family = AF_INET;
  31.         server.sin_port = htons(PORT);
  32.         server.sin_addr.s_addr = inet_addr("127.0.0.1");

  33.         printf("connecting...\n");
  34.         if(connect(fd, (struct sockaddr *)&server,sizeof(struct sockaddr)) == -1){
  35.                 fprintf(stderr,"connect() error:%d\a\n",errno);
  36.                 return 0;
  37.         }

  38.         if(( numbytes = recv(fd,buf,MAXDATASIZE,0)) == -1){
  39.                 printf("recv() error\n");
  40.                 return 0;
  41.         }
  42.         buf[numbytes] = '\0';
  43.         printf("server message:%s\n",buf);

  44.         close(fd);
  45. }
复制代码




[root@localhost tcpsocket]# ls
help  tcpsocketC.c  tcpsocketS.c
[root@localhost tcpsocket]# g++ -g -o myserver tcpsocketS.c -lc -lnsl
[root@localhost tcpsocket]# g++ -g -o myclient tcpsocketC.c -lc -lnsl
[root@localhost tcpsocket]# ls
help  myclient  myserver  tcpsocketC.c  tcpsocketS.c
[root@localhost tcpsocket]# ./myserver
binding...
listen...
accept....

再开一个终端
[root@localhost tcpsocket]# netstat -a | grep 8848
tcp        0      0 *:8848                      *:*                         LISTEN
[root@localhost tcpsocket]# ifconfig
eth0      Link encap:Ethernet  HWaddr 00:134:3E:9F:89
          inet addr:125.221.160.241  Bcast:125.221.160.255  Mask:255.255.255.0
          inet6 addr: fe80::213:d4ff:fe3e:9f89/64 Scopeink
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:39108 errors:0 dropped:0 overruns:0 frame:0
          TX packets:46 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:2359238 (2.2 MiB)  TX bytes:4040 (3.9 KiB)
          Interrupt:17 Base address:0xa000

lo        Link encapocal Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:2005 errors:0 dropped:0 overruns:0 frame:0
          TX packets:2005 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:2078171 (1.9 MiB)  TX bytes:2078171 (1.9 MiB)

[root@localhost tcpsocket]# ./myclient 127.0.0.1
gethostbynem....
code changed
connecting...
connect() error:1223548480
[root@localhost tcpsocket]# ./myclient 125.221.160.241
gethostbynem....
code changed
connecting...
connect() error:1223548480
[root@localhost tcpsocket]#


ping 127.0.0.1
ping 125.221.160.241
都是通的。

那到底是程序出错了,还是FC5的环境配置有问题?
发表于 2006-10-12 21:11:16 | 显示全部楼层
错误信息好奇怪
不能用perror把错误信息打印出来吗
回复 支持 反对

使用道具 举报

发表于 2006-10-12 21:14:34 | 显示全部楼层
请使用code标签
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-10-12 21:38:16 | 显示全部楼层
哦,那个错误信息里的数字是那个样子,应该是因为没定errno没有被赋值。错误处理函数我不太会。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-10-12 22:25:03 | 显示全部楼层
在客户端connect()函数后面加了一个perror("error");
运行后是这个错:
[root@localhost tcpsocket]# ./myclient 127.0.0.1
gethostbynem....
code changed
connecting...
error: Bad file descriptor

客户端:

  1. #include <stdio.h>
  2. #include <sys/types.h>
  3. #include <netinet/in.h>
  4. #include <sys/socket.h>
  5. #include <netdb.h>
  6. #include <unistd.h>
  7. #include <string.h>
  8. #include <arpa/inet.h>
  9. #include <errno.h>
  10. #define PORT 8848
  11. #define MAXDATASIZE 100

  12. int main(int argc, char *argv[])
  13. {
  14.         int fd, numbytes;
  15.         char buf[MAXDATASIZE];
  16.         struct hostent *he;
  17.         int errno;
  18.         struct sockaddr_in server;

  19.         if(argc != 2) {
  20.                 printf("usage: %s <ip address>\n",argv[0]);
  21.                 return 0;
  22.         }
  23.         printf("gethostbynem....\n");
  24.         if ((he = gethostbyname(argv[1]))==NULL){
  25.                 printf("gethostbyname() error\n");
  26.                 return 0;
  27.         }
  28.         printf("code changed\n");
  29.         bzero(&server,sizeof(server));
  30.         server.sin_family = AF_INET;
  31.         server.sin_port = htons(PORT);
  32.         server.sin_addr = *((in_addr*)he->h_addr);
  33.         printf("connecting...\n");
  34.         if(connect(fd, (struct sockaddr *)&server,sizeof(struct sockaddr)) == -1){
  35.         //        printf("connect() error\n");
  36.                 perror("error");
  37.                 return 0;
  38.         }

  39.         if(( numbytes = recv(fd,buf,MAXDATASIZE,0)) == -1){
  40.                 printf("recv() error\n");
  41.                 return 0;
  42.         }
  43.         buf[numbytes] = '\0';
  44.         printf("server message:%s\n",buf);

  45.         close(fd);
  46. }

复制代码
回复 支持 反对

使用道具 举报

发表于 2006-10-12 23:05:10 | 显示全部楼层
客户端代码中没有调用socket初始化fd。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-10-12 23:27:45 | 显示全部楼层
谢谢了~
看来以后不能熬夜搞了,头脑不清楚。。。。。。。
回复 支持 反对

使用道具 举报

发表于 2006-10-13 09:28:41 | 显示全部楼层
其实perror挺好用的
一般会指出你的错误  然后就好说了  HOHO
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表