daytimetcpcli2.c 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #include "unp.h"
  2. int
  3. main(int argc, char **argv)
  4. {
  5. int sockfd, n;
  6. char recvline[MAXLINE + 1];
  7. struct sockaddr_in servaddr;
  8. struct in_addr **pptr, *addrs[2];
  9. struct hostent *hp;
  10. struct servent *sp;
  11. if (argc != 3)
  12. err_quit("usage: daytimetcpcli2 <hostname> <service>");
  13. bzero(&servaddr, sizeof(servaddr));
  14. servaddr.sin_family = AF_INET;
  15. if (inet_pton(AF_INET, argv[1], &servaddr.sin_addr) == 1) {
  16. addrs[0] = &servaddr.sin_addr;
  17. addrs[1] = NULL;
  18. pptr = &addrs[0];
  19. } else if ( (hp = gethostbyname(argv[1])) != NULL) {
  20. pptr = (struct in_addr **) hp->h_addr_list;
  21. } else
  22. err_quit("hostname error for %s: %s", argv[1], hstrerror(h_errno));
  23. if ( (n = atoi(argv[2])) > 0)
  24. servaddr.sin_port = htons(n);
  25. else if ( (sp = getservbyname(argv[2], "tcp")) != NULL)
  26. servaddr.sin_port = sp->s_port;
  27. else
  28. err_quit("getservbyname error for %s", argv[2]);
  29. for ( ; *pptr != NULL; pptr++) {
  30. sockfd = Socket(AF_INET, SOCK_STREAM, 0);
  31. memmove(&servaddr.sin_addr, *pptr, sizeof(struct in_addr));
  32. printf("trying %s\n",
  33. Sock_ntop((SA *) &servaddr, sizeof(servaddr)));
  34. if (connect(sockfd, (SA *) &servaddr, sizeof(servaddr)) == 0)
  35. break; /* success */
  36. err_ret("connect error");
  37. close(sockfd);
  38. }
  39. if (*pptr == NULL)
  40. err_quit("unable to connect");
  41. while ( (n = Read(sockfd, recvline, MAXLINE)) > 0) {
  42. recvline[n] = 0; /* null terminate */
  43. Fputs(recvline, stdout);
  44. }
  45. exit(0);
  46. }