网络对抗技术实验一
实验报告
实验一 |
网络侦查与网络扫描 |
学生姓名 |
刘鑫研 |
年级 |
2018级 |
区队 |
网安四区 |
指导教师 |
高见 |
信息技术与网络安全学院
2017年7月7日
实验任务总纲
2017—2018 学年 第 一 学期
一、实验目的
1.加深并消化本课程授课内容,复习所学过的互联网搜索技巧、方法和技术;
2.了解并熟悉常用搜索引擎、扫描工具、社交网站等互联网资源,对给定的任务进行搜索、关联、分析;
3.达到巩固课程知识和实际应用的目的。
二、实验要求
1.认真阅读每个实验内容,需要截图的题目,需清晰截图并对截图进行标注和说明。
2.文档要求结构清晰,图文表达准确,标注规范。推理内容客观、合理、逻辑性强。
3.软件工具可使用office2003或2007、Nmap、等。
4.实验结束后,保留电子文档。
三、实验步骤
1.准备
提前做好实验准备,实验前应把详细了解实验目的、实验要求和实验内容,熟悉并准备好实验用的软件工具,按照实验内容和要求提前做好实验内容的准备。
2.实验环境
描述实验所使用的硬件和软件环境(包括各种软件工具);
开机并启动软件office2003或2007、浏览器、扫描软件。
3.实验过程
1)启动系统和启动工具软件环境。
2)用软件工具实现实验内容。
4.实验报告
按照统一要求的实验报告格式书写实验报告。把按照模板格式编写的文档嵌入到实验报告文档中,文档按照规定的书写格式书写,表格要有表说图形要有图说。
实验任务(一)
网络侦查是指黑客为了更加有效地实施攻击而在攻击前或攻击过程中对目标主机的所有探测活动。网络侦查有时也被称为“踩点”。通常“踩点”包括以下内容:目标主机的域名、IP地址、操作系统类型、开放了哪些端口,以及这些端口后面运行着什么样的应用程序,这些应用程序有没有漏洞等。那么如何收集信息呢?可以利用与技术无关的“社会工程学”,搜索引擎以及扫描工具。
问题一:
用百度或google搜索www.ppsuc.edu.cn中所有包含“网络安全”的网页。(附截图)
答:利用 site:www.ppsuc.edu.cn intext:网络安全 来搜索www.ppsuc.edu.cn中所有包含“网络安全”的网页
问题二:
用百度或google搜索所有包含“网络安全”的pdf文档(附截图)
答:利用filetype:pdf 网络安全 搜索所有包含“网络安全”的pdf文档
问题三:
小丽是药学专业的一名本科生,现已从事药学专业的工作,目前她想考取一个资格证,但是报名条件中要求其工作满三年。那么,小丽想考取的是什么证。(请回答并附截图证明。)
答:执业药师资格证。在百度上搜索关键词 本科生 从事医药学工作三年 资格证
问题四:
6月28日是小王的生日,他是中国人民公安大学2008年入学的本科生。在大四这年,为了庆祝生日,他和朋友们一起看了一场刚好在生日这天上映的国产玄幻电影。在这场电影中,饰演“炼丹大师”角色的演员曾经出家,请问他当时的法号是什么?(附截图)
答:在百度上通过关键词2012年6月28日 国产玄幻电影 搜索出《画皮2》
然后在百度上通过关键词 画皮2中炼丹大师的扮演者,最终搜索出事游本昌
然后再搜索关键词 游本昌的法号 最后得到法号是乘培
问题五:
210.31.48.31,该IP地址是属于哪个单位的(附截图)
答:属于中国人民公安大学,来源于北京市教育网
问题六:
在一个案件中,获取了犯罪嫌疑人的一个MAC地址:40-16-9F-4E-7F-B4,请查询该MAC地址对应的厂商是(附截图)
答:MAC地址40-16-9F-4E-7F-B4是对应的厂商是TP-LINK TECHNOLOGIES CO.,LTD.(普联)
问题七:
在一个案件中,获取了犯罪嫌疑人的LAC是41064,CID是16811,这个人可能在什么地方?(附截图)
答:利用minigps基站查询到犯罪嫌疑人在北京市大兴区黄亦路.中国人民公安大学团河校区-南2门西189米。
问题八:
获取www.zzz.gov.cn域名注册时,注册人的邮箱是(附截图)
答:利用站长之家工具获取www.zzz.gov.cn域名注册时,注册人的邮箱是13901327592@263.net
问题九:
通过一个人的QQ号码,从互联网扩充相关线索。如网络昵称,MSN号码等信息。
也可以自己选择一个网络虚拟身份(QQ,Mail,Tel),通过互联网搜索获取该虚拟身份的其它相关信息。(请说明推理过程,附搜索截图)
例如:昵称->邮箱->QQ号码->电话、姓名->微信->物理地址...................
(1)在腾讯QQ的app上搜索QQ号 915534913, 得知该用户的QQ昵称是婷啊婷阿扎,性别女,年龄20岁,生日是11月26日,QQ邮箱是915534913@qq.com
(2)在微博上搜索用户名婷啊婷阿扎,查看用户基本资料猜测用户来自甘肃张掖
(3)在微信app上搜索昵称婷啊婷阿扎,搜索到微信号是ltt18189361426 ,得到手机号是18189361426
(3)利用支付宝的转账界面,输入需要转账人的手机号18189361426,查询到手机号对应人的姓名是李婷婷
(4)通过手机号18189361426,查询到手机号归属地在甘肃张掖,邮编734000,区号0936
(5)在百度上搜索关键词 李婷婷 ,发现没有与年龄20岁相符合的人,所以未搜索到有用信息。
问题十:
请查询本机的IP地址和子网掩码,并在局域网中扫描本网段内的所有存活主机(附截图)
答:IP地址:192.168.31.1
子网掩码:255.255.255.0
在局域网 192.168.31.0/24 中扫描本网段内的所有存活主机
问题十一:
选择一个存活IP地址,扫描所开放的端口(分别用ping扫描,syn扫描尝试和全连接扫描),并查询常用端口所对应的服务及操作系统信息。
熟悉nmap相关命令,通过抓包,分析全连接和半连接扫描数据包的特征(附截图)
选择一个存活IP地址 192.168.31.1
(1)ping扫描
使用nmap -sP 192.168.31.1进行扫描
(2)syn扫描
使用nmap -sS 192.168.31.1 进行syn端口扫描,扫描到8个端口,其中常用端口是23端口和80端口,23端口是telnet服务,80端口是http服务
(2).1 如果扫描端口开放
扫描者发送SYN
被扫描方返回SYN/ACK包,然后扫描完成后,扫描放发送RST包断开连接
(2).2 如果端口未开放
扫描者发送SYN
被扫描方返回RST包,端口未开放
(3)TCP扫描
(3).1 如果端口开放
扫描方发送SYN
被扫描方回复SYN/ACK包
扫描者返回ACK包,建立连接
扫描完成后,扫描方发送RST包断开连接
(3).2 如果端口未开放
扫描者发送SYN包
被扫描者回复RST/ACK数据包,表示端口未开放
(4)扫描到的常用端口及服务
23端口 telnet服务
80端口 http服务
(5)操作系统信息
(6)SYN扫描(半连接扫描)的特征
SYN扫描的过程
1、扫描端向目标端发送SYN请求建立连接
2、目标端收到请求后,回复SYN/ACK同意连接并同意发送SYN请求建立连接;回复RST表示拒绝建立连接
3、扫描完成后,发送RST断开连接
SYN扫描的优缺点
优点:
1、SYN扫描要比TCP Connect()扫描隐蔽一些,SYN仅仅需要发送初始的SYN数据包给目标主机,如果端口开放,则相应SYN/ACK数据包;如果关闭,则响应RST数据包。
2、SYN扫描速度相对较快。
3、扫描不会被记录到系统日志中,这种扫描技术一般不会在目标主机上留下扫描痕迹。
(7)TCP扫描(全连接扫描)的特征
TCP扫描过程
1、扫描端向目标端发送SYN请求建立连接
2、目标端收到请求后,回复ACK同意连接并同意发送SYN请求建立连接
3、扫描端收到后,发送ACK同意,此时三次握手完成,以此来判断端口是否存活
4、扫描完成后,发送RST断开连接
TCP扫描的优缺点
优点:
1、执行了TCP的三次握手,故检测到的信息准确度非常高。
2、该命令对执行者的权限没有特殊要求,系统中权限比较低的用户也可以调用。
缺点:
1、扫描速度相对较慢。
2、扫描中留下的日志比较多,每次TCP连接后会将信息记录到日志中
3、是很容易被对方的防火墙、入侵检测设备截杀,得不到真实的端口开放情况。
问题十二:
在实验楼上网的局域网内,请扫描出来,哪些机器开启了ftp服务,哪些机器开启了远程桌面连接服务,并附截图证明。
用命令nmap -sS -p 21,3389 192.168.31.1/24
问题十三:(该项选做)
用程序实现全连接端口扫描,扫描常用端口
参考:
include "stdafx.h"
#include "stdafx.h"
#include "stdio.h"
#include <string.h>
#include <Winsock2.h>
#pragma comment(lib, "ws2_32.lib")
#define DEST_IP "127.0.0.1"
#define DEST_PORT 135
int main()
{
//初始化WinSock
WORD wVersionRequested = MAKEWORD(2,2);
WSADATA wsaData;
if(WSAStartup(wVersionRequested,&wsaData) != 0)
{
printf("初始化WinSock失败!\n") ;
return 0 ;
}
int sockfd,n;
struct sockaddr_in dest_addr;
sockfd = socket(AF_INET, SOCK_STREAM, 0);
dest_addr.sin_family = AF_INET;
dest_addr.sin_port = htons(DEST_PORT);
dest_addr.sin_addr.s_addr = inet_addr(DEST_IP);
//bzero(&(dest_addr.sin_zero));
n=connect(sockfd, (struct sockaddr *)&dest_addr, sizeof(struct sockaddr));
if(n==-1){
printf("端口没有开启");
}else{
printf("端口开启");
}
}
使用python
声明:凡因违规浏览而引起的任何法律纠纷,本人概不负责!