whois域名查询

 <?
class SearchDomain
{
        var $domain="";
        function SetDomain($udomain)
        {
                $this->domain = $udomain;
        }
        //
        // 获取whois并分析域名状态
        // ok 未被注册
        // 非空值 过期时间
        // 空值 未知
        //
        function GetInfo()
        {
                /*
                $dinfo = trim($this->GetWhois());
                if($dinfo=="") return "";
                if(eregi("no match",$dinfo)) return "ok";
        //return $rs;
        */
        $wl = "";
                $w_server = $this->GetServer();
                if($w_server=="") return "";
                $fp = fsockopen($w_server, 43, $errno, $errstr, 30);
                if(!$fp)
                {
                        echo $errstr;
                        return "";
                }
                  $out = $this->domain."/r/n";
              $out .= "Connection: Close/r/n/r/n";
              fputs($fp, $out);
              while (!feof($fp))
              {
                $wl = fgets($fp, 255);
                if(eregi("no match",$wl))
                {
                        fclose($fp);
                        return "ok";
                }
                if(eregi("Expiration Date",$wl))
                {
                        $lines = split(":",$wl);
                        $t = trim($lines[1]);
                        $ts = split(" ",$t);
                        $t = $ts[0];
                        if(ereg("[^0-9-]",$t))
                        {
                                $ts = split("-",$t);
                                $t = $ts[2]."-".$this->MonthToNum($ts[1])."-".$ts[0];
                        }
                        fclose($fp);
                        return $t;
                }
              }
              fclose($fp);
              return "";
          }
        //
        //获得域名的整个whois信息
        //
        function GetWhois()
        {
                $wh = "";
                $w_server = $this->GetServer();
                if($w_server=="") return "";
                $fp = fsockopen($w_server, 43, $errno, $errstr, 30);
                if(!$fp)
                {
                        echo $errstr;
                        return "";
                }
                  $out = $this->domain."/r/n";
              $out .= "Connection: Close/r/n/r/n";
              fputs($fp, $out);
              while (!feof($fp))
              {
                $wh .= nl2br(fgets($fp, 255));
              }
              fclose($fp);
              return $wh;
          }
          //
          //输出当前域名的状态信息
          //
          function PrintSta()
          {
                  $rs = $this->GetInfo();
                  if($rs=="ok") echo $this->domain." 未注册!<br/>/r/n";
                  else if($rs=="") echo "无法查询 ".$this->domain." 状态!<br/>/r/n";
                  else echo $this->domain." 已注册,到期时间:$rs<br/>/r/n";
          }
          //
          //获得 whois 查询服务器
          //
          function GetServer()
          {
                  $udomain=substr($this->domain,-3);
                  switch($udomain)
                  {
                    case "com":
                              $w_server="whois.internic.net";
                              break;
                    case "net":
                              $w_server="whois.internic.net";
                              break;
                        case "org":
                              $w_server="whois.pir.org";
                                break;
                    case "nfo":
                              $w_server="whois.afilias.info";
                              break;
                    case "biz":
                              $w_server="whois.biz";
                              break;
                    case ".cc":
                              $w_server="whois.nic.cc";
                              break;
                    case "edu":
                              $w_server="whois.educause.net";
                              break;
                    case "gov":
                              $w_server="whois.nic.gov";
                              break;
                    case ".cn":
                              $w_server="whois.cnnic.net.cn";
                              break;
                    default:
                                $w_server="";
                  }
                  return $w_server;
        }
        //
        //英语的月份转为数字
        //
        function MonthToNum($m)
        {
                $m = strtolower($m);
                for($i=1;$i<=12;$i++)
                {
                        $tt = mktime(0,0,0,$i+1,0,2005);
                        if($m==strtolower(strftime("%b",$tt)))
                        {
                                if($i>9) return $i-1;
                                else return "0".$i-1;
                        }
                }
        }
}


$sd = new SearchDomain();
$sd->SetDomain("job-sky.com");

//查询域名是否被注册,等价于 $sd->PrintSta();
$rs = $sd->GetInfo();
if($rs=="ok") echo $sd->domain." 未注册!<br/>/r/n";
else if($rs=="") echo "无法查询 ".$sd->domain." 状态!<br/>/r/n";
else echo $sd->domain." 已注册,到期时间:$rs<br/>/r/n";

//获得域名的详细whois信息
//echo $sd->GetWhois();

?>

 

???????????????????????????????????????????????????

asp代码

jjx原创,转载必须注明出处
要复制代码,请使用论坛的“复制“功能完成
chinaasp的域名查询要卖1000元,网友提了意见,却被吕科一句(你把他封装成组件试试?)给挡了回去。域名登记查询(whois)真的很复杂吗?

 

