急求:网络端口扫描源程序(100分)

  • 主题发起人 badpanda
  • 开始时间
B

badpanda

Unregistered / Unconfirmed
GUEST, unregistred user!
一个简单得端口扫描功能即可!
谢谢了![:(][:(][:(][blue][/blue]
 
只需要一个简单得功能即可,但希望能有详细得注释,因为是给一个delphi菜鸟看得,现在对delphi热情特高,希望不要让他冷却了,谢谢大家了^_^
 
果你写扫描程序可千万不要直接去连接,应该使用别的链接方法,否则你的踪迹会被别人
发现.例如使用sys扫描或者fin扫描:
我给你异步socket的api代码:
unit Unit1;
interface
uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
StdCtrls,WInSock, ExtCtrls;

const WM_SOCKET=WM_USER+1; //socket消息

type
TForm1 = class(TForm)
Button1: TButton;
Edit1: TEdit;
Panel1: TPanel;
Memo1: TMemo;
procedure FormCreate(Sender: TObject);
procedure FormDestroy(Sender: TObject);
procedure Button1Click(Sender: TObject);
procedure Button2Click(Sender: TObject);
procedure Button3Click(Sender: TObject);
private
Sockhd : integer; //socket句柄
Serv_Addr : Tsockaddr;//目标地址

procedure SockEvent(var msg: Tmessage);message WM_SOCKET; //处理cocket消息
procedure DspMsg(msg : string); //显示信息
{ Private declarations }
public
{ Public declarations }
end;

Form1: TForm1;

implementation
{$R *.DFM}

function lookup_hostname(const hostname:string):longint; //把域名转化成IP地址
var
RemoteHost : PHostEnt; (* no, don't free it! *)
ip_address: longint;
begin
ip_address:=-1;
try
if hostname='' then
begin (* no host given! *)
lookup_hostname:=ip_address;
EXIT;
end
else
begin
ip_address:=Winsock.Inet_Addr(PChar(hostname)); (* try a xxx.xxx.xxx.xx first *)
if ip_address=SOCKET_ERROR then begin
RemoteHost:=Winsock.GetHostByName(PChar(hostname));
if (RemoteHost=NIL) or (RemoteHost^.h_length<=0) then
begin
lookup_hostname:=ip_address;
EXIT; (* host not found *)
end
else
ip_address:=longint(pointer(RemoteHost^.h_addr_list^)^);
end;
end;
except
ip_address:=-1;
end;
lookup_hostname:=ip_address;
end;

procedure TFOrm1.DspMsg(msg: string);
begin
memo1.Lines.Add(msg+'...');
if Memo1.Lines.Count>200 then Memo1.Lines.Delete(0);
end;

procedure TForm1.SockEvent(var msg : tmessage); //处理socket消息
begin
case msg.LParam of
FD_READ: begin //标识可以读数据,当然肯定已经链接上了
dspmsg('可以读取数据');
//do what you want do
end;

FD_WRITE: begin
dspmsg('可以发送数据');
//do what you want do
end;

FD_ERROR: begin
dspmsg('发生错误');
//如果你是客户端,则应该是连接不上,即端口没有开
end;

FD_CLOSE: Begin
dspmsg('服务器断开连接');
//对方关闭连接
end;

FD_CONNECT: begin
dspmsg('连结上服务器');
//表示对方端口开放
end;

FD_ACCEPT: begin
dspmsg('接收一个请求');
//这个消息只有服务端可能出现
end;
end;
end;

procedure TForm1.FormCreate(Sender: TObject);
var wsaData:TwsaData;
begin //启动winsock动态链接库
if WSAStartup (makeword(2,2), wsaData)<>0 then begin
messagebox(application.handle,'无法启动winsock动态连接库!','警告',MB_OK or MB_APPLMODAL or MB_ICONWARNING);
Application.Terminate;
end;
end;

procedure TForm1.FormDestroy(Sender: TObject);
begin //关闭dll
WSACleanup;
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
Sockhd := socket(AF_INET,SOCK_STREAM,0); //创建socket句柄
if Sockhd<0 then begin
messagebox(application.handle,'无法创建句柄!','警告',MB_OK or MB_APPLMODAL or MB_ICONWARNING);
exit;
end;
Serv_addr.sin_addr.s_addr:= lookup_hostname(edit1.Text); //主机名
Serv_addr.sin_family := PF_INET;
Serv_addr.sin_port := htons(23); //any port you want to connect

if WSAAsyncSelect(Sockhd,Form1.handle,WM_SOCKET,FD_ACCEPT or FD_CONNECT or FD_CLOSE or FD_READ or FD_WRITE)=SOCKET_ERROR
then begin
messagebox(application.handle,'无法创建句柄!','警告',MB_OK or MB_APPLMODAL or MB_ICONWARNING);
exit;
end; //异步socket
connect(sockhd,serv_addr,sizeof(serv_addr)); //连接,结果会在前面的处理函数处理
end;

end.
相信应该可以满足你的要求



 
能把程序发给我吗?如果可以我把积分都给你哦!!!
xuming828@163.net
谢谢了,我现在在线,读你给我的代码,等着你的回信!!
 
对了,还有一个问题,为何是异步socket的api代码??
还有就是为什么直接扫描会留下踪迹?能告诉我一下原理吗?:)
 
编译通不过
 
to 天真
能不能给小弟也发一份wb_l@eyou.com
 
可以给我发一份源程序吗?
paf@163.net
 
天真:
有完整代码吗?能否发一份给我?
EAMIL: Serverplus@msn.com

如果谁呢有好的 扫描程序,麻烦给我一份,重谢~
 
顶部