1

我正在为一个大学项目制作一个简单的网络钓鱼扫描仪工具。我的一种检测方法包括检查电子邮件中的 DNS 是否有效,并且我还想检查它们的年龄。这是我如何检查它们是否存在的示例代码:

import javax.naming.NamingException;
import javax.naming.directory.Attribute;
import javax.naming.directory.Attributes;
import javax.naming.directory.DirContext;
import javax.naming.directory.InitialDirContext;
import java.util.Hashtable;

public class DNSExample {
    static int doLookup( String hostName ) throws NamingException {
        Hashtable env = new Hashtable();
        env.put("java.naming.factory.initial",
                "com.sun.jndi.dns.DnsContextFactory");
        DirContext ictx = new InitialDirContext( env );
        Attributes attrs =
                ictx.getAttributes( hostName, new String[] { "MX" });
        Attribute attr = attrs.get( "MX" );
        if( attr == null ) return( 0 );
        return( attr.size() );
    }

    public static void main( String args[] ) {

        String [] array = {"google.com","dsad33114sssaxzx.com"} ;
        for( int i = 0; i < array.length; i++ ) {
            try {
                System.out.println( array[i] + " has " +
                        doLookup( array[i] ) + " mail servers" );
            }
            catch( Exception e ) {
                System.out.println(array[i] + " : " + e.getMessage());
            }
        }
    }
}

我需要如何修改上述代码以检查现有服务器的年龄?

4

2 回答 2

1

根据您上面的描述和评论,您似乎正在尝试收集 whois 信息。

  1. 从http://commons.apache.org/proper/commons-net/下载 API
  2. 更改下面的 nameToQuery 并运行它。

公共类 WhoisIt {

public static final String WHOIS_SERVER = "whois.internic.net";
public static final int WHOIS_PORT = 43;

public static void main(String[] args) throws Exception {

    String nameToQuery = "avajava.com";

    WhoisClient whoisClient = new WhoisClient();
    whoisClient.connect(WHOIS_SERVER, WHOIS_PORT);
    String results = whoisClient.query(nameToQuery);

    System.out.println(results);
}
}

祝你好运

于 2013-03-02T01:48:23.843 回答
1

我认为您选择了一个在一般情况下无法解决的问题......使用当前一代互联网标准:

  1. 您需要的信息无法从 DNS 本身获得。
  2. 在某些情况下,可以从 WHOIS 获得有关 DNS 注册的信息。但是,WHOIS 服务器返回的信息不是标准化的:
    • 没有标准的信息模型。
    • 没有标准格式。
    • 不保证信息的准确性。
    • 甚至不清楚“服务器年龄”是否可用。(例如,APNIC 的 WHOIS 提供的最接近的是 DNS 记录的最后修改时间戳。这不是服务器年龄的良好代理。)
  3. 有一组 RFC 定义了一个叫做CRISP的东西,但据我所知,该标准的目的是让注册商与注册商交换信息。(我找不到任何基于 CRISP 的面向公众的服务。)
  4. 还有一个名为WEIRDS的 IETF 工作组,我认为它旨在为 WHOIS 定义一个支持网络的替代品。(不要将 WEIRDS 与 IETF WEIRD WG 混淆!)但这是最近才成立的,现在对结果做出任何预测还为时过早。(或者 NIC 需要多长时间来实施 WG 提出的任何规范。)

总结:你在这个领域实现真正有效的东西的机会目前很低。可能您希望达到的最好结果是基于屏幕抓取一两个 WHOIS 服务。

这可能会在几年内改变,但这对您当前的项目没有帮助。

于 2013-03-02T02:07:00.770 回答