域名登记查询主要是通过whois服务器来完成的,当前比较常用的是rs.internic.net,通过它可以查询各种国际域名是否注册。whois的端口通常是43。利用winsock,你可以在asp简单的实现这个功能
asp不同于php/jsp,winsock功能并不内置,所以必须借助第三方的winsock组件。
这里的举例使用了serverobjects的aspsock,代码的注释比较详细,大家可以举一翻三
aspsock不是免费的,需要$49,如果需要免费的大家可以自己封装vb6中的winsock控件
或从这个地址下载免费的
Xceed Winsock Library v1.1
ftp://ftp.xceedsoft.com/pub/xceedwsl.exe
该组件的主页是
http://www.xceedsoft.com/

whois.asp
-------------------------------------------
<%@ Language=VBScript %>
<HTML>
<HEAD>
<META NAME="GENERATOR" Content="Microsoft Visual Studio 6.0">
</HEAD>
<BODY>
<form action=whois.asp method=post>
域名:www<B>.</B> <INPUT size=8 name=domainname value="<% =request("domainname") %>">. <SELECT name=ext> <OPTION
selected>com</OPTION> <OPTION>net</OPTION> <OPTION>org</OPTION>
</SELECT>
<INPUT class=input1 type=submit value=域名查询 name=Submit>
</form>

<%
dim strResult
if Request.ServerVariables("request_method")="POST" THEN
dim strQuery
'取得需要查询的域名
strQuery=request("domainname") & "." & request("ext")

dim objSock
'创建sock对象
Set objSock=Server.CreateObject("Aspsock.conn")
'设置whois服务器为rs.internic.net
objSock.RemoteHost="rs.internic.net"
'设置whois服务器端口为43
objSock.Port=43
'设置操作的超时为60秒
objSock.TimeOut=60
'打开与remotehost的连接,返回真为成功
if objSock.Open then
'发出查询 WriteLn表示用vbCrlf终结(strQuery & vbCRlf)
objSock.WriteLn strQuery
'读取返回值,最大长度为65535
strResult=objSock.ReadBytesAsString(65535)
'关闭连接
objSock.Close
'打印查询结果,你可以需要对此作些处理
Response.Write "<b>查询结果</b><br><textarea rows=10 cols=60>" & strResult & "</textarea>"
end if
Set objSock=Nothing

end if
%>

</BODY>
</HTML>

利用winsock可以完成许多asp不太可能完成的事情,比方像网易一样真正无刷新的聊天室,大家仔细研究研究吧

#################################

asp2

voodoo发表于 2000-06-03 22:42:07<%@ Language=VBScript %>
<HTML>
<HEAD>
<META NAME="GENERATOR" Content="Microsoft Visual Studio 6.0">
</HEAD>
<BODY>
<form action=whois.asp method=post>
域名:www<B>.</B> <INPUT size=8 name=domainname value="<% =request("domainname") %>">. <SELECT name=ext>
<OPTION selected>com</OPTION>
<OPTION>net</OPTION>
<OPTION>org</OPTION>
<OPTION>com.cn</OPTION> <OPTION>net.cn</OPTION> <OPTION>org.cn</OPTION>
</SELECT>
<INPUT class=input1 type=submit value=域名查询 name=Submit>
</form>

<%
dim strResult
if Request.ServerVariables("request_method")="POST" THEN
dim strQuery
'取得需要查询的域名
strQuery=request("domainname") & "." & request("ext")

 

dim objSock
'创建sock对象
Set objSock=Server.CreateObject("Aspsock.conn")
'设置whois服务器为rs.internic.net
select case request("ext")
case "com","net","org"
objSock.RemoteHost="rs.internic.net"
gj=0
case "com.cn","net.cn","org.cn"
objSock.RemoteHost="drop.cnnic.net.cn"
gj=1
end select
'设置whois服务器端口为43
objSock.Port=43
'设置操作的超时为60秒
objSock.TimeOut=60
'打开与remotehost的连接,返回真为成功
if objSock.Open then
'发出查询 WriteLn表示用vbCrlf终结(strQuery & vbCRlf)
objSock.WriteLn strQuery
'读取返回值,最大长度为65535
strResult=objSock.ReadBytesAsString(65535)
'关闭连接
objSock.Close
'打印查询结果,你可以需要对此作些处理
' Response.Write "<b>查询结果</b><br><textarea rows=10 cols=60>" & strResult & "</textarea>"
select case gj
case "0"
str1=inter(strresult)
response.write str1
Response.Write "<b>查询结果</b><br><textarea rows=10 cols=60>" & strResult & "</textarea>"
case "1"
str1=cnnic(strresult)
response.write str1
Response.Write "<b>查询结果</b><br><textarea rows=10 cols=60>" & strResult & "</textarea>"
end select
end if
Set objSock=Nothing

end if

function inter(str)
if instr(str,"No match")=0 then
response.write "您的域名已经被注册。"
else
response.write "您的域名没有被注册。"
end if
end function

function cnnic(str)
if instr(str,"%")=0 then
response.write "您的域名已经被注册。"
else
response.write "您的域名没有被注册。"
end if
end function
%>

</BODY>
</HTML>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值