免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4846 | 回复: 2
打印 上一主题 下一主题

gethostbyaddr总是返回NULL [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-16 22:19 |只看该作者 |倒序浏览
10可用积分
char * host_name="220.181.38.82";///百度音乐盒网址http://220.181.38.82
struct in_addr addr;

if(inet_pton(AF_INET,host_name,(void*)&addr)==-1)
{
                        perror("phost");
                        exit(1);
}

if((host = gethostbyaddr((char *)&addr, 4, AF_INET))==NULL)
{
                        perror("gethostbyaddr");
                        exit(1);
}

失败。为什么啊?

即是解析主机IP地址都是失败的。
说明一下,我在虚拟机下的linux系统下做的。

论坛徽章:
0
2 [报告]
发表于 2008-07-17 12:12 |只看该作者
程序没有问题。
gethostbyaddr是查询反向解析域, 就是根据ip通过DNS查出域名来,
如果DNS没有配置你输入的ip地址的反向解析域, 就查不出来,

论坛徽章:
0
3 [报告]
发表于 2008-07-17 12:22 |只看该作者
反向域名解析的意义:

最重要的解释就是这个IP地址的网络身份是被认可的。


反向域名解析的大体过程:

IP地址为a.b.c.d
查询时先向in-addr.arpa.域查询a.in-addr.arpa.域
返回一个ns地址,中国一般是apnic的dns
再向apnic的dns查询b.a.in-addr.arpa.域
返回一个ns地址,一般是isp的dns
再向isp的dns查询c.b.a.in-addr.arpa.域
返回一个ns地址,一般还是isp的dns或者授权后的dns
最后向这个dns查询d.c.b.a.in-addr.arpa.既c.b.a.in-addr.arpa.域中的记录d
返回一个对应的地址

在中国一般到isp这里以后in-addr.arpa.域的ns记录就没有了


网上找了一段:

一般反向解析是和IP地址分配有联系的,所以isp直接申请反向解析的授权很难得到。而电信运营商在这方面就具备天然优势,通常这个授权都会直接授予本地的电信运营商(当然,电信运营商也要去申请才可以),然后再由电信运营商授予各个使用此IP地址的isp(当然,这个isp至少要完全占有整个C类地址的使用权,否则不会得到授权),或者由电信运营商自己的DNS来提供相应IP地址的反向解析服务。

解释一下,由于反向解析的记录格式是:
d.c.b.a.in-addr.arpa (IP地址是a.b.c.d)
它的体系及解析过程是和正向解析同样的,所以还是由根开始查询下一级的NS记录,直至查到 c.b.a.in-addr.arpa 的NS记录,再在此记录的DNS服务器上查询 d.c.b.a.in-addr.arpa 的 PTR记录,所以拥有反向解析授权的DNS服务器一定是有限的且授权的最小单位为一个C类地址段
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP