我收到以下代码的细分错误。
我需要程序做的是,当输入无效/未知名称或服务作为参数时,它仅针对该特定服务显示错误,并继续在其余提供的服务上运行。
现在,如果我在某行服务中的任何地方包含无效服务(例如./dnslookup www.nhawurha.com www.google.com或www.google.com www.nhawurha.com),该程序都将起作用 >
但是,如果仅将无效服务用作唯一的参数(例如./dnslookup www.nhawurha.com),则会在打印错误后给我一个Segmentation Fault
非常感谢您提供任何帮助!
#include <arpa/inet.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <netdb.h>
#define BUFLEN 1500
int main(int argc, char *argv[]) {
struct addrinfo hints, *ai, *result;
char ipaddrv4[BUFLEN];
char ipaddrv6[BUFLEN];
int error;
if (argc < 2) {
fprintf(stderr, "Missing <hostname> after %s \n", argv[0]);
return 0;
}
for (int j = 1; j < argc; j++) {
memset(&hints, 0, sizeof(hints));
hints.ai_family = PF_UNSPEC; /* IPv4, IPv6, or anything */
hints.ai_socktype = SOCK_DGRAM; /* Dummy socket type */
error = getaddrinfo(argv[j], NULL, &hints, &result);
if (error) {
fprintf(stderr, "ERROR (%s: %s)\n", argv[j], gai_strerror(error));
continue;
}
for (ai = result; ai != NULL; ai = ai->ai_next) {
if (ai->ai_family == AF_INET) {
struct sockaddr_in *ipv4 = (struct sockaddr_in *) ai->ai_addr;
void *addr = &(ipv4->sin_addr);
inet_ntop(AF_INET, addr, ipaddrv4, BUFLEN);
printf("%s IPv4 %s\n", argv[j], ipaddrv4);
}
else if (ai->ai_family == AF_INET6) {
struct sockaddr_in6 *ipv6 = (struct sockaddr_in6 *) ai->ai_addr;
void *addr = &(ipv6->sin6_addr);
inet_ntop(AF_INET6, addr, ipaddrv6, BUFLEN);
printf("%s IPv6 %s\n", argv[j], ipaddrv6);
}
else {
continue;
}
}
}
freeaddrinfo(result);
return 0;
}
答案 0 :(得分:0)
看看'result'参数-如果一次唯一的查询失败,则结果将未初始化,并且freeaddrinfo
将会分段。尝试先将其初始化为NULL。
如果您进行了不止一次查找,则会遇到第二个问题-内存泄漏,因为您没有在每个结果上都调用freeaddrinfo
。
所以我认为您的逻辑应该更像:
for each command line arg
if lookup succeeds
print result
free result
else
print error
有关getaddrinfo
,请参见man page