📄 421.htm
字号:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>CTerm非常精华下载</title>
</head>
<body bgcolor="#FFFFFF">
<table border="0" width="100%" cellspacing="0" cellpadding="0" height="577">
<tr><td width="32%" rowspan="3" height="123"><img src="DDl_back.jpg" width="300" height="129" alt="DDl_back.jpg"></td><td width="30%" background="DDl_back2.jpg" height="35"><p align="center"><a href="http://apue.dhs.org"><font face="黑体"><big><big>apue</big></big></font></a></td></tr>
<tr>
<td width="68%" background="DDl_back2.jpg" height="44"><big><big><font face="黑体"><p align="center"> ● UNIX网络编程 (BM: clown) </font></big></big></td></tr>
<tr>
<td width="68%" height="44" bgcolor="#000000"><font face="黑体"><big><big><p align="center"></big></big><a href="http://cterm.163.net"><img src="banner.gif" width="400" height="60" alt="banner.gif"border="0"></a></font></td>
</tr>
<tr><td width="100%" colspan="2" height="100" align="center" valign="top"><br><p align="center">[<a href="index.htm">回到开始</a>][<a href="316.htm">上一层</a>][<a href="422.htm">下一篇</a>]
<hr><p align="left"><small>发信人: guru ( Darkness), 信区: UNP <br>
标 题: 源码阅读--源例分析之pscan.c <br>
发信站: UNIX编程 (2001年07月13日21:11:56 星期五), 站内信件 <br>
<br>
: 一个简单的SCANNER,基本上知道流程,但要开发出一个高效的 <br>
:SCANNER,发现要掌握的东西还要很多。算是具备功能了,但是 <br>
:还差很远,在以后的学习中再慢慢健全吧。:) <br>
: 1。connect计时器对扫描时间影响 <br>
:如果能正常完成三次握手还好,否则必须等待connect定时器到期 <br>
: 2。gethostbyname对扫描时间影响 <br>
:如果运行程序的本地机器没有配置DNS服务器,必须追溯到上级DNS服务器。 <br>
:运行时: <br>
:输入IP正常,速度慢。:( <br>
:如果输入域名如"www.263.net"则立刻报错:error cannot resolve host www.263.net <br>
<br>
:strace出一堆结果,明天再看,有什么发现再贴出来。 <br>
: 3。hostent结构中char **h_addr_list的运用:数组(见本例)和指针(精华区新手 <br>
:入门常见问题域名转换) <br>
: 4。LINUX的sin_family是PF_***不是AF_*** <br>
: 5.一些格式处理函数: <br>
:sscanf();inet_addr() inet_aton();fsprintf();strncpy(); <br>
:程序在Linux 2.4.2-2上编译通过(gcc -o pscan -c pscan.c) , <br>
:精华区还有一些扫描器的精彩文章,希望能尽快阅读完。 <br>
//cc -o pscan pscan.c -lsocket -lnsl <br>
//-------------------------------------------------------------------------- <br>
-- <br>
//---- // cloudsky 于 00-6-23 11:56:36 加贴在 绿盟科技论坛(bbs.nsfocus.com) <br>
--UNIX系 统 <br>
// static char sccsid[] = "@(#)pscan.c 1.0 (KRAD) 08/25/94"; <br>
#include <stdio.h> <br>
#include <sys/types.h> <br>
#include <sys/socket.h> <br>
#include <netinet/in.h> <br>
#include <netdb.h> <br>
#define MAX_PORT 1024 /* scan up to this port */ <br>
int sockfd; <br>
struct sockaddr_in addr; <br>
char rmt_host[100]; <br>
int scan(port) <br>
int port; <br>
{ <br>
int r; <br>
sockfd = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP); <br>
if (sockfd < 0) { <br>
/* fprintf("ERROR: socket() failed\n");*/ <br>
/* Changed to printf for my Linux1.1.18 box */ <br>
printf("ERROR: socket() failed\n"); <br>
exit(0); <br>
} <br>
addr.sin_family = PF_INET; <br>
addr.sin_port = port; <br>
addr.sin_addr.s_addr = inet_addr(rmt_host); <br>
:inet_addr is obsolute to inet_aton(char *,struct in_addr *), <br>
:将形如x.x.x.x的IP地址转换为二进制格式。 <br>
:the following is the typical syn scaning.使用系统调用connect, <br>
:在三次握手完成后(connect成功返回)或在指定的定时器到时后(connect return - <br>
1) <br>
:关闭sockfd. <br>
r = connect(sockfd,(struct sockaddr *) &addr, sizeof(addr)); <br>
close(sockfd); <br>
if (r < 0) { <br>
return (1 == 0); <br>
} <br>
return (1 == 1); <br>
} <br>
main(argc,argv) <br>
int argc; <br>
int argc; <br>
char *argv[]; { <br>
int a,b,c,d,e,f; <br>
struct hostent *foo; <br>
struct servent *bar; <br>
if (argc < 2) { <br>
fprintf(stderr,"usage: %s <host> [highestport]\n",argv[0]); <br>
exit(0); <br>
} <br>
if (sscanf(argv[1],"%d.%d.%d.%d",&a,&b,&c,&d)!= 4) { <br>
:处理输入hostname的情况,调用gethostbyname得到IP <br>
:总觉得象a,b,c,d这样处理IP很不爽,以后看看有没有更好的方法 <br>
:sscanf get its input from argv[1] ,the value is assigned to a,b,c,d with th <br>
e format <br>
foo = gethostbyname(argv[1]); <br>
if (foo == NULL) { <br>
fprintf(stderr,"error:cannot resolve host %s\n",argv[1]); <br>
exit(1); } <br>
:精华区新手入门->常见问题中有处理多个IP的文章, <br>
:maybe multi_ip:foo->h_addr_list[1][0-4]... <br>
:IP用h_addr_list[0][0-3]. <br>
sprintf(rmt_host,"%d.%d.%d.%d",(unsigned char )foo->h_addr_list[0][0], <br>
(unsigned char ) foo->h_addr_list[0][1], <br>
(unsigned char ) foo->h_addr_list[0][2], <br>
(unsigned char ) foo->h_addr_list[0][3]); <br>
} else { <br>
strncpy(rmt_host,argv[1],99); >here,null-terminated. <br>
} <br>
if (argc > 2) { f = atoi(argv[2]); >convert the initial portion of th <br>
e string to int <br>
} else <br>
f = MAX_PORT; <br>
:the maxport by default <br>
fprintf(stdout,"Scanning host %s - TCP ports 1 through %d\n",rmt_host,f); <br>
:the main loop of the scanning: <br>
for (e =1;e<=f;e++) { <br>
char serv[100]; <br>
if (scan(e)) { <br>
bar = getservbyport(e,"tcp"); <br>
printf("%d (%s) is running.\n",e,(bar== NULL) ? "UNKNOWN" : <br>
<br>
bar->s_name); <br>
:UNKNOWN should be replaced by "the ack of the syn is not received" :) <br>
} <br>
} <br>
} <br>
<br>
-- <br>
Target Locked:Guru In Darkness. <br>
我只是一只静静卧着的狮子。。。 <br>
※ 来源:·UNIX编程 www.tiaozhan.com/unixbbs/·[FROM: 202.114.36.210] <br>
</small><hr>
<p align="center">[<a href="index.htm">回到开始</a>][<a href="316.htm">上一层</a>][<a href="422.htm">下一篇</a>]
<p align="center"><a href="http://cterm.163.net">欢迎访问Cterm主页</a></p>
</table>
</body>
</html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -