<div class="markdown-body editormd-preview-container" previewcontainer="true" style="padding: 20px;"><div class="markdown-toc editormd-markdown-toc"><ul class="markdown-toc-list"><li><a class="toc-level-1" href="#0x1. 前言" level="1">0x1. 前言</a><ul><li><a class="toc-level-2" href="#0x1.1 行文结构以及如何快速查找？" level="2">0x1.1 行文结构以及如何快速查找？</a></li><li><a class="toc-level-2" href="#0x1.2 这里放了一张我自己做的脑图，有需要可以自取哦~" level="2">0x1.2 这里放了一张我自己做的脑图，有需要可以自取哦~</a></li><li><a class="toc-level-2" href="#0x1.3 作业在哪里写，我要写哪些作业？（来来来，点进来，看这里）" level="2">0x1.3 作业在哪里写，我要写哪些作业？（来来来，点进来，看这里）</a><ul><li><a class="toc-level-3" href="#1. 作业在哪里写？" level="3">1. 作业在哪里写？</a></li><li><a class="toc-level-3" href="#2. 我怎么知道我要做哪些作业？" level="3">2. 我怎么知道我要做哪些作业？</a></li></ul></li><li><a class="toc-level-2" href="#0x1.4 我该从哪里开始学？如何学习？" level="2">0x1.4 我该从哪里开始学？如何学习？</a></li><li><a class="toc-level-2" href="#0x1.5 课程里面的软件都有提供吗？课件在哪里？" level="2">0x1.5 课程里面的软件都有提供吗？课件在哪里？</a></li><li><a class="toc-level-2" href="#0x1.6 下载的软件是装在本机还是虚拟机呀？" level="2">0x1.6 下载的软件是装在本机还是虚拟机呀？</a></li><li><a class="toc-level-2" href="#0x1.7 EverEdit显示：您的试用已过期怎么办？" level="2">0x1.7 EverEdit显示：您的试用已过期怎么办？</a><ul><li><a class="toc-level-3" href="#解决方法1: Everedit无限试用" level="3">解决方法1: Everedit无限试用</a></li><li><a class="toc-level-3" href="#解决方法2：其他软件替代" level="3">解决方法2：其他软件替代</a></li></ul></li><li><a class="toc-level-2" href="#0x1.8 当期结束之后，后面学习完课程还能找辅导员问问题嘛？" level="2">0x1.8 当期结束之后，后面学习完课程还能找辅导员问问题嘛？</a></li></ul></li><li><a class="toc-level-1" href="#0x2 常见问题解答与分析" level="1">0x2 常见问题解答与分析</a><ul><li><a class="toc-level-2" href="#0x2.0 作业怎么写？markdown语法怎么用？" level="2">0x2.0 作业怎么写？markdown语法怎么用？</a></li><li><a class="toc-level-2" href="#0x2.1 web通信原理" level="2">0x2.1 web通信原理</a><ul><li><a class="toc-level-3" href="#0x2.1.1 虚拟机安装" level="3">0x2.1.1 虚拟机安装</a><ul><li><a class="toc-level-4" href="#1. 安装VMware16时弹出需要输入许可证？" level="4">1. 安装VMware16时弹出需要输入许可证？</a></li><li><a class="toc-level-4" href="#2. VMware以及虚拟机安装需要注意的一些事项？" level="4">2. VMware以及虚拟机安装需要注意的一些事项？</a></li><li><a class="toc-level-4" href="#3. 虚拟机正确安装好以后，一打开虚拟机就蓝屏重启了！？（疑难杂症）" level="4">3. 虚拟机正确安装好以后，一打开虚拟机就蓝屏重启了！？（疑难杂症）</a><ul><li><a class="toc-level-5" href="#解决办法一(检查VMware版本)" level="5">解决办法一(检查VMware版本)</a></li><li><a class="toc-level-5" href="#解决办法二(检查windows功能)" level="5">解决办法二(检查windows功能)</a></li><li><a class="toc-level-5" href="#解决方法三(禁用HV服务)" level="5">解决方法三(禁用HV服务)</a></li><li><a class="toc-level-5" href="#解决办法四" level="5">解决办法四</a></li></ul></li><li><a class="toc-level-4" href="#4. 正确安装了VM Tools之后，发现往虚拟机拖文件拖不进去，咋办啊？" level="4">4. 正确安装了VM Tools之后，发现往虚拟机拖文件拖不进去，咋办啊？</a><ul><li><a class="toc-level-5" href="#尝试办法一" level="5">尝试办法一</a></li><li><a class="toc-level-5" href="#尝试办法二" level="5">尝试办法二</a></li><li><a class="toc-level-5" href="#尝试办法三" level="5">尝试办法三</a></li></ul></li><li><a class="toc-level-4" href="#5. 虚拟机安装之后，如何保存快照（保存快照是一个好习惯）？" level="4">5. 虚拟机安装之后，如何保存快照（保存快照是一个好习惯）？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.1.2 计算机基础命令和概念讲解" level="3">0x2.1.2 计算机基础命令和概念讲解</a><ul><li><a class="toc-level-4" href="#1. 什么是ip？" level="4">1. 什么是ip？</a></li><li><a class="toc-level-4" href="#2. 公网ip和内网ip的区别?" level="4">2. 公网ip和内网ip的区别?</a></li><li><a class="toc-level-4" href="#3. 怎么理解域名？" level="4">3. 怎么理解域名？</a></li><li><a class="toc-level-4" href="#4.关于web通信原理,学安全要去理解tcp/ip吗？" level="4">4.关于web通信原理,学安全要去理解tcp/ip吗？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.1.3 快速自建web安全测试环境" level="3">0x2.1.3 快速自建web安全测试环境</a><ul><li><a class="toc-level-4" href="#1. phpstudy哪里可以下载？" level="4">1. phpstudy哪里可以下载？</a></li><li><a class="toc-level-4" href="#2. phpstudy安装好后，数据库账号密码是多少？" level="4">2. phpstudy安装好后，数据库账号密码是多少？</a></li><li><a class="toc-level-4" href="#3. phpmyadmin默认用户名密码是什么？" level="4">3. phpmyadmin默认用户名密码是什么？</a></li><li><a class="toc-level-4" href="#4. 在使用phpstudy时，点击启动发现apache启动不了怎么办？" level="4">4. 在使用phpstudy时，点击启动发现apache启动不了怎么办？</a></li><li><a class="toc-level-4" href="#5. 怎么使用phpstudy快速搭建web环境，如何快速建站？" level="4">5. 怎么使用phpstudy快速搭建web环境，如何快速建站？</a></li></ul></li></ul></li><li><a class="toc-level-2" href="#0x2.2 网络安全法（讲解）" level="2">0x2.2 网络安全法（讲解）</a><ul><li><a class="toc-level-3" href="#0x2.2.1 点进来看看，有惊喜~" level="3">0x2.2.1 点进来看看，有惊喜~</a></li></ul></li><li><a class="toc-level-2" href="#0x2.3 Web安全前后端基础" level="2">0x2.3 Web安全前后端基础</a><ul><li><a class="toc-level-3" href="#0x2.3.1 后端基础PHP———表单验证" level="3">0x2.3.1 后端基础PHP———表单验证</a><ul><li><a class="toc-level-4" href="#1. 表单验证的基本流程是什么？" level="4">1. 表单验证的基本流程是什么？</a></li><li><a class="toc-level-4" href="#2. POST提交方式和GET方式有什么区别" level="4">2. POST提交方式和GET方式有什么区别</a></li><li><a class="toc-level-4" href="#3. 表单中的target属性有什么作用？" level="4">3. 表单中的target属性有什么作用？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.3.2 渗透测试常用工具讲解" level="3">0x2.3.2 渗透测试常用工具讲解</a><ul><li><a class="toc-level-4" href="#1. 环境变量是什么，设置环境变量的意义？" level="4">1. 环境变量是什么，设置环境变量的意义？</a></li><li><a class="toc-level-4" href="#2. java如何设置环境变量？" level="4">2. java如何设置环境变量？</a></li><li><a class="toc-level-4" href="#3. sqlmap最新版获取？" level="4">3. sqlmap最新版获取？</a></li><li><a class="toc-level-4" href="#4. sqlmap如何运行起来？" level="4">4. sqlmap如何运行起来？</a></li><li><a class="toc-level-4" href="#5. sqlmap指令太多了记不住怎么办？" level="4">5. sqlmap指令太多了记不住怎么办？</a></li><li><a class="toc-level-4" href="#6. SqlMap中探测等级的区别？" level="4">6. SqlMap中探测等级的区别？</a></li><li><a class="toc-level-4" href="#7. sqlmap如何清除缓存重新测试？" level="4">7. sqlmap如何清除缓存重新测试？</a></li><li><a class="toc-level-4" href="#8. burp如何配置安装抓浏览器的数据包？" level="4">8. burp如何配置安装抓浏览器的数据包？</a><ul><li><a class="toc-level-5" href="#burp安装，激活" level="5">burp安装，激活</a></li><li><a class="toc-level-5" href="#浏览器安装、使用代理插件Proxy SwitchyOmega、证书安装、BURP抓包？" level="5">浏览器安装、使用代理插件Proxy SwitchyOmega、证书安装、BURP抓包？</a></li></ul></li><li><a class="toc-level-4" href="#9. 为什么要设置代理才能抓到数据包、burp是怎么抓到包的？" level="4">9. 为什么要设置代理才能抓到数据包、burp是怎么抓到包的？</a></li><li><a class="toc-level-4" href="#10. 设置代理监听的8080端口，能改成别的端口吗？" level="4">10. 设置代理监听的8080端口，能改成别的端口吗？</a></li></ul></li></ul></li><li><a class="toc-level-2" href="#0x2.4 信息搜集" level="2">0x2.4 信息搜集</a><ul><li><a class="toc-level-3" href="#0x2.4.1 信息搜集的意义—渗透测试的灵魂" level="3">0x2.4.1 信息搜集的意义—渗透测试的灵魂</a><ul><li><a class="toc-level-4" href="#1. 如何查看网站cms" level="4">1. 如何查看网站cms</a></li><li><a class="toc-level-4" href="#2. 什么是旁站，什么是C段，它俩的区别是什么？" level="4">2. 什么是旁站，什么是C段，它俩的区别是什么？</a></li><li><a class="toc-level-4" href="#3. 目录扫描用什么工具？" level="4">3. 目录扫描用什么工具？</a></li><li><a class="toc-level-4" href="#4. 端口探测用什么工具？" level="4">4. 端口探测用什么工具？</a></li><li><a class="toc-level-4" href="#5. 如何识别页面是否伪静态？" level="4">5. 如何识别页面是否伪静态？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.4.2 信息收集实战 1 &amp; 2" level="3">0x2.4.2 信息收集实战 1 &amp; 2</a><ul><li><a class="toc-level-4" href="#1. 信息收集脑图" level="4">1. 信息收集脑图</a></li></ul></li></ul></li><li><a class="toc-level-2" href="#0x2.5 注入——全方位利用" level="2">0x2.5 注入——全方位利用</a><ul><li><a class="toc-level-3" href="#0x2.5.1 SQL注入的原理分析" level="3">0x2.5.1 SQL注入的原理分析</a><ul><li><a class="toc-level-4" href="#1. sql注入本质是什么" level="4">1. sql注入本质是什么</a></li><li><a class="toc-level-4" href="#2. 数据库管理工具Navicat安装、与破解激活教程？" level="4">2. 数据库管理工具Navicat安装、与破解激活教程？</a></li><li><a class="toc-level-4" href="#3. order by的作用及含义？" level="4">3. order by的作用及含义？</a></li><li><a class="toc-level-4" href="#4. 闭合是什么？" level="4">4. 闭合是什么？</a></li><li><a class="toc-level-4" href="#5. union all 和 union 区别？" level="4">5. union all 和 union 区别？</a></li><li><a class="toc-level-4" href="#6. 为什么用and 1=1正常 and 1=2报错来判断是否存在SQL注入？" level="4">6. 为什么用and 1=1正常 and 1=2报错来判断是否存在SQL注入？</a></li><li><a class="toc-level-4" href="#7. 除了 and 1=1、and1=2，可以用 or 1=1 、or 1=2 吗？" level="4">7. 除了 and 1=1、and1=2，可以用 or 1=1 、or 1=2 吗？</a></li><li><a class="toc-level-4" href="#8. 注入语句最后的 --是什么意思？为什么 -- 后面要加个 qwe？" level="4">8. 注入语句最后的 --是什么意思？为什么 -- 后面要加个 qwe？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.5.2 POST注入/HEAD注入" level="3">0x2.5.2 POST注入/HEAD注入</a><ul><li><a class="toc-level-4" href="#1. POST注入如何注入?" level="4">1. POST注入如何注入?</a></li><li><a class="toc-level-4" href="#2. post注入会出现在哪里？" level="4">2. post注入会出现在哪里？</a></li><li><a class="toc-level-4" href="#3. 万能密码原理？" level="4">3. 万能密码原理？</a></li><li><a class="toc-level-4" href="#4. head头注入原理？" level="4">4. head头注入原理？</a></li><li><a class="toc-level-4" href="#5. POST注入用 SQLMAP 怎么测试？" level="4">5. POST注入用 SQLMAP 怎么测试？</a></li><li><a class="toc-level-4" href="#6. HEAD注入用 SQLMAP 怎么测试？" level="4">6. HEAD注入用 SQLMAP 怎么测试？</a></li><li><a class="toc-level-4" href="#7. POST和GET传参方式都会进行编码吗？" level="4">7. POST和GET传参方式都会进行编码吗？</a></li><li><a class="toc-level-4" href="#8. POST传参和GET传参有什么区别？(可以记一记，有的时候简单面试会问到)" level="4">8. POST传参和GET传参有什么区别？(可以记一记，有的时候简单面试会问到)</a></li></ul></li><li><a class="toc-level-3" href="#0x2.5.3 宽字节注入" level="3">0x2.5.3 宽字节注入</a><ul><li><a class="toc-level-4" href="#1. 为什么在注入的时候使用的查询表名要用16进制进行编码？" level="4">1. 为什么在注入的时候使用的查询表名要用16进制进行编码？</a></li><li><a class="toc-level-4" href="#2. 除了使用16进制编码绕过外还有什么方法吗？" level="4">2. 除了使用16进制编码绕过外还有什么方法吗？</a></li><li><a class="toc-level-4" href="#3. 如何开启魔术引号？" level="4">3. 如何开启魔术引号？</a></li><li><a class="toc-level-4" href="#4. 宽字节只发生在GBK编码上面吗？" level="4">4. 宽字节只发生在GBK编码上面吗？</a></li><li><a class="toc-level-4" href="#5. 魔术引号默认开启吗？" level="4">5. 魔术引号默认开启吗？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.5.4 盲注" level="3">0x2.5.4 盲注</a><ul><li><a class="toc-level-4" href="#1. 盲注中的substr()怎么用？" level="4">1. 盲注中的substr()怎么用？</a></li><li><a class="toc-level-4" href="#2. 布尔盲注的原理，如何理解布尔盲注？" level="4">2. 布尔盲注的原理，如何理解布尔盲注？</a></li><li><a class="toc-level-4" href="#3. 布尔盲注和延时盲注有什么区别？" level="4">3. 布尔盲注和延时盲注有什么区别？</a></li><li><a class="toc-level-4" href="#4. if()判断如何使用？" level="4">4. if()判断如何使用？</a></li></ul></li></ul></li><li><a class="toc-level-2" href="#0x2.6 数据库注入" level="2">0x2.6 数据库注入</a><ul><li><a class="toc-level-3" href="#0x2.6.1 Access—Cookie注入" level="3">0x2.6.1 Access—Cookie注入</a><ul><li><a class="toc-level-4" href="#1. cookie注入怎么理解，怎么做注入？" level="4">1. cookie注入怎么理解，怎么做注入？</a></li><li><a class="toc-level-4" href="#2. 为啥我在做cookie注入的时候，在cookie字段写sql语句并且确认是正确的，但是就是注入不出来？" level="4">2. 为啥我在做cookie注入的时候，在cookie字段写sql语句并且确认是正确的，但是就是注入不出来？</a></li><li><a class="toc-level-4" href="#3. 有没有好用的编码工具或者在线网站？" level="4">3. 有没有好用的编码工具或者在线网站？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.6.2 Access—偏移注入" level="3">0x2.6.2 Access—偏移注入</a><ul><li><a class="toc-level-4" href="#1. 偏移注入的flag在哪里？" level="4">1. 偏移注入的flag在哪里？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.6.3 MySQL注入—Dns注入" level="3">0x2.6.3 MySQL注入—Dns注入</a><ul><li><a class="toc-level-4" href="#1. dnslog平台接收不到DNS注入外带的数据？" level="4">1. dnslog平台接收不到DNS注入外带的数据？</a></li><li><a class="toc-level-4" href="#2. DNS注入原理？" level="4">2. DNS注入原理？</a></li><li><a class="toc-level-4" href="#3. load_file函数的作用？" level="4">3. load_file函数的作用？</a></li><li><a class="toc-level-4" href="#4. DNS注入可以用在Linux的机器上面吗？" level="4">4. DNS注入可以用在Linux的机器上面吗？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.6.4 MSSQL注入—反弹注入" level="3">0x2.6.4 MSSQL注入—反弹注入</a><ul><li><a class="toc-level-4" href="#1. 反弹注入使用到的外部连接数据库在哪里有？(看这里，不需要自己去注册的！！！)" level="4">1. 反弹注入使用到的外部连接数据库在哪里有？(看这里，不需要自己去注册的！！！)</a></li><li><a class="toc-level-4" href="#2. 反弹注入需要什么条件？" level="4">2. 反弹注入需要什么条件？</a></li><li><a class="toc-level-4" href="#3. 在MSSQL中为什么不能直接查询表里的字段？" level="4">3. 在MSSQL中为什么不能直接查询表里的字段？</a></li><li><a class="toc-level-4" href="#4. MSSQL中常用的语句？" level="4">4. MSSQL中常用的语句？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.6.5 Oracle注入—报错注入" level="3">0x2.6.5 Oracle注入—报错注入</a><ul><li><a class="toc-level-4" href="#1. Oracle系统表有哪些？" level="4">1. Oracle系统表有哪些？</a></li><li><a class="toc-level-4" href="#2. Oracle 使用查询语句获取数据时要注意什么？" level="4">2. Oracle 使用查询语句获取数据时要注意什么？</a></li><li><a class="toc-level-4" href="#3. Oracle 是否需要大小写问题？" level="4">3. Oracle 是否需要大小写问题？</a></li><li><a class="toc-level-4" href="#4. Oracle常用的一些语句有哪些？" level="4">4. Oracle常用的一些语句有哪些？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.6.6 SQLmap绕WAF脚本编写" level="3">0x2.6.6 SQLmap绕WAF脚本编写</a><ul><li><a class="toc-level-4" href="#1. 课程或这哪搞sqlmap绕WAF那张脑图？" level="4">1. 课程或这哪搞sqlmap绕WAF那张脑图？</a></li></ul></li></ul></li><li><a class="toc-level-2" href="#0x2.7 前端渗透测试" level="2">0x2.7 前端渗透测试</a><ul><li><a class="toc-level-3" href="#0x2.7.1 XSS的原理分析与解剖" level="3">0x2.7.1 XSS的原理分析与解剖</a><ul><li><a class="toc-level-4" href="#1. XSS的本质（原理）？" level="4">1. XSS的本质（原理）？</a></li><li><a class="toc-level-4" href="#2. 反射型常见的三种触发方法？" level="4">2. 反射型常见的三种触发方法？</a></li><li><a class="toc-level-4" href="#3. XSS在什么地方可以插入？" level="4">3. XSS在什么地方可以插入？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.7.2 存储型XSS" level="3">0x2.7.2 存储型XSS</a><ul><li><a class="toc-level-4" href="#1. 存储型xss也可以通过弹窗来验证吗？" level="4">1. 存储型xss也可以通过弹窗来验证吗？</a></li><li><a class="toc-level-4" href="#2. 存储型xss可能出现在哪些位置呢？" level="4">2. 存储型xss可能出现在哪些位置呢？</a></li><li><a class="toc-level-4" href="#3. xss平台的payload为什么就可以获取别人的cookie呢？" level="4">3. xss平台的payload为什么就可以获取别人的cookie呢？</a></li><li><a class="toc-level-4" href="#4. 打靶场的时候，使用XSS平台打了好多次，xss平台就是收不到Cookie呀咋办？" level="4">4. 打靶场的时候，使用XSS平台打了好多次，xss平台就是收不到Cookie呀咋办？</a></li><li><a class="toc-level-4" href="#5. xss平台搭建教程（仅用于技术教学）" level="4">5. xss平台搭建教程（仅用于技术教学）</a><ul><li><a class="toc-level-5" href="#环境准备" level="5">环境准备</a></li><li><a class="toc-level-5" href="#搭建过程" level="5">搭建过程</a></li></ul></li></ul></li><li><a class="toc-level-3" href="#0x2.7.3 Dom Based XSS" level="3">0x2.7.3 Dom Based XSS</a><ul><li><a class="toc-level-4" href="#1. DOM型XSS究竟是持久型还是非持久型，怎么理解？" level="4">1. DOM型XSS究竟是持久型还是非持久型，怎么理解？</a></li><li><a class="toc-level-4" href="#2. 为什么靶场可以用native编码来绕waf？" level="4">2. 为什么靶场可以用native编码来绕waf？</a></li><li><a class="toc-level-4" href="#3. 为什么不建议用谷歌浏览器做dom-xss?" level="4">3. 为什么不建议用谷歌浏览器做dom-xss?</a></li><li><a class="toc-level-4" href="#4. 可能触发DOM型XSS的属性有哪些？" level="4">4. 可能触发DOM型XSS的属性有哪些？</a></li></ul></li><li><a class="toc-level-3" href="#0x2.7.4 跨站请求伪造 - CSRF" level="3">0x2.7.4 跨站请求伪造 - CSRF</a><ul><li><a class="toc-level-4" href="#1. CSRF脑图？" level="4">1. CSRF脑图？</a></li><li><a class="toc-level-4" href="#2. CSRF的攻击流程？" level="4">2. CSRF的攻击流程？</a></li><li><a class="toc-level-4" href="#3. CSRF靶场上传了CSRF文件，在问题反馈页面点击提交之后，并没有创建文件？" level="4">3. CSRF靶场上传了CSRF文件，在问题反馈页面点击提交之后，并没有创建文件？</a></li><li><a class="toc-level-4" href="#4. CSRF与SSRF的区别？" level="4">4. CSRF与SSRF的区别？</a></li><li><a class="toc-level-4" href="#5. CSRF与XSS的区别？" level="4">5. CSRF与XSS的区别？</a></li><li><a class="toc-level-4" href="#6. CSRF图解" level="4">6. CSRF图解</a></li></ul></li><li><a class="toc-level-3" href="#0x2.7.5 验证码绕过、密码找回漏洞" level="3">0x2.7.5 验证码绕过、密码找回漏洞</a><ul></ul></li></ul></li></ul></li></ul></div><h1 id="h1-0x1-"><a name="0x1. 前言" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1. 前言</h1><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">本文主要用于解答正式课中，同学们遇到的一些比较常见的问题，对于常见的问题进行了分析解答，如果有不正确的地方请同学们在下方评论指出或者私聊我~~，小王会根据你的建议去做适当的修改^</span><span class="pln">_</span><span class="pun">^</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pun">本文将持续更新，不断补充~~</span></code></li><li class="L3"><code></code></li><li class="L4"><code><span class="pun">本文中所有涉及到的工具以及源码放在文末了哈,不必担心工具源码问题~~</span></code></li><li class="L5"><code></code></li><li class="L6"><code><span class="pun">学习如逆水行舟，希望能够与君共勉~~~</span></code></li></ol></pre><h2 id="h2-0x1-1-"><a name="0x1.1 行文结构以及如何快速查找？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1.1 行文结构以及如何快速查找？</h2><ul>
<li><p>行文结构 ： 根据正式课的课程体系大纲，对每一节中比较常见的问题作解答分析</p>
</li><li><p>快速查找 ： 在文章的头部目录中，直接点击相关课程大纲内容或相关问题可快速跳转进行查找</p>
</li></ul>
<h2 id="h2-0x1-2-"><a name="0x1.2 这里放了一张我自己做的脑图，有需要可以自取哦~" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1.2 这里放了一张我自己做的脑图，有需要可以自取哦~</h2><p>脑图制作比较潦草，大佬们轻点喷哈，如果大佬们也有想要分享的内容文字或者脑图或图片，可以联系我呀~</p>
<p>脑图在底部,名为：web安全学习笔记.zip</p>
<h2 id="h2-0x1-3-"><a name="0x1.3 作业在哪里写，我要写哪些作业？（来来来，点进来，看这里）" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1.3 作业在哪里写，我要写哪些作业？（来来来，点进来，看这里）</h2><h3 id="h3-1-"><a name="1. 作业在哪里写？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 作业在哪里写？</h3><p>1，首先访问我们的社区并登陆：<a href="https://bbs.zkaq.cn/">https://bbs.zkaq.cn/</a></p>
<p>2，登陆以后看到页面的右侧，找到 “作业专版” ，然后点击进去：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/3da08376583d73f4dc38981efb73c35a_19152.png" alt=""></p>
<p>3，进去之后可以看到，”作业模板” ，这个东西的作用就是教你怎么写作业的，请一定要浏览一遍：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/19fea5bc03a34e2674acccbdff98a1cc_78262.png" alt=""></p>
<p>4，点击”提交作业”：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/adda2aa17bb7b64d2e2f582ac156b5c8_66982.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/b52df9e4f0365f2a2e31bb0bf49d43a1_58369.png" alt=""></p>
<h3 id="h3-2-"><a name="2. 我怎么知道我要做哪些作业？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 我怎么知道我要做哪些作业？</h3><p>1，首先登陆咱们的社区，然后点击右上角的头像，”个人中心”—&gt;”学习计划” ，然后看到“学习计划及进度表”，这里有你在学习正式课所有的作业清单以及完成情况：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/25bf9a4de0ce11d28983054270da27d6_82861.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/3829037159dc4488f8c57d5ef4860ca0_15480.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/d75170be58228e7d0b8f62a60289be03_21973.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/27552ab22e634058016ee7d8d964bf11_65646.png" alt=""></p>
<p>同时再次提醒一下，写作业的时候尽量将你的思路，过程，截图都展现出来哈，越详细越好，也可以稍微注意一下作业的排版，尽量做到简洁大方，可阅读性强。</p>
<h2 id="h2-0x1-4-"><a name="0x1.4 我该从哪里开始学？如何学习？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1.4 我该从哪里开始学？如何学习？</h2><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">直接从正式课的第一节课开始，顺序往下学习即可，课程的学习顺序都是咱们的讲师安排好的，由易到难，由简到繁，所以同学只需要一步一个脚印，从上往下顺序学习即可，学习的过程中，希望同学可以养成做笔记的好习惯（好记性不如烂笔头），同时打靶场的同时，别忘了记录下过程和思路哦~~~</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">    </span><span class="pun">我建议的学习方法是：把视频完完整整认认真真看完，再进行实践操作，不推荐一边看一边对着做，这样学很容易卡壳的。</span></code></li></ol></pre><h2 id="h2-0x1-5-"><a name="0x1.5 课程里面的软件都有提供吗？课件在哪里？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1.5 课程里面的软件都有提供吗？课件在哪里？</h2><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">课程中涉及的</span><span class="pln">ppt</span><span class="pun">，课堂笔记，软件安装包我们都有提供，请同学放心。</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">    </span><span class="pun">课件可以在</span><span class="pln">QQ</span><span class="pun">群聊中的群文件中找到，以及辅导员给你的网盘，如果没有，可以找辅导员也就是我拿就行，如果有缺失的课件，也可以来找我哦~~~</span></code></li></ol></pre><h2 id="h2-0x1-6-"><a name="0x1.6 下载的软件是装在本机还是虚拟机呀？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1.6 下载的软件是装在本机还是虚拟机呀？</h2><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">关于这个问题，如果同学觉得某个软件不安全，害怕有病毒，可以将软件装在虚拟机里面，如果觉得装在本机也没事，就装在本机，你有完全控制权，你可以自主选择安装在哪里！！！</span></code></li></ol></pre><h2 id="h2-0x1-7-everedit-"><a name="0x1.7 EverEdit显示：您的试用已过期怎么办？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1.7 EverEdit显示：您的试用已过期怎么办？</h2><p>你看到的肯定是如下界面：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/3ba426f1f43c2c2e09398194efbba6b8_33689.png" alt=""></p>
<h3 id="h3--1-everedit-"><a name="解决方法1: Everedit无限试用" class="reference-link"></a><span class="header-link octicon octicon-link"></span>解决方法1: Everedit无限试用</h3><p>参考大佬的文章：<a href="https://bbs.zkaq.cn/t/471.html">https://bbs.zkaq.cn/t/471.html</a><br>设置快捷打开：<a href="https://bbs.zkaq.cn/t/2829.html">https://bbs.zkaq.cn/t/2829.html</a></p>
<h3 id="h3--2-"><a name="解决方法2：其他软件替代" class="reference-link"></a><span class="header-link octicon octicon-link"></span>解决方法2：其他软件替代</h3><p>OK，这个软件我在网上找了很多的破解方法，发现破解方法都比较复杂（也许是我没看到简单的方法），所以我这里建议你安装其他的编辑器软件比如 notepad++ ,sublime_text（推荐） 等，这些编辑器和 EverEdit其实差不多。</p>
<ul>
<li><p>notepad++ 官网下载地址：<a href="https://github.com/notepad-plus-plus/notepad-plus-plus/releases/download/v8.5.4/npp.8.5.4.portable.x64.zip">https://github.com/notepad-plus-plus/notepad-plus-plus/releases/download/v8.5.4/npp.8.5.4.portable.x64.zip</a></p>
<p>notepad++ 设置中文教程参考：<a href="https://blog.csdn.net/qq_35685189/article/details/116263871">https://blog.csdn.net/qq_35685189/article/details/116263871</a></p>
</li><li><p>sublime_text 官网下载地址：<a href="https://www.sublimetext.com/download_thanks?target=win-x64">https://www.sublimetext.com/download_thanks?target=win-x64</a></p>
<p>sublime_text 设置中文教程参考：<a href="https://zhuanlan.zhihu.com/p/102376540">https://zhuanlan.zhihu.com/p/102376540</a></p>
</li></ul>
<h2 id="h2-0x1-8-"><a name="0x1.8 当期结束之后，后面学习完课程还能找辅导员问问题嘛？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x1.8 当期结束之后，后面学习完课程还能找辅导员问问题嘛？</h2><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">请同学放心，报名了正式课课程，后面你如果还在学习或者复习正式课的课程内容，问辅导员正式课的问题，辅导员在看到后，依然会去给你解答的，如果有时候不是能够及时回复，可能是问问题的学员有点多哈，辅导员在一</span><span class="pln"> </span><span class="pun">一解答，届时希望能够谅解一下哈~</span><span class="pln"> </span><span class="pun">^</span><span class="pln">_</span><span class="pun">^</span></code></li></ol></pre><h1 id="h1-0x2-"><a name="0x2 常见问题解答与分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2 常见问题解答与分析</h1><h2 id="h2-0x2-0-markdown-"><a name="0x2.0 作业怎么写？markdown语法怎么用？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.0 作业怎么写？markdown语法怎么用？</h2><p>OK，请宝子们参考这篇文章：<a href="https://bbs.zkaq.cn/t/6306.html">文章内容很乱不知道该怎么排版,看这篇就够了(Markdown语法教程)</a></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">建议：在边做靶场的时候希望同学们可以边打开咱们的社区作业专版边记录过程哦，如果是保存在本地文件然后进行复制粘贴的话到时候图片还要重新截图比较麻烦的</span><span class="pln">QAQ</span></code></li></ol></pre><h2 id="h2-0x2-1-web-"><a name="0x2.1 web通信原理" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.1 web通信原理</h2><h3 id="h3-0x2-1-1-"><a name="0x2.1.1 虚拟机安装" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.1.1 虚拟机安装</h3><h4 id="h4-1-vmware16-"><a name="1. 安装VMware16时弹出需要输入许可证？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 安装VMware16时弹出需要输入许可证？</h4><p>在安装课件中的VMware时会弹出输出许可密钥：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/b5a7c32c5ba210ac2f6c7deac0c5305b_65673.png" alt=""><br>可以直接将以下许可密钥输入进去尝试激活：<br>VMware Workstation Pro 16 激活密钥：</p>
<ul>
<li>ZF3R0-FHED2-M80TY-8QYGC-NPKYF  </li><li>YF390-0HF8P-M81RQ-2DXQE-M2UT6  </li><li>ZF71R-DMX85-08DQY-8YMNC-PPHV8</li></ul>
<p>如果不是VMware版本不是16的宝子也不用担心，直接在百度上搜索：<code>VMware+你的版本+激活密钥</code> 即可</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/f7e6fdb7f153eead04b3c863b44039d0_39598.png" alt=""></p>
<h4 id="h4-2-vmware-"><a name="2. VMware以及虚拟机安装需要注意的一些事项？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. VMware以及虚拟机安装需要注意的一些事项？</h4><p>1，VMware安装时，安装路径最好选择<code>默认路径</code>，不要改动，更不要改动到<code>中文路径</code>下。<br>默认安装路径一般是C:\Program Files (x86)\VMware\xxx<br><img src="https://nc0.cdn.zkaq.cn/md/5597/a172fa1ca2df11886cbf212c3315c7b2_85438.png" alt=""></p>
<p>2，安装虚拟机是同样，虚拟机镜像以及虚拟机的存放路径最好是<code>英文路径</code>，否则容易发生系统错误</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/719454c6be065912ba38e815f41d9ee1_77213.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/75bff99184187c31c081fe01d6e7ece6_78552.png" alt=""></p>
<p>3，虚拟机安装在选择客户机操作系统时，需要选择与你安装的操作系统保持一致，比如我现在想安装一个<code>windows server2008 R2 64位</code>，那么我选择版本的时候就需要选择对应版本<code>windows server 2008 r2x64</code></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/e7cf724b1f1b5c423dbbc3e433a45e9e_83423.png" alt=""></p>
<h4 id="h4-3-"><a name="3. 虚拟机正确安装好以后，一打开虚拟机就蓝屏重启了！？（疑难杂症）" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 虚拟机正确安装好以后，一打开虚拟机就蓝屏重启了！？（疑难杂症）</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">因每个人的电脑情况都不一样，所以这里只写了几种常用上的解决方法，希望能够帮助到你。</span></code></li></ol></pre><h5 id="h5--vmware-"><a name="解决办法一(检查VMware版本)" class="reference-link"></a><span class="header-link octicon octicon-link"></span>解决办法一(检查VMware版本)</h5><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">查看</span><span class="typ">VMware</span><span class="pun">版本，如果版本是</span><span class="pln">VM15</span><span class="pun">.</span><span class="pln">x</span><span class="pun">的版本，请先将</span><span class="typ">VMware</span><span class="pun">卸载，然后重新安装一个</span><span class="pln">VM16</span><span class="pun">.</span><span class="pln">x</span><span class="pun">的版本，如果没有</span><span class="pln">VM16</span><span class="pun">.</span><span class="pln">x</span><span class="pun">的安装包，可以找辅导员也就是我拿</span><span class="pln"> </span><span class="pun">，</span><span class="pln"> </span><span class="pun">安装</span><span class="pln">VM16</span><span class="pun">需要的许可证在本文的</span><span class="pln"> </span><span class="pun">&lt;安装</span><span class="typ">VMware16</span><span class="pun">时弹出需要输入许可证？&gt;</span><span class="pln"> </span><span class="pun">这一问题中。</span></code></li></ol></pre><h5 id="h5--windows-"><a name="解决办法二(检查windows功能)" class="reference-link"></a><span class="header-link octicon octicon-link"></span>解决办法二(检查windows功能)</h5><p>打开”控制面板”，”程序”—&gt;”启用或关闭windows功能” ：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/a5821ef4c9dfd55ee38e7ed619e10b17_15324.png" alt=""></p>
<p>如果看到有 “Hyper-V” 功能且勾选了，则将该项<code>取消勾选</code>，如果没有该项，则默认没有：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/d4aea8f4a4b8d52bab0a003afc364d2f_27957.png" alt=""></p>
<p>然后找到<code>windows虚拟机监控程序平台</code>以及<code>虚拟机平台</code>，将这两项勾选上：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/29b4aeb0fe5eab9a39f48f3b93a44196_52843.png" alt=""></p>
<p>然后点<code>确定</code>来保存设置，保存之后会弹出重启电脑，直接重启就好了。<br>重启之后再打开VMware运行虚拟机试试。</p>
<h5 id="h5--hv-"><a name="解决方法三(禁用HV服务)" class="reference-link"></a><span class="header-link octicon octicon-link"></span>解决方法三(禁用HV服务)</h5><p><strong><em>先尝试前两个办法，这个办法最后尝试；</em></strong><br>同时按住 win+R 键，会弹出<code>运行</code>，输入<code>services.msc</code>会打开<code>服务</code>：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/442ac07c32813df8de8d089630083d77_39920.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/586b081c5f5010ee244e53e99e4091f0_93711.png" alt=""></p>
<p>找到<code>HV服务</code>,“右键”-&gt;”属性”-&gt;“启动类型”-&gt;”禁用”-&gt;”确定”：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/6f3354f34093da9dd9c247ddeef87a72_62967.png" alt=""></p>
<p>保险起见，可以尝试将所有Hyper-V服务禁用掉：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/d565bb89eb2122bb7736312e419efe27_59709.png" alt=""></p>
<p>然后以管理员身份运行powershell，输入<code>bcdedit /set hypervisorlaunchtype off</code></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/85dd12a6412bfbe22f42f679cc459be4_79343.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/0f51f65a159ce480f9ea9f2a799e09d6_38732.png" alt=""></p>
<p>然后重启电脑，再打开VMware运行虚拟机试试。</p>
<h5 id="h5-u89E3u51B3u529Eu6CD5u56DB"><a name="解决办法四" class="reference-link"></a><span class="header-link octicon octicon-link"></span>解决办法四</h5><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">都看到这了，还等啥，站在门口，大喊一声王妈</span><span class="pln">QAQ</span><span class="pun">，小王火速远程，给你看看到底是什么问题。</span></code></li></ol></pre><h4 id="h4-4-vm-tools-"><a name="4. 正确安装了VM Tools之后，发现往虚拟机拖文件拖不进去，咋办啊？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. 正确安装了VM Tools之后，发现往虚拟机拖文件拖不进去，咋办啊？</h4><h5 id="h5-u5C1Du8BD5u529Eu6CD5u4E00"><a name="尝试办法一" class="reference-link"></a><span class="header-link octicon octicon-link"></span>尝试办法一</h5><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">先选中本机的文件右键，选择</span><span class="str">`复制`</span><span class="pun">，然后到虚拟机里面找个位置右键，选择</span><span class="str">`粘贴`</span><span class="pun">，如果可以正常复制粘贴，那么虚拟机是可以正常拖文件进去的，可以再多尝试几次。</span></code></li></ol></pre><h5 id="h5-u5C1Du8BD5u529Eu6CD5u4E8C"><a name="尝试办法二" class="reference-link"></a><span class="header-link octicon octicon-link"></span>尝试办法二</h5><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">使用远程桌面，来把本地的文件上传到虚拟机上。（</span><span class="pln">windows</span><span class="pun">操作系统为例）</span></code></li></ol></pre><p>首先需要开启<code>远程桌面</code>，“开始”-&gt;”计算机”(或此电脑)-&gt;”属性”：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/16dc68f648de1abcbbfecef78e7c7816_37678.png" alt=""></p>
<p>“远程设置”-&gt;”仅允许xxxxx”-&gt;”确定”，此时默认administrator用户是可以直接远程登录的，可以不用”选择用户”，如果需要使用其他用户登录远程，需要用管理员账号”选择用户”，这里就不赘述了:</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/8a3277ed459351d474602ae1da84c6a9_91595.png" alt=""></p>
<p>设置好以后，在虚拟机中同时按 win+R键，输入cmd打开cmd窗口，输入ipconfig查看当前虚拟机的ip：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/3a1ea984540490c72f6d1e71101516b3_70917.png" alt=""></p>
<p>将虚拟机ip记下，然后回到本机，按win+R键，输入mstsc打开远程连接，点连接，输入登录虚拟机的账号密码即可：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/8759458ac612225033fbf169e2eb3708_40009.png" alt=""></p>
<p>此时，你从本机直接复制的文件，可以直接通过远程桌面，粘贴到虚拟机当中。</p>
<h5 id="h5-u5C1Du8BD5u529Eu6CD5u4E09"><a name="尝试办法三" class="reference-link"></a><span class="header-link octicon octicon-link"></span>尝试办法三</h5><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">可以在虚拟机下载一个</span><span class="pln">QQ</span><span class="pun">，登录</span><span class="pln">QQ</span><span class="pun">，把文件发给自己，然后在虚拟机中进行下载。</span></code></li></ol></pre><h4 id="h4-5-"><a name="5. 虚拟机安装之后，如何保存快照（保存快照是一个好习惯）？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. 虚拟机安装之后，如何保存快照（保存快照是一个好习惯）？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">快照可以简单理解为：将你安装的虚拟机的某一时刻的状态保存下来（备份了那一时刻的所有数据内容），当你想恢复到之前的状态时（比如系统崩溃了），只需要还原快照即可。</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/5597/2cdc19c9c09afc77974e680005d4293e_94452.png" alt=""></p>
<p>查看拍摄的快照：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/af8da857b9e8aa6ad5891b6880eb3aed_96593.png" alt=""></p>
<p>恢复快照（快照还原）：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/ce277a72e6787d225123921dfad9f07f_34752.png" alt=""></p>
<p><strong>注意：拍摄快照需要占用磁盘空间，在使用虚拟机拍摄快照时，不需要拍摄很多快照，一般在刚安装时先拍摄一个，后面需要时再拍摄即可。</strong></p>
<h3 id="h3-0x2-1-2-"><a name="0x2.1.2 计算机基础命令和概念讲解" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.1.2 计算机基础命令和概念讲解</h3><h4 id="h4-1-ip-"><a name="1. 什么是ip？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 什么是ip？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">ip</span><span class="pun">就是你的计算机在互联网上的地址，可以理解为你淘宝买东西的时候你写的收货地址.</span></code></li></ol></pre><h4 id="h4-2-ip-ip-"><a name="2. 公网ip和内网ip的区别?" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 公网ip和内网ip的区别?</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">每个人只要输入公网</span><span class="pln">ip</span><span class="pun">就能找到对应服务器，但是内网</span><span class="pln">ip</span><span class="pun">是路由器通过</span><span class="pln">DHCP</span><span class="pun">协议分配的，只能在相同内网中才能互相访问.</span></code></li></ol></pre><h4 id="h4-3-"><a name="3. 怎么理解域名？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 怎么理解域名？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">因为域名更好记忆，以百度为例，你想想，百度的域名</span><span class="pln">baidu</span><span class="pun">.</span><span class="pln">com</span><span class="pun">，假设对应的公网</span><span class="pln">IP</span><span class="pun">是</span><span class="lit">123.125</span><span class="pun">.</span><span class="lit">114.144</span><span class="pun">，你访问的时候更记</span><span class="pln">baidu</span><span class="pun">.</span><span class="pln">com </span><span class="pun">还是</span><span class="lit">123.125</span><span class="pun">.</span><span class="lit">114.144</span><span class="pun">呢。</span></code></li></ol></pre><h4 id="h4-4-web-tcp-ip-"><a name="4.关于web通信原理,学安全要去理解tcp/ip吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4.关于web通信原理,学安全要去理解tcp/ip吗？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">不需要，咱们刚开始只需要稍微了解下</span><span class="pln">http</span><span class="pun">协议就行</span></code></li></ol></pre><h3 id="h3-0x2-1-3-web-"><a name="0x2.1.3 快速自建web安全测试环境" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.1.3 快速自建web安全测试环境</h3><h4 id="h4-1-phpstudy-"><a name="1. phpstudy哪里可以下载？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. phpstudy哪里可以下载？</h4><p>可以去官网下载，也可以在群里下载；<br>    官网下载网址是：<a href="https://www.xp.cn/download.html">Windows版phpstudy下载 - 小皮面板(phpstudy) (xp.cn)</a>，最新版长下面这个样子：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/2c7f8657b895ae139c9b92c8befcf7fd_53808.png" alt=""></p>
<p>咱课件提供的phpstudy是2016版本的:</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/554d63cdecbcd5f9cda75ec101950512_41684.png" alt=""></p>
<h4 id="h4-2-phpstudy-"><a name="2. phpstudy安装好后，数据库账号密码是多少？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. phpstudy安装好后，数据库账号密码是多少？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">phpstudy</span><span class="pun">默认账号密码是：</span><span class="pln">root root</span></code></li></ol></pre><h4 id="h4-3-phpmyadmin-"><a name="3. phpmyadmin默认用户名密码是什么？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. phpmyadmin默认用户名密码是什么？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">默认账号密码是：</span><span class="pln"> root root</span></code></li><li class="L1"><code><span class="pun">当然，如果你自己设置了数据库账号密码，则以你自己设置的账号密码去登录即可</span></code></li></ol></pre><h4 id="h4-4-phpstudy-apache-"><a name="4. 在使用phpstudy时，点击启动发现apache启动不了怎么办？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. 在使用phpstudy时，点击启动发现apache启动不了怎么办？</h4><p>你所遇到的应该是如下情况：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/915e0e2745548c4ac261143503ac681b_57612.png" alt=""><br>这种情况一般是由于系统中有一个进程（例如iis）占用了80端口，而apache也需要使用80端口，这就产生了<code>端口冲突问题</code>，此时可以在phpstudy中找到：<code>其他选项菜单 -&gt; 环境端口检测 -&gt; 环境端口检测</code><br><img src="https://nc0.cdn.zkaq.cn/md/5597/149b123f30c2953f33db9d0b8a420817_17365.png" alt=""></p>
<p>然后点击<code>检测端口</code>和<code>尝试强制关闭相关进程并启动</code>即可：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/808952d461232e18d028bab84d236186_64787.png" alt=""></p>
<h4 id="h4-5-phpstudy-web-"><a name="5. 怎么使用phpstudy快速搭建web环境，如何快速建站？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. 怎么使用phpstudy快速搭建web环境，如何快速建站？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">在网上下载</span><span class="pln">CMS</span><span class="pun">源代码（或者使用咱们课件中提供的源代码，没有的宝子可以找我要），将</span><span class="pln">CMS</span><span class="pun">源码放在</span><span class="pln">phpstudy</span><span class="pun">的</span><span class="pln">WWW</span><span class="pun">目录下（</span><span class="pln">PS</span><span class="pun">:建议在</span><span class="pln">WWW</span><span class="pun">目录中自己建一个</span><span class="str">`英文目录`</span><span class="pun">对应搭建的网站，方便自己做站点管理），然后设置好网站根目录，访问安装的文件夹就可以实现快速建站。</span></code></li></ol></pre><p>这里以dedecms为例，手把手教你如何快速搭建一个站点QAQ<br>首先，我们将dedecms的源码压缩包放入WWW目录并解压：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/17bd4ae01a6e178b559987d85d99f04f_81734.png" alt=""></p>
<p>解压后，我们来设置一下我们的<code>网站根目录</code>，打开phpstusdy，<code>其他选项菜单 -&gt; 站点域名管理</code></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/2c5e87b92451a7e6e5fca305d33a48e9_78614.png" alt=""></p>
<p>然后，<code>网站域名</code>和<code>第二域名</code>都设置为<code>127.0.0.1</code>(PS: <code>127.0.0.1</code>表示本地，电脑本身的意思)、端口先不用管，设置网站根目录选择到：<code>uploads</code>目录，就是我们dedecms网站源码所在的目录，然后点击<code>新增</code>以及<code>保存设置并生成配置文件</code><br><img src="https://nc0.cdn.zkaq.cn/md/5597/a8c2f6dbea157adf0568568b58d581a0_32793.png" alt=""></p>
<p>最后打开浏览器，访问<code>127.0.0.1</code>即可开始网站的安装啦~~ ^_^<br><img src="https://nc0.cdn.zkaq.cn/md/5597/933a6df609c575060b0ae7a16aa7f2f4_58624.png" alt=""></p>
<h2 id="h2-0x2-2-"><a name="0x2.2 网络安全法（讲解）" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.2 网络安全法（讲解）</h2><h3 id="h3-0x2-2-1-"><a name="0x2.2.1 点进来看看，有惊喜~" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.2.1 点进来看看，有惊喜~</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">OK</span><span class="pun">，你还是点进来看了，那么翻到咱们课件</span><span class="pln">PPT</span><span class="pun">第四页，可以默念，可以朗读^</span><span class="pln">_</span><span class="pun">^，学法的目的在于希望同学们可以时刻保持安全意识和法律意识，保护好自己哦~</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/5597/8d20b2aff57ee6323ec4e70ccdcf4a7d_10330.png" alt=""></p>
<h2 id="h2-0x2-3-web-"><a name="0x2.3 Web安全前后端基础" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.3 Web安全前后端基础</h2><h3 id="h3-0x2-3-1-php-"><a name="0x2.3.1 后端基础PHP———表单验证" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.3.1 后端基础PHP———表单验证</h3><h4 id="h4-1-"><a name="1. 表单验证的基本流程是什么？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 表单验证的基本流程是什么？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">在登陆页面提交信息，提交到后端数据库验证，然后返回信息到其他或原有页面.</span></code></li></ol></pre><h4 id="h4-2-post-get-"><a name="2. POST提交方式和GET方式有什么区别" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. POST提交方式和GET方式有什么区别</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">GET</span><span class="pun">方式通过</span><span class="pln">url</span><span class="pun">传参，比如：</span><span class="pln">http</span><span class="pun">:</span><span class="com">//xxx.com/?id=1 ；</span></code></li><li class="L1"><code><span class="pln">POST</span><span class="pun">方式则会将传参放到请求包的请求体当中，对于普通用户而言是不可见的，通过抓包软件如</span><span class="pln">burp</span><span class="pun">或者</span><span class="pln">F12</span><span class="pun">进行分析才能看见；</span></code></li><li class="L2"><code><span class="pln">POST</span><span class="pun">方式相对于</span><span class="pln">GET</span><span class="pun">方式传参数量可以多很多；</span></code></li></ol></pre><h4 id="h4-3-target-"><a name="3. 表单中的target属性有什么作用？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 表单中的target属性有什么作用？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">target</span><span class="pun">属性决定表单点击提交后究竟是新打开一个页面还是当前页面跳转</span></code></li></ol></pre><h3 id="h3-0x2-3-2-"><a name="0x2.3.2 渗透测试常用工具讲解" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.3.2 渗透测试常用工具讲解</h3><h4 id="h4-1-"><a name="1. 环境变量是什么，设置环境变量的意义？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 环境变量是什么，设置环境变量的意义？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">环境变量一般是指在操作系统中用来指定操作系统运行环境的一些参数，如果我定义了这个环境变量的路径，那么当在</span><span class="pln">windows</span><span class="pun">系统的变量中寻找不到的时候，就会去我添加的路径去寻找对应的东西。</span></code></li><li class="L1"><code><span class="pun">如果我没有把</span><span class="typ">Python</span><span class="pun">加入环境变量，我在</span><span class="pln">cmd</span><span class="pun">中不能直接运行</span><span class="pln">python</span><span class="pun">,因为在系统路径里面找不到</span><span class="pln">python</span><span class="pun">这个东西，然后加了环境变量，于是乎就会去我添加的路径查找，然后他发现了，有一个东西交</span><span class="pln">python</span><span class="pun">然后调用了。</span></code></li></ol></pre><h4 id="h4-2-java-"><a name="2. java如何设置环境变量？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. java如何设置环境变量？</h4><p>教程链接地址：<a href="https://m.runoob.com/java/java-environment-setup.html">Java 开发环境配置 | 菜鸟教程 (runoob.com)</a></p>
<h4 id="h4-3-sqlmap-"><a name="3. sqlmap最新版获取？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. sqlmap最新版获取？</h4><p>sqlmap官网获取：<a href="https://sqlmap.org/">https://sqlmap.org/</a> 【推荐】<br>或者github地址：<a href="https://github.com/sqlmapproject/sqlmap">https://github.com/sqlmapproject/sqlmap</a></p>
<h4 id="h4-4-sqlmap-"><a name="4. sqlmap如何运行起来？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. sqlmap如何运行起来？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">首先你得安装好</span><span class="pln">python</span></code></li><li class="L1"><code><span class="pun">然后打开</span><span class="pln">cmd</span><span class="pun">命令行，</span><span class="pln">cd</span><span class="pun">到</span><span class="pln">sqlmap</span><span class="pun">所在目录</span></code></li><li class="L2"><code><span class="pun">然后使用</span><span class="pln"> python sqlmap</span><span class="pun">.</span><span class="pln">py </span><span class="pun">运行</span><span class="pln">sqlmap</span></code></li></ol></pre><h4 id="h4-5-sqlmap-"><a name="5. sqlmap指令太多了记不住怎么办？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. sqlmap指令太多了记不住怎么办？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">在这里，主要说一个学习方法就是不要去死记一些命令，无论是</span><span class="pln">sqlmap</span><span class="pun">指令，还是计算机命令、代码等，去背指令没有任何意义，多用，用着用着自然而然就能打出来，指令用到不记得的时候直接去查相关使用手册就行了。</span></code></li><li class="L1"><code><span class="pln">sqlmap</span><span class="pun">手册：</span><span class="pln">https</span><span class="pun">:</span><span class="com">//www.cnblogs.com/hongfei/p/3872156.html</span></code></li></ol></pre><h4 id="h4-6-sqlmap-"><a name="6. SqlMap中探测等级的区别？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>6. SqlMap中探测等级的区别？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">当–</span><span class="pln">level</span><span class="pun">的参数设定为</span><span class="lit">2</span><span class="pun">或者</span><span class="lit">2</span><span class="pun">以上的时候，</span><span class="pln">sqlmap</span><span class="pun">会尝试注入</span><span class="typ">Cookie</span><span class="pun">参数；</span></code></li><li class="L1"><code><span class="pun">当–</span><span class="pln">level</span><span class="pun">参数设定为</span><span class="lit">3</span><span class="pun">或者</span><span class="lit">3</span><span class="pun">以上的时候，会尝试对</span><span class="typ">User</span><span class="pun">-</span><span class="typ">Angent</span><span class="pun">，</span><span class="pln">referer</span><span class="pun">进行注入。</span></code></li></ol></pre><h4 id="h4-7-sqlmap-"><a name="7. sqlmap如何清除缓存重新测试？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>7. sqlmap如何清除缓存重新测试？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">使用参数：</span><span class="pln"> </span><span class="pun">--</span><span class="pln">flush</span><span class="pun">-</span><span class="pln">session</span><span class="pun">，他将会刷新会话，进行测试</span></code></li></ol></pre><h4 id="h4-8-burp-"><a name="8. burp如何配置安装抓浏览器的数据包？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>8. burp如何配置安装抓浏览器的数据包？</h4><h5 id="h5-burp-"><a name="burp安装，激活" class="reference-link"></a><span class="header-link octicon octicon-link"></span>burp安装，激活</h5><p>这也是很多宝子问的问题，在这里，我写一个保姆级教程吧，希望对宝子们有用~~<br><code>注意：本教程的前提是宝子们把java环境安装并配置好环境变量哦</code></p>
<p>OK,首先，我们直接打开我发的新的burp，解压zip包，双击运行<code>BurpSuiteLoader1.jar</code><br><img src="https://nc0.cdn.zkaq.cn/md/5597/d8c0136ae0fd432c7a0c2881228e1bbb_67670.png" alt=""></p>
<p>然后会弹出一个页面，点击<code>run</code>后，弹出第二个页面，点<code>I Accept</code>接受用户协议：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/f76a80f8bbb7231bcc64dacd0994cfd9_67125.png" alt=""></p>
<p>然后复制激活密钥，点击<code>NEXT</code>：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/1f4c0d9c0764421788f670ee85696a2c_38144.png" alt=""></p>
<p>点击<code>Manual activation</code>选择手动激活模式：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/14aebdde2d885fb9a633a82f3200c4c6_40481.png" alt=""></p>
<p>将<code>copy request</code>中的代码复制到<code>Activation request</code>，将<code>Activation response</code>中的代码复制到<code>Paste resoponse</code>，勾选上屏蔽跟新和自动运行，然后点<code>Next</code><br><img src="https://nc0.cdn.zkaq.cn/md/5597/db0ec75413d5e3d76bc2653970c052cc_60785.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/05d028109806d51c20aae9ee911caadd_78854.png" alt=""></p>
<p>然后就可以正常使用burp了，此时我们的burp是默认监听本地的8080端口的：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/433a160510ab0fb1ea86e05a7565898d_28948.png" alt=""></p>
<h5 id="h5--proxy-switchyomega-burp-"><a name="浏览器安装、使用代理插件Proxy SwitchyOmega、证书安装、BURP抓包？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>浏览器安装、使用代理插件Proxy SwitchyOmega、证书安装、BURP抓包？</h5><p><code>Proxy SwitchyOmega</code>这款插件是火狐、谷歌、edge浏览器插件市场上都能够搜到的插件，直接在管理扩展的搜索框中输入<code>Proxy SwitchyOmega</code>，然后安装即可：<br>以下以edge举例安装：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/e32109f6c0a1c98f5360ff1179017e98_73432.png" alt=""></p>
<p><code>Proxy SwitchyOmega</code>使用：<br>点击<code>新建情景模式</code>，然后设置一个自己喜欢的名字，点击<code>创建</code><br><img src="https://nc0.cdn.zkaq.cn/md/5597/914604ee3131f322fa17f4f785e34a8b_84967.png" alt=""></p>
<p>按照序号的顺序依次设置：</p>
<ul>
<li>代理协议选择HTTP</li><li>代理服务器设置127.0.0.1，即代理自己电脑的意思</li><li>代理端口设置为8080 ，即代理自己电脑上的8080端口</li><li>将不代理地址列表中默认的值全都删除</li><li>点击<code>应用选项</code>保存代理设置</li></ul>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/72e2e35ae2e5e0f68e9b3623f963527e_82283.png" alt=""></p>
<p>OK，到这里我们设置了一个名叫burp_test的代理，代理的是本地的8080端口，代理的流量协议为http/https，那么我们只是设置好了代理，要如何使用呢，且先看下文：<br>我们先访问www.baidu.com,在没有开代理的情况下，是可以正常访问的：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/49cccd7d266bd9109303c6e765516436_99000.png" alt=""><br>此时，我们尝试去抓百度的包，首先在扩展图标点击一下，将我们的Proxy SwitchyOmega显示出来（默认是收起来的）点击<code>小眼睛</code>：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/b86113528953a1953194ba1ba4106f8d_92485.png" alt=""></p>
<p>接下来设置让浏览器只代理百度这个域名的数据包（如果要抓其他域名或者IP的包也同样做如下设置即可，这也是该插件的优点，可以让你只抓某个IP或域名的包，方便你分析数据包，减少其他数据包的干扰）：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/0d519b9c0aa8c1f91daec9f36a26cbac_31656.png" alt=""><br>设置完成后我们发现访问百度失败了，这是因为浏览器没有安装burp的证书导致的：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/272cb1b026dc0a304dd8c8a3739f50ab_16522.png" alt=""></p>
<p>接下来，我们安装burp的证书：<br>浏览器访问<code>127.0.0.1:8080</code>，点击<code>CA Certificate</code>下载burp的证书：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/702556e6bfaf6a3405758b897411ea71_45556.png" alt=""><br>下载下来后文件名为<code>cacert.der</code>，这里，有一个小细节，如果你用的是edge浏览器，你需要将证书的后缀改为<code>.cer</code>，其他浏览器不需要改；</p>
<p>然后在edge的设置中，搜索<code>证书</code>：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/edc98b2a04658a25ef472cadb279fed7_62928.png" alt=""></p>
<p>打开证书管理页面，然后点击<code>导入</code>-&gt; <code>下一步</code> -&gt; <code>浏览</code>选择刚刚下载的burp证书：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/1bfa6c5dd3adba79c7398a76ba27d61d_55101.png" alt=""></p>
<p>然后<code>证书被分入下列存储</code>选择<code>受信任的根证书颁发机构</code><br><img src="https://nc0.cdn.zkaq.cn/md/5597/1c85c9c7580d50bb5b3d5889698826c8_94724.png" alt=""></p>
<p>完成后弹出<code>安全警告</code>，选择<code>是</code>，即可导入成功：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/8bb21e68fccd39e7cb036973cd3b18a7_32627.png" alt=""><br><img src="https://nc0.cdn.zkaq.cn/md/5597/2cc829ff2e91e4bd6d155dcefb0f0722_83468.png" alt=""></p>
<p>此时我们再次抓百度的包，发现仍然报隐私错误，因为系统还需要安装一遍burp的证书，因此，我们直接找到我们下载的证书，直接双击：<br><code>安装证书 -&gt; 当前用户 -&gt; 下一步</code><br><img src="https://nc0.cdn.zkaq.cn/md/5597/4197b1f88509d739c5de49f67b13be59_80508.png" alt=""></p>
<p>选择存储位置为<code>受信任根证书颁发机构</code>，然后导入成功：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/80fb5986d481854684381c47452774a2_44200.png" alt=""><br><img src="https://nc0.cdn.zkaq.cn/md/5597/e372ad805cbc148c4ec5c6750cb275e4_68198.png" alt=""></p>
<p>接下来再次访问百度抓包，此时能够正常加载出百度首页，burp也能够正常抓到包：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/f214892011efd0b818e34121427d627b_34427.png" alt=""></p>
<p><code>注意：如果安装系统证书和浏览器证书后抓百度的包仍然报"隐私错误"，可以重启一下虚拟机或者电脑试试哦~</code></p>
<h4 id="h4-9-burp-"><a name="9. 为什么要设置代理才能抓到数据包、burp是怎么抓到包的？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>9. 为什么要设置代理才能抓到数据包、burp是怎么抓到包的？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">浏览器和服务器是直接通信的，而我们增加了代理，就把直接发送到服务器的数据发送到你设置的代理的端口。</span></code></li><li class="L1"><code><span class="typ">Burp</span><span class="pln"> </span><span class="typ">Suite</span><span class="pun">代理工具是以拦截代理的方式，拦截所有通过代理的网络流量，如客户端的请求数据、服务器端的返回信息等。</span></code></li><li class="L2"><code><span class="typ">Burp</span><span class="pln"> </span><span class="typ">Suite</span><span class="pun">主要拦截</span><span class="pln">http</span><span class="pun">和</span><span class="pln">https</span><span class="pun">协议的流量，通过拦截，</span><span class="pln">burp </span><span class="typ">Suite</span><span class="pun">以中间人的方式，可以对客户端请求数据、服务端返回做各种处理，以达到安全评估测试的目的</span></code></li></ol></pre><p>以下以图的方式来理解代理（或者说burp抓包）:</p>
<p>在没有设置代理的情况下，一个用户使用浏览器发起请求的流程如下：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/61ddcd7ab7177060d532655610e8cbc4_33905.png" alt=""></p>
<p>当挂上了代理软件或者说代理服务器时，一个用户使用浏览器发起请求的流程如下：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/971dd7bb058abafe0ca211b479a80470_71131.png" alt=""></p>
<h4 id="h4-10-8080-"><a name="10. 设置代理监听的8080端口，能改成别的端口吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>10. 设置代理监听的8080端口，能改成别的端口吗？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">burp</span><span class="pun">上默认的端口就是</span><span class="lit">8080</span><span class="pun">，我们可以修改，在</span><span class="pln">proxy</span><span class="pun">模块</span><span class="pln">option</span><span class="pun">处，点击设置的端口，然后点击</span><span class="pln">edit</span><span class="pun">，就可以修改了，但记住一些常见的端口比如</span><span class="lit">3389</span><span class="pun">远程桌面这种系统使用的端口就不要使用啦，不然容易产生端口冲突问题</span><span class="pln">QAQ</span></code></li></ol></pre><h2 id="h2-0x2-4-"><a name="0x2.4 信息搜集" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.4 信息搜集</h2><h3 id="h3-0x2-4-1-"><a name="0x2.4.1 信息搜集的意义—渗透测试的灵魂" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.4.1 信息搜集的意义—渗透测试的灵魂</h3><h4 id="h4-1-cms"><a name="1. 如何查看网站cms" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 如何查看网站cms</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">F12</span><span class="pun">查看网页源代码，可能在页面源代码里</span></code></li><li class="L1"><code><span class="pun">或者用指纹识别的平台查找，例如：云溪指纹</span><span class="pln"> https</span><span class="pun">:</span><span class="com">//www.yunsee.cn/</span></code></li><li class="L2"><code><span class="pun">通过特殊的页面查看</span><span class="pln">CMS</span><span class="pun">信息，比如有些</span><span class="pln">CMS</span><span class="pun">会在</span><span class="pln">robots</span><span class="pun">.</span><span class="pln">txt</span><span class="pun">中写明</span><span class="pln">CMS</span><span class="pun">的名字和版本</span></code></li></ol></pre><h4 id="h4-2-c-"><a name="2. 什么是旁站，什么是C段，它俩的区别是什么？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 什么是旁站，什么是C段，它俩的区别是什么？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">旁站是指同</span><span class="pln">ip</span><span class="pun">(或者说同服务器下的)的不同网站</span></code></li><li class="L1"><code><span class="pln">C</span><span class="pun">段是指公网</span><span class="typ">Ip</span><span class="pun">同一网段下的网站</span></code></li></ol></pre><h4 id="h4-3-"><a name="3. 目录扫描用什么工具？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 目录扫描用什么工具？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">御剑、</span><span class="lit">7KB</span><span class="pun">、</span><span class="pln">dirsearch</span><span class="pun">等这些都是优秀的目录扫描工具，其中</span><span class="pln">dirsearch</span><span class="pun">需要</span><span class="pln">python</span><span class="pun">环境支持哦~</span></code></li></ol></pre><h4 id="h4-4-"><a name="4. 端口探测用什么工具？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. 端口探测用什么工具？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">目前主流是：</span><span class="typ">Nmap</span><span class="pun">，也有一些小众轻量化的扫描工具如：</span><span class="pln">portscan</span><span class="pun">等</span></code></li></ol></pre><h4 id="h4-5-"><a name="5. 如何识别页面是否伪静态？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. 如何识别页面是否伪静态？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">控制台输入</span><span class="pln"> javascript</span><span class="pun">:</span><span class="pln">alert</span><span class="pun">(</span><span class="pln">document</span><span class="pun">.</span><span class="pln">lastModified</span><span class="pun">)，如果网站是个</span><span class="pln">html</span><span class="pun">,但是显示的却是现在的时间，就是伪静态页面</span></code></li></ol></pre><h3 id="h3-0x2-4-2-1-amp-2"><a name="0x2.4.2 信息收集实战 1 &amp; 2" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.4.2 信息收集实战 1 &amp; 2</h3><h4 id="h4-1-"><a name="1. 信息收集脑图" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 信息收集脑图</h4><p><img src="https://nc0.cdn.zkaq.cn/md/5597/d3a4de73b56786c9fb905fb6de4463cd_43631.png" alt=""></p>
<h2 id="h2-0x2-5-"><a name="0x2.5 注入——全方位利用" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.5 注入——全方位利用</h2><h3 id="h3-0x2-5-1-sql-"><a name="0x2.5.1 SQL注入的原理分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.5.1 SQL注入的原理分析</h3><h4 id="h4-1-sql-"><a name="1. sql注入本质是什么" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. sql注入本质是什么</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">把用户的输入当做</span><span class="pln">SQL</span><span class="pun">语句执行。</span></code></li></ol></pre><h4 id="h4-2-navicat-"><a name="2. 数据库管理工具Navicat安装、与破解激活教程？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 数据库管理工具Navicat安装、与破解激活教程？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln"> navicat</span><span class="pun">是一款数据库管理工具，使用它我们可以清晰的看到数据库中的数据结构以及数据，能够很方便的进行查找以及数据管理。</span></code></li></ol></pre><p>安装与激活教程：<br>跟着下面这个篇文章一步步走，亲测有效~~~<br><code>这里只需要注意一点，在博客里面下载navicat12,下载安装好后，先不要启动navicat12哦~，其他按照博客中的教程走即可</code><br><a href="https://www.cnblogs.com/wei9593/p/11907307.html">https://www.cnblogs.com/wei9593/p/11907307.html</a></p>
<h4 id="h4-3-order-by-"><a name="3. order by的作用及含义？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. order by的作用及含义？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    order </span><span class="kwd">by</span><span class="pln"> </span><span class="pun">用于判断字段数，</span><span class="pln">order </span><span class="kwd">by</span><span class="pln"> </span><span class="pun">原有的作用是对字段进行一个排序，在</span><span class="pln">sql</span><span class="pun">注入中用</span><span class="pln">order </span><span class="kwd">by</span><span class="pln"> </span><span class="pun">来判断排序，</span><span class="pln">order </span><span class="kwd">by</span><span class="pln"> </span><span class="lit">1</span><span class="pun">就是对一个字段进行排序，如果一共四个字段，你</span><span class="pln">order </span><span class="kwd">by</span><span class="pln"> </span><span class="lit">5</span><span class="pln"> </span><span class="pun">数据库不知道怎么排序，于是乎就错误了无返回值。</span></code></li></ol></pre><h4 id="h4-4-"><a name="4. 闭合是什么？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. 闭合是什么？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">在</span><span class="pln">sql</span><span class="pun">查询中，代码比较严谨，括号和引号都得成双成对，引号内的默认是字符串不会当作</span><span class="pln">SQL</span><span class="pun">语句执行，所以必须闭合然后才能注入，当然有些</span><span class="pln">SQL</span><span class="pun">语句直接拼接，也就不用什么闭合了。</span></code></li></ol></pre><h4 id="h4-5-union-all-union-"><a name="5. union all 和 union 区别？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. union all 和 union 区别？</h4><p>如果输出的数据有相同的，union只会输出一次，而union all都会输出。</p>
<h4 id="h4-6-and-1-1-and-1-2-sql-"><a name="6. 为什么用and 1=1正常 and 1=2报错来判断是否存在SQL注入？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>6. 为什么用and 1=1正常 and 1=2报错来判断是否存在SQL注入？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">因为如果存在</span><span class="pln">SQL</span><span class="pun">注入，那么</span><span class="kwd">and</span><span class="pun">就是</span><span class="pln"> </span><span class="pun">和</span><span class="pln"> </span><span class="pun">的意思，</span><span class="lit">1</span><span class="pun">=</span><span class="lit">1</span><span class="pun">是一个恒等式，然后因为原本能够查出数据，那么两个真就是</span><span class="kwd">True</span><span class="pun">，但是</span><span class="lit">1</span><span class="pun">=</span><span class="lit">2</span><span class="pun">肯定是不可能的，这里就会返回一个</span><span class="kwd">False</span><span class="pun">,然后因为</span><span class="pln"> </span><span class="pun">和</span><span class="pln"> </span><span class="pun">必须两个真才返回</span><span class="kwd">True</span><span class="pun">,所以这里拼接就不成立返回</span><span class="kwd">False</span><span class="pun">。</span></code></li></ol></pre><h4 id="h4-7-and-1-1-and1-2-or-1-1-or-1-2-"><a name="7. 除了 and 1=1、and1=2，可以用 or 1=1 、or 1=2 吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>7. 除了 and 1=1、and1=2，可以用 or 1=1 、or 1=2 吗？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">可以，在常规的渗透测试中，建议都去尝试一下，根据不同的情况，去选择用</span><span class="pln"> </span><span class="kwd">and</span><span class="pln"> </span><span class="pun">还是用</span><span class="pln"> </span><span class="kwd">or</span><span class="pun">。</span></code></li></ol></pre><h4 id="h4-8-qwe-"><a name="8. 注入语句最后的 --是什么意思？为什么 -- 后面要加个 qwe？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>8. 注入语句最后的 --是什么意思？为什么 -- 后面要加个 qwe？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">     </span><span class="pun">--</span><span class="pln"> </span><span class="pun">减减空格在数据库中表示“注释”的意思，在</span><span class="pln">SQL</span><span class="pun">注入的时候使用</span><span class="pln"> </span><span class="pun">--</span><span class="pln"> qwe</span><span class="pun">用于注释掉后面的</span><span class="pln">SQL</span><span class="pun">语句，使我们构造的</span><span class="pln">SQL</span><span class="pun">语句能够正常执行。</span></code></li><li class="L1"><code><span class="pln">     </span><span class="pun">加</span><span class="pln">qwe</span><span class="pun">，首先</span><span class="pln">qwe</span><span class="pun">是我们随便打的字符，也可以写</span><span class="pln">aaa</span><span class="pun">,其作用主要是</span></code></li></ol></pre><h3 id="h3-0x2-5-2-post-head-"><a name="0x2.5.2 POST注入/HEAD注入" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.5.2 POST注入/HEAD注入</h3><h4 id="h4-1-post-"><a name="1. POST注入如何注入?" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. POST注入如何注入?</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    post</span><span class="pun">注入其实很简单，就是在</span><span class="pln">POST</span><span class="pun">传参的地方做注入，和前面课程《</span><span class="pln">SQL</span><span class="pun">注入的原理分析》中讲到的注入流程是一样的，只不过注入点在</span><span class="pln">POST</span><span class="pun">传参这个地方，就像同一个东西，只是放的位置不同。</span></code></li></ol></pre><h4 id="h4-2-post-"><a name="2. post注入会出现在哪里？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. post注入会出现在哪里？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">比较常见的是：登录框，搜索框，还有一些其实是在抓包的时候，如果看到</span><span class="pln">POST</span><span class="pun">数据包中有可疑参数可能存在注入，也可以去尝试看看，本质就在于</span><span class="str">"试"</span><span class="pun">嘛。</span></code></li></ol></pre><h4 id="h4-3-"><a name="3. 万能密码原理？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 万能密码原理？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="kwd">select</span><span class="pln"> username</span><span class="pun">,</span><span class="pln">password </span><span class="kwd">from</span><span class="pln"> users </span><span class="kwd">where</span><span class="pln"> username</span><span class="pun">=</span><span class="str">'admin'</span><span class="pln"> </span><span class="kwd">and</span><span class="pln"> password </span><span class="pun">=</span><span class="pln"> </span><span class="str">' '</span><span class="kwd">or</span><span class="pln"> </span><span class="lit">1</span><span class="pun">=</span><span class="lit">1</span><span class="pln"> </span><span class="pun">--</span><span class="pln"> qwe</span><span class="str">' limit 0,1</span></code></li><li class="L1"><code><span class="str">    （我们来看语句逻辑，where后面是条件，username和password之间是and连接，所以两个有一个为否返回就是否，但是or 1=1,这个返回真，否 or 真=真 ，-- qwe是注释，将后面的SQL语句注释掉，防止SQL语句受到干扰。）</span></code></li></ol></pre><h4 id="h4-4-head-"><a name="4. head头注入原理？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. head头注入原理？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">简单理解：在请求数据包头部(</span><span class="pln">HEAD</span><span class="pun">)字段做注入。</span></code></li></ol></pre><h4 id="h4-5-post-sqlmap-"><a name="5. POST注入用 SQLMAP 怎么测试？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. POST注入用 SQLMAP 怎么测试？</h4><p>POST可以通过-r参数指定数据包也可以使用--data去跑：</p>
<ul>
<li>首先，使用burp抓post数据包，然后在注入点打上<code>*</code>号标记,将数据包保存为 1.txt；<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">python sqlmap</span><span class="pun">.</span><span class="pln">py </span><span class="pun">-</span><span class="pln">r post</span><span class="pun">数据包文件名</span></code></li></ol></pre></li><li>python sqlmap.py -u url --data post数据</li></ul>
<h4 id="h4-6-head-sqlmap-"><a name="6. HEAD注入用 SQLMAP 怎么测试？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>6. HEAD注入用 SQLMAP 怎么测试？</h4><p>有两种方式：</p>
<ul>
<li>第一种就是和post注入一样，抓包，然后在注入点上打上<code>*</code>标记</li><li>第二种：加上参数 --level 3 将检测等级提高</li></ul>
<h4 id="h4-7-post-get-"><a name="7. POST和GET传参方式都会进行编码吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>7. POST和GET传参方式都会进行编码吗？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">GET</span><span class="pun">传参会进行</span><span class="pln">URL</span><span class="pun">编码，</span><span class="pln">POST</span><span class="pun">传参一般不会进行编码</span></code></li></ol></pre><h4 id="h4-8-post-get-"><a name="8. POST传参和GET传参有什么区别？(可以记一记，有的时候简单面试会问到)" class="reference-link"></a><span class="header-link octicon octicon-link"></span>8. POST传参和GET传参有什么区别？(可以记一记，有的时候简单面试会问到)</h4><ul>
<li>1,GET传参在URL中传参，POST传参在请求数据包的请求体中</li><li>2,GET传参一般长度限制为2048字节，POST传参长度一般无限制</li></ul>
<h3 id="h3-0x2-5-3-"><a name="0x2.5.3 宽字节注入" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.5.3 宽字节注入</h3><h4 id="h4-1-16-"><a name="1. 为什么在注入的时候使用的查询表名要用16进制进行编码？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 为什么在注入的时候使用的查询表名要用16进制进行编码？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">因为表名要用到单引号括起来，但是会被转义，单引号会被加上反斜杠对查询产生影响，所以可以使用</span><span class="lit">16</span><span class="pun">进制进行编码处理，</span><span class="lit">16</span><span class="pun">进制到了数据库中会被自动转换成字符串，</span><span class="pln"> </span><span class="pun">注意：</span><span class="lit">16</span><span class="pun">进制需要手动在前面加上</span><span class="pln"> </span><span class="lit">0x</span><span class="pln"> </span><span class="pun">。</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/5597/c6961545467feba37106eaa29019d4c4_12754.png" alt=""></p>
<h4 id="h4-2-16-"><a name="2. 除了使用16进制编码绕过外还有什么方法吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 除了使用16进制编码绕过外还有什么方法吗？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">有，可以使用嵌套子查询，比如：</span></code></li><li class="L1"><code><span class="str">'admin'</span><span class="pln"> </span><span class="pun">表名</span><span class="pln"> </span><span class="pun">可以使用以下语句来代替</span></code></li><li class="L2"><code><span class="pun">(</span><span class="kwd">select</span><span class="pln"> table_name </span><span class="kwd">from</span><span class="pln"> information_schema</span><span class="pun">.</span><span class="pln">tables </span><span class="kwd">where</span><span class="pln"> table_schema</span><span class="pun">=</span><span class="pln">database</span><span class="pun">()</span><span class="pln"> limit </span><span class="lit">0</span><span class="pun">,</span><span class="lit">1</span><span class="pun">)</span></code></li></ol></pre><h4 id="h4-3-"><a name="3. 如何开启魔术引号？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 如何开启魔术引号？</h4><p>在php的配置文件php.ini中，找到magic_quotes_gpc ,如果为on就是开启，为off就是关闭。<br><img src="https://nc0.cdn.zkaq.cn/md/5597/901309369d8247bbff8399ab78f75636_32317.png" alt=""></p>
<h4 id="h4-4-gbk-"><a name="4. 宽字节只发生在GBK编码上面吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. 宽字节只发生在GBK编码上面吗？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">并不是的，只要</span><span class="pln">PHP</span><span class="pun">的编码格式和数据库的编码格式不同，特别是字符不同的编码就可能会造成。</span></code></li></ol></pre><h4 id="h4-5-"><a name="5. 魔术引号默认开启吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. 魔术引号默认开启吗？</h4><p>魔术引号默认是开启的，但是在高版本中php5.4.0以后被移除。</p>
<h3 id="h3-0x2-5-4-"><a name="0x2.5.4 盲注" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.5.4 盲注</h3><h4 id="h4-1-substr-"><a name="1. 盲注中的substr()怎么用？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 盲注中的substr()怎么用？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    substr</span><span class="pun">()的功能是截取某个字符串的一部分。</span></code></li><li class="L1"><code><span class="pln">    substr</span><span class="pun">(要截取的字符串，从哪个位置开始截取，截取多少位)</span></code></li><li class="L2"><code></code></li><li class="L3"><code><span class="pln">    </span><span class="pun">例如：</span><span class="pln">substr</span><span class="pun">(</span><span class="str">'adminadmin'</span><span class="pun">,</span><span class="lit">1</span><span class="pun">,</span><span class="lit">3</span><span class="pun">)</span><span class="pln"> </span><span class="pun">--&gt;</span><span class="pln"> </span><span class="str">'adm'</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/5597/9b8f76c79208c9c243e49a6bf06db779_53639.png" alt=""></p>
<h4 id="h4-2-"><a name="2. 布尔盲注的原理，如何理解布尔盲注？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 布尔盲注的原理，如何理解布尔盲注？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">当</span><span class="pln">SQL</span><span class="pun">语句在数据库中执行有结果的时候，返回正确的页面（这个正确的页面可以是页面上有数据，页面显示正常等），当</span><span class="pln">SQL</span><span class="pun">语句在数据库中执行无结果的时候，返回错误的页面（例如返回的是空白页，或者页面上显示有错误等），而我们就是通过页面的两种不同显示状态，来做注入，这就叫布尔盲注。</span></code></li></ol></pre><h4 id="h4-3-"><a name="3. 布尔盲注和延时盲注有什么区别？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 布尔盲注和延时盲注有什么区别？</h4><p>一个根据返回页面的正常与否，一个根据页面响应时间判断，之前的语句是相同的，只是延时增加了if()判断和延时函数sleep()。</p>
<h4 id="h4-4-if-"><a name="4. if()判断如何使用？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. if()判断如何使用？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">食用方法：</span></code></li><li class="L1"><code><span class="pln">        </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">exp1</span><span class="pun">,</span><span class="pln">exp2</span><span class="pun">,</span><span class="pln">exp3</span><span class="pun">)</span></code></li><li class="L2"><code><span class="pln">    </span><span class="pun">解释：如果</span><span class="pln">exp1</span><span class="pun">执行成功，那么返回</span><span class="pln">exp2</span><span class="pun">，如果失败，返回</span><span class="pln">exp3</span></code></li></ol></pre><h2 id="h2-0x2-6-"><a name="0x2.6 数据库注入" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.6 数据库注入</h2><h3 id="h3-0x2-6-1-access-cookie-"><a name="0x2.6.1 Access—Cookie注入" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.6.1 Access—Cookie注入</h3><h4 id="h4-1-cookie-"><a name="1. cookie注入怎么理解，怎么做注入？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. cookie注入怎么理解，怎么做注入？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    cookie</span><span class="pun">注入简单理解就是：在请求数据包中的请求头部，</span><span class="typ">Cookie</span><span class="pun">字段这个地方做注入，其他流程都是一样的，只不过注入的位置不一样。</span></code></li></ol></pre><p>cookie注入做注入有两种方法：</p>
<ul>
<li>使用burp抓包，修改请求数据包的cookie字段</li><li>使用浏览器的控制台，document.cookie=xxx，然后刷新页面。</li></ul>
<h4 id="h4-2-cookie-cookie-sql-"><a name="2. 为啥我在做cookie注入的时候，在cookie字段写sql语句并且确认是正确的，但是就是注入不出来？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 为啥我在做cookie注入的时候，在cookie字段写sql语句并且确认是正确的，但是就是注入不出来？</h4><p>OK，同学，你是不是这种情况：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/019b85f216ce380959a39eadff6e7888_40527.png" alt=""></p>
<p>如果是这种情况的话，是注入不了的，因为你在GET传参中有id=171，而cookie中传参id=171 and 1=2 ,而当前这个网站后端代码是GET和POST传参优先的，如果你GET和COOKIE传相同的参数过去，当前这个站点会先取GET传参，因此，<code>在对这个网站做注入的时候，需要把GET中的传参删除</code>。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/832bc8dd5e8307af086563b02fe4ccde_66141.png" alt=""></p>
<h4 id="h4-3-"><a name="3. 有没有好用的编码工具或者在线网站？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 有没有好用的编码工具或者在线网站？</h4><p>在线网站：</p>
<ul>
<li><a href="http://www.hiencode.com/">http://www.hiencode.com/</a></li><li><a href="https://gchq.github.io/CyberChef/">https://gchq.github.io/CyberChef/</a></li><li>解码工具：</li><li>浏览器插件：Ctool / 安装教程：<a href="https://github.com/baiy/Ctool">https://github.com/baiy/Ctool</a></li><li>CaptfEncoder</li></ul>
<h3 id="h3-0x2-6-2-access-"><a name="0x2.6.2 Access—偏移注入" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.6.2 Access—偏移注入</h3><h4 id="h4-1-flag-"><a name="1. 偏移注入的flag在哪里？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 偏移注入的flag在哪里？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">如果你偏移注入成功了，可以</span><span class="pln">F12</span><span class="pun">查看一下源代码哦~</span></code></li></ol></pre><h3 id="h3-0x2-6-3-mysql-dns-"><a name="0x2.6.3 MySQL注入—Dns注入" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.6.3 MySQL注入—Dns注入</h3><h4 id="h4-1-dnslog-dns-"><a name="1. dnslog平台接收不到DNS注入外带的数据？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. dnslog平台接收不到DNS注入外带的数据？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">dnslog</span><span class="pun">.</span><span class="pln">cn</span><span class="pun">这个平台可能比较卡，需要等一会，可以多打几次，多刷新几次看看</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pun">一个</span><span class="pln">dnslog</span><span class="pun">平台是：</span><span class="pln">dnslog</span><span class="pun">.</span><span class="pln">cn </span></code></li><li class="L3"><code><span class="pun">另外推荐一个</span><span class="pln">dnslog</span><span class="pun">平台：</span><span class="pln">http</span><span class="pun">:</span><span class="com">//dnslog.pw/login 可以不用注册，使用"创建随机ID并登录"的方式去登录。</span></code></li></ol></pre><h4 id="h4-2-dns-"><a name="2. DNS注入原理？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. DNS注入原理？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">通过子查询，将内容拼接到域名内，让</span><span class="pln">load_file</span><span class="pun">()去访问共享文件，访问的域名被记录,此时变为显错注入,将盲注变显错注入,读取远程共享文件，通过拼接出函数做查询,拼接到域名中，访问时将访问服务器，记录后查看日志。</span></code></li></ol></pre><h4 id="h4-3-load_file-"><a name="3. load_file函数的作用？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. load_file函数的作用？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    load_file</span><span class="pun">函数主要用于读取文件并返回输出。</span></code></li></ol></pre><h4 id="h4-4-dns-linux-"><a name="4. DNS注入可以用在Linux的机器上面吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. DNS注入可以用在Linux的机器上面吗？</h4><p>不可以，因为这里其实依靠的是UNC，只有Windows有这个。</p>
<h3 id="h3-0x2-6-4-mssql-"><a name="0x2.6.4 MSSQL注入—反弹注入" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.6.4 MSSQL注入—反弹注入</h3><h4 id="h4-1-"><a name="1. 反弹注入使用到的外部连接数据库在哪里有？(看这里，不需要自己去注册的！！！)" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 反弹注入使用到的外部连接数据库在哪里有？(看这里，不需要自己去注册的！！！)</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">靶场提供的数据库地址（两个）：</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pun">地址：</span><span class="pln">den1</span><span class="pun">.</span><span class="pln">mssql8</span><span class="pun">.</span><span class="pln">gear</span><span class="pun">.</span><span class="pln">host</span></code></li><li class="L3"><code><span class="pun">初始化库：</span><span class="pln">zkaqzkaq1n</span></code></li><li class="L4"><code><span class="pun">账户名：</span><span class="pln">zkaqzkaq1n</span></code></li><li class="L5"><code><span class="pun">密码：</span><span class="typ">Rz7VjmvQ</span><span class="pun">!</span><span class="lit">6e</span><span class="pun">~</span></code></li><li class="L6"><code></code></li><li class="L7"><code><span class="pun">连接地址：</span><span class="pln">SQL5095</span><span class="pun">.</span><span class="pln">site4now</span><span class="pun">.</span><span class="pln">net</span></code></li><li class="L8"><code><span class="pun">库名：</span><span class="pln"> DB_14DC259_a94</span></code></li><li class="L9"><code><span class="pun">用户名：</span><span class="pln">DB_14DC259_a94_admin</span></code></li><li class="L0"><code><span class="pun">密码：</span><span class="pln">nsqvcf96310</span></code></li></ol></pre><h4 id="h4-2-"><a name="2. 反弹注入需要什么条件？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 反弹注入需要什么条件？</h4><p>需要配合堆叠注入，因为要执行insert into语句。</p>
<h4 id="h4-3-mssql-"><a name="3. 在MSSQL中为什么不能直接查询表里的字段？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 在MSSQL中为什么不能直接查询表里的字段？</h4><p>因为在MSSQL中，要使用表名结合表对应的id来查表里的字段，因为MSSQL中表名和id是绑定的。</p>
<h4 id="h4-4-mssql-"><a name="4. MSSQL中常用的语句？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. MSSQL中常用的语句？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">查用户建立的数据表</span></code></li><li class="L1"><code><span class="pln">    </span><span class="kwd">select</span><span class="pln"> name</span><span class="pun">,</span><span class="pln">id </span><span class="kwd">from</span><span class="pln"> dbo</span><span class="pun">.</span><span class="pln">sysobjects </span><span class="kwd">where</span><span class="pln"> xtype</span><span class="pun">=</span><span class="str">"U"</span><span class="pun">;</span></code></li><li class="L2"><code></code></li><li class="L3"><code><span class="pun">查询字段名</span></code></li><li class="L4"><code><span class="pln">    </span><span class="kwd">select</span><span class="pln"> name</span><span class="pun">,</span><span class="pln">id </span><span class="kwd">from</span><span class="pln"> dbo</span><span class="pun">.</span><span class="pln">syscolumns </span><span class="kwd">where</span><span class="pln"> id</span><span class="pun">=</span><span class="lit">244668</span><span class="pun">;</span></code></li><li class="L5"><code></code></li><li class="L6"><code><span class="pun">查询当前库名</span></code></li><li class="L7"><code><span class="pln">    </span><span class="kwd">select</span><span class="pln"> db_name</span><span class="pun">();</span></code></li></ol></pre><h3 id="h3-0x2-6-5-oracle-"><a name="0x2.6.5 Oracle注入—报错注入" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.6.5 Oracle注入—报错注入</h3><h4 id="h4-1-oracle-"><a name="1. Oracle系统表有哪些？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. Oracle系统表有哪些？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">主要记以下几个表：</span></code></li><li class="L1"><code><span class="pln">    DBA_TABLES </span><span class="pun">表示</span><span class="pln">DBA</span><span class="pun">拥有或可以访问的所有的表</span></code></li><li class="L2"><code></code></li><li class="L3"><code><span class="pln">    ALL_TABLES </span><span class="pun">表示某一个用户拥有或可以访问的所有的表</span></code></li><li class="L4"><code></code></li><li class="L5"><code><span class="pln">    USER_TABLES </span><span class="pun">表示某一个用户拥有的关系表</span></code></li><li class="L6"><code></code></li><li class="L7"><code><span class="pln">    </span><span class="pun">所需权限：</span><span class="pln">DBA_TABLES </span><span class="pun">&gt;</span><span class="pln"> ALL_TABLES </span><span class="pun">&gt;=</span><span class="pln"> USER_TABLES</span></code></li></ol></pre><h4 id="h4-2-oracle-"><a name="2. Oracle 使用查询语句获取数据时要注意什么？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. Oracle 使用查询语句获取数据时要注意什么？</h4><p>Oracle使用查询语句时，必须符合查询语法规范，也就是说必须满足：select username from admin 这种样式，如果没有表的情况下，需要使用 dual虚表来符合语法规则：select username from dual 。</p>
<h4 id="h4-3-oracle-"><a name="3. Oracle 是否需要大小写问题？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. Oracle 是否需要大小写问题？</h4><p>Oracle查询字段时不区分大小写，但查询数据时需要区分大小写。</p>
<h4 id="h4-4-oracle-"><a name="4. Oracle常用的一些语句有哪些？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. Oracle常用的一些语句有哪些？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">查所有的表</span></code></li><li class="L1"><code><span class="pln">    </span><span class="kwd">select</span><span class="pln"> </span><span class="pun">*</span><span class="pln"> </span><span class="kwd">from</span><span class="pln"> all_tables</span><span class="pun">;</span></code></li><li class="L2"><code></code></li><li class="L3"><code><span class="pun">查当前用户的表</span></code></li><li class="L4"><code><span class="pln">    </span><span class="kwd">select</span><span class="pln"> </span><span class="pun">*</span><span class="pln"> </span><span class="kwd">from</span><span class="pln"> user_tables</span><span class="pun">;</span></code></li><li class="L5"><code></code></li><li class="L6"><code><span class="pun">查所有的字段</span></code></li><li class="L7"><code><span class="pln">    selet </span><span class="pun">*</span><span class="pln"> </span><span class="kwd">from</span><span class="pln"> all_tab_columns</span><span class="pun">;</span></code></li><li class="L8"><code></code></li><li class="L9"><code><span class="pun">查当前用户的字段</span></code></li><li class="L0"><code><span class="pln">    </span><span class="kwd">select</span><span class="pln"> </span><span class="pun">*</span><span class="pln"> </span><span class="kwd">from</span><span class="pln"> user_tab_columns</span><span class="pun">;</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pun">查版本</span></code></li><li class="L3"><code><span class="pln">    </span><span class="kwd">select</span><span class="pln"> </span><span class="pun">*</span><span class="pln"> </span><span class="kwd">from</span><span class="pln"> v$version</span><span class="pun">;</span></code></li></ol></pre><h3 id="h3-0x2-6-6-sqlmap-waf-"><a name="0x2.6.6 SQLmap绕WAF脚本编写" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.6.6 SQLmap绕WAF脚本编写</h3><h4 id="h4-1-sqlmap-waf-"><a name="1. 课程或这哪搞sqlmap绕WAF那张脑图？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 课程或这哪搞sqlmap绕WAF那张脑图？</h4><p><img src="https://nc0.cdn.zkaq.cn/md/5597/20230703/16ed690b-f1f2-4491-9273-3f9cc315f2f1.png" alt=""></p>
<h2 id="h2-0x2-7-"><a name="0x2.7 前端渗透测试" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.7 前端渗透测试</h2><h3 id="h3-0x2-7-1-xss-"><a name="0x2.7.1 XSS的原理分析与解剖" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.7.1 XSS的原理分析与解剖</h3><h4 id="h4-1-xss-"><a name="1. XSS的本质（原理）？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. XSS的本质（原理）？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">将用户的输入当做前端代码执行。</span></code></li></ol></pre><h4 id="h4-2-"><a name="2. 反射型常见的三种触发方法？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 反射型常见的三种触发方法？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">     </span><span class="pun">标签法：&lt;</span><span class="pln">script</span><span class="pun">&gt;</span><span class="pln">alert</span><span class="pun">(</span><span class="lit">1</span><span class="pun">)&lt;/</span><span class="pln">sctipt</span><span class="pun">&gt;</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">     </span><span class="pun">事件触发：&lt;</span><span class="pln">img src</span><span class="pun">=</span><span class="str">"xxx"</span><span class="pln"> onerror</span><span class="pun">=</span><span class="pln">alert</span><span class="pun">(</span><span class="lit">1</span><span class="pun">)/&gt;</span></code></li><li class="L3"><code></code></li><li class="L4"><code><span class="pln">     </span><span class="pun">伪协议：&lt;</span><span class="pln">a href</span><span class="pun">=</span><span class="pln">javascript</span><span class="pun">:</span><span class="pln">alert</span><span class="pun">(</span><span class="lit">1</span><span class="pun">)&gt;</span><span class="lit">123</span><span class="pun">&lt;/</span><span class="pln">a</span><span class="pun">&gt;</span></code></li></ol></pre><h4 id="h4-3-xss-"><a name="3. XSS在什么地方可以插入？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. XSS在什么地方可以插入？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">见框就插</span></code></li></ol></pre><h3 id="h3-0x2-7-2-xss"><a name="0x2.7.2 存储型XSS" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.7.2 存储型XSS</h3><h4 id="h4-1-xss-"><a name="1. 存储型xss也可以通过弹窗来验证吗？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. 存储型xss也可以通过弹窗来验证吗？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">可以，但是不建议，因为存储型</span><span class="pln">XSS</span><span class="pun">如果弹窗造成的影响会比较大，比如你在评论区发现一个存储型</span><span class="pln">XSS</span><span class="pun">，然后你插入了一个弹窗代码，那么所有浏览此评论的用户都会被弹窗。</span></code></li></ol></pre><h4 id="h4-2-xss-"><a name="2. 存储型xss可能出现在哪些位置呢？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 存储型xss可能出现在哪些位置呢？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">可以插入数据的地方，比如用户注册，留言板，上传文件的文件名处，管理员可见的报错信息（会记录错误日志的地方）等。</span></code></li></ol></pre><h4 id="h4-3-xss-payload-cookie-"><a name="3. xss平台的payload为什么就可以获取别人的cookie呢？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. xss平台的payload为什么就可以获取别人的cookie呢？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">简单理解：</span><span class="pln">xss</span><span class="pun">平台的代码写好了有读取别人</span><span class="pln">cookie</span><span class="pun">的功能，并且能够将读取到的</span><span class="pln">cookie</span><span class="pun">发送到</span><span class="pln">xss</span><span class="pun">平台，因此你在</span><span class="pln">URL</span><span class="pun">中添加了</span><span class="pln">XSS</span><span class="pun">代码，别人点击，</span><span class="pln">XSS</span><span class="pun">平台就能看到他的</span><span class="pln">cookie</span><span class="pun">。</span></code></li></ol></pre><h4 id="h4-4-xss-xss-cookie-"><a name="4. 打靶场的时候，使用XSS平台打了好多次，xss平台就是收不到Cookie呀咋办？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. 打靶场的时候，使用XSS平台打了好多次，xss平台就是收不到Cookie呀咋办？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    xss</span><span class="pun">平台推荐使用：</span><span class="pln">xsscom</span><span class="pun">.</span><span class="pln">com</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">    </span><span class="pun">来自</span><span class="lit">20</span><span class="pun">期同学推荐的一个</span><span class="pln">XSS</span><span class="pun">平台：</span><span class="pln">https</span><span class="pun">:</span><span class="com">//xssaq.com/ ，感谢大佬的提议</span></code></li><li class="L3"><code></code></li><li class="L4"><code><span class="pln">    </span><span class="pun">还有别的平台：</span><span class="pln">xss8</span><span class="pun">.</span><span class="pln">cc  xss</span><span class="pun">.</span><span class="pln">pt </span></code></li></ol></pre><p>第二，靶场提交那个地方，手机号和姓名是需要填的，填了后台机器人才会给你点击链接哟（又是一个小细节）。</p>
<h4 id="h4-5-xss-"><a name="5. xss平台搭建教程（仅用于技术教学）" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. xss平台搭建教程（仅用于技术教学）</h4><p>有的同学可能对xss平台比较感兴趣，这里我写了一个xss-platform的搭建过程，感兴趣的话可以自己在虚拟机上搭建玩一玩哈；<br><strong><em>不推荐搭建在公网上，如果非要搭建，请将注册功能删除掉，以及将登录的账号密码设复杂一些。</em></strong></p>
<h5 id="h5-u73AFu5883u51C6u5907"><a name="环境准备" class="reference-link"></a><span class="header-link octicon octicon-link"></span>环境准备</h5><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">        xss</span><span class="pun">平台源码：</span><span class="pln">https</span><span class="pun">:</span><span class="com">//github.com/78778443/xssplatform</span></code></li><li class="L1"><code><span class="pln">        windows</span><span class="pun">操作系统</span></code></li><li class="L2"><code><span class="pln">        phpstudy</span><span class="pun">快速建站软件：</span><span class="pln">https</span><span class="pun">:</span><span class="com">//www.xp.cn/</span></code></li><li class="L3"><code></code></li><li class="L4"><code><span class="pln">        </span><span class="pun">教程步骤来自于这位大佬的博客：</span><span class="pln">https</span><span class="pun">:</span><span class="com">//icepeak.icu/2021/03/03/da-jian-xss-ping-tai/#toc-heading-2， 在此向大佬致谢</span></code></li></ol></pre><h5 id="h5-u642Du5EFAu8FC7u7A0B"><a name="搭建过程" class="reference-link"></a><span class="header-link octicon octicon-link"></span>搭建过程</h5><p>将XSS平台源码解压到phpstudy的网站根目录：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/95a1bcef56db84766a2bdb04dcd7c628_96778.png" alt=""></p>
<p>修改源码中的配置文件config.php:</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">  </span><span class="str">'dbHost'</span><span class="pln"> </span><span class="pun">=&gt;</span><span class="pln"> </span><span class="str">'127.0.0.1'</span><span class="pun">,</span><span class="pln">    </span><span class="com"># 主机地址，如果是本机搭建，就填本机ip</span></code></li><li class="L1"><code><span class="pln">  </span><span class="str">'dbUser'</span><span class="pln"> </span><span class="pun">=&gt;</span><span class="pln"> </span><span class="str">'root'</span><span class="pun">,</span><span class="pln">         </span><span class="com"># 数据库用户名</span></code></li><li class="L2"><code><span class="pln">  </span><span class="str">'dbPwd'</span><span class="pln"> </span><span class="pun">=&gt;</span><span class="pln"> </span><span class="str">'root'</span><span class="pun">,</span><span class="pln">          </span><span class="com"># 数据库密码</span></code></li><li class="L3"><code><span class="pln">  </span><span class="str">'database'</span><span class="pln"> </span><span class="pun">=&gt;</span><span class="pln"> </span><span class="str">'xssplatform'</span><span class="pun">,</span><span class="pln">  </span><span class="com"># xss平台的数据库，默认是 xssplatform</span></code></li><li class="L4"><code><span class="pln">  </span><span class="str">'urlroot'</span><span class="pln"> </span><span class="pun">=&gt;</span><span class="pln"> </span><span class="str">'http://127.0.0.1'</span><span class="pun">,</span><span class="pln">    </span><span class="com"># url根路径，如果是本机搭建，就填本机ip</span></code></li><li class="L5"><code><span class="pln">  </span><span class="str">'urlrewrite'</span><span class="pln"> </span><span class="pun">=&gt;</span><span class="pln"> </span><span class="kwd">false</span><span class="pun">,</span><span class="pln">               </span><span class="com"># 默认就行</span></code></li><li class="L6"><code><span class="pln">  </span><span class="str">'filepath'</span><span class="pln"> </span><span class="pun">=&gt;</span><span class="pln"> </span><span class="str">'D:/phpstudy_pro/WWW/xssplatform-master/xssplatform-master/upload'</span><span class="pun">,</span><span class="pln">  </span><span class="com"># 改为 "xss源码的路径地址/upload"</span></code></li><li class="L7"><code><span class="pln">  </span><span class="str">'fileprefix'</span><span class="pln"> </span><span class="pun">=&gt;</span><span class="pln"> </span><span class="str">'http://127.0.0.1/upload'</span><span class="pun">,</span><span class="pln">    </span><span class="com"># http://主机ip/upload</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/5597/d6817ff32235877f5bb99212ee68b295_15164.png" alt=""></p>
<p>保存配置后，将网站根目录指向xss平台源码所在的目录：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/f1cf20d590d707f159f8e6600cbc4132_97315.png" alt=""></p>
<p>将XSS平台自身的数据库导入我们本地的数据库：<br>进入phpstudy的mysql命令行（根据自己电脑phpstudy的安装路径去找，我的路径是D:\phpstudy_pro\Extensions\MySQL5.7.26\bin），在文件栏输入cmd进入命令行，然后输入<code>mysql -uroot -p数据库密码</code>:</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/27d29fe4488508c6b2e9de22b57079f2_52451.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/7b94d433341cc2a1e42210dcea44a858_38256.png" alt=""></p>
<p>创建一个数据库：<code>create database xssplatform;</code><br>进入数据库：<code>use xssplatform;</code><br>导入xss平台数据库文件：<code>source xss平台数据库文件命令（将sql文件拖进命令行即可）</code></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/03e925548f15be8e969941f8b9573c93_56851.png" alt=""></p>
<p>修改数据库域名：<code>update oc_module set code=replace(code,'http://xsser.me','配置文件中设置的URL根路径')</code></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/957e4f0612795ac99516aa1cbc9bee24_61280.png" alt=""></p>
<p>设置伪静态： xss平台源码目录中，有一个安装说明，复制apache方式下的内容：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/ff24572c7e3cd0bb1ff5207e48878607_39789.png" alt=""></p>
<p>然后在phpstudy中，打开伪静态页面设置：管理 -&gt; 修改 -&gt; 伪静态，将复制的内容粘贴进框里，然后点 确定</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/2c7409b6feb3996063f87780e6bc1e20_10786.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/cfed1071bb5e32db828465dffae2ab69_79098.png" alt=""></p>
<p>接下来，浏览器访问<a href="http://127.0.0.1">http://127.0.0.1</a> ,搭建成功~， 注册个用户进去玩一玩：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/cad5fe5b9962ec83d6cf0149319843a9_78186.png" alt=""></p>
<p>在本地写一段含有XSS漏洞的php代码：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/30d954c76bf563cd74f5a9763685e1b2_20173.png" alt=""></p>
<p>然后进入xss平台，获取xss攻击代码，使用攻击代码对我们的测试页面进行攻击：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/700299e351ad998e5519059b46a04257_11441.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/9faf543952cfe6ba1e57e927fde826fa_97845.png" alt=""></p>
<p>至此，说明我们的xss平台搭建并且能够运用了。</p>
<h3 id="h3-0x2-7-3-dom-based-xss"><a name="0x2.7.3 Dom Based XSS" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.7.3 Dom Based XSS</h3><h4 id="h4-1-dom-xss-"><a name="1. DOM型XSS究竟是持久型还是非持久型，怎么理解？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. DOM型XSS究竟是持久型还是非持久型，怎么理解？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">既有持久也有非持久，</span><span class="pln">DOM</span><span class="pun">型最简单的理解方法就是通过网页自带</span><span class="pln">JS</span><span class="pun">操作后造成的</span><span class="pln">XSS</span><span class="pun">，例如本身可能有</span><span class="pln">HTML</span><span class="pun">实体编码，结果我们输出点因为</span><span class="pln">JS</span><span class="pun">会进行解码，然后我们打了编码过的字符串，绕过了</span><span class="pln">HTML</span><span class="pun">实体编码造成的</span><span class="pln">XSS</span><span class="pun">就属于</span><span class="pln">DOM</span><span class="pun">型。</span></code></li></ol></pre><h4 id="h4-2-native-waf-"><a name="2. 为什么靶场可以用native编码来绕waf？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. 为什么靶场可以用native编码来绕waf？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">因为</span><span class="pln">document</span><span class="pun">.</span><span class="pln">write</span><span class="pun">（）它可以接受</span><span class="kwd">native</span><span class="pun">编码，它会对经过</span><span class="kwd">native</span><span class="pun">编码的字符串进行自动解码。</span></code></li></ol></pre><h4 id="h4-3-dom-xss-"><a name="3. 为什么不建议用谷歌浏览器做dom-xss?" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. 为什么不建议用谷歌浏览器做dom-xss?</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">新版</span><span class="typ">Chrome</span><span class="pun">针对</span><span class="pln">script context</span><span class="pun">类型的</span><span class="pln">domxss</span><span class="pun">做了检测拦截</span></code></li></ol></pre><h4 id="h4-4-dom-xss-"><a name="4. 可能触发DOM型XSS的属性有哪些？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. 可能触发DOM型XSS的属性有哪些？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">document</span><span class="pun">.</span><span class="pln">referer</span></code></li><li class="L1"><code><span class="pln">window</span><span class="pun">.</span><span class="pln">name</span></code></li><li class="L2"><code><span class="pln">location</span></code></li><li class="L3"><code><span class="pln">innerHTML</span></code></li><li class="L4"><code><span class="pln">documen</span><span class="pun">.</span><span class="pln">write</span></code></li></ol></pre><h3 id="h3-0x2-7-4-csrf"><a name="0x2.7.4 跨站请求伪造 - CSRF" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.7.4 跨站请求伪造 - CSRF</h3><h4 id="h4-1-csrf-"><a name="1. CSRF脑图？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. CSRF脑图？</h4><p>同时，底部有这个脑图的压缩包，有需要的同学可以直接到底部下载哈：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/20230704/f4ac4e8a-b912-4f6d-912c-55dfb78ecb94.png" alt=""></p>
<h4 id="h4-2-csrf-"><a name="2. CSRF的攻击流程？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. CSRF的攻击流程？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">    </span><span class="pun">用户</span><span class="pln"> A </span><span class="pun">在登录</span><span class="pln"> D </span><span class="pun">站以后，收到了攻击者</span><span class="pln"> C </span><span class="pun">发来的不明链接，用户</span><span class="pln"> A </span><span class="pun">点击链接，被攻击者</span><span class="pln"> C </span><span class="pun">利用用户</span><span class="pln"> A </span><span class="pun">在浏览器登录</span><span class="pln"> D </span><span class="pun">站时的</span><span class="pln">cookie</span><span class="pun">，在</span><span class="pln">D</span><span class="pun">站上进行一些非用户</span><span class="pln">A</span><span class="pun">本意的操作，比如偷偷转账、创建或删除用户、文件等，注意，这里攻击者</span><span class="pln"> C </span><span class="pun">并没有直接获得用户</span><span class="pln"> A </span><span class="pun">的</span><span class="pln">cookie</span><span class="pun">，而是利用用户</span><span class="pln"> A </span><span class="pun">的浏览器进行的操作。</span></code></li></ol></pre><h4 id="h4-3-csrf-csrf-"><a name="3. CSRF靶场上传了CSRF文件，在问题反馈页面点击提交之后，并没有创建文件？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. CSRF靶场上传了CSRF文件，在问题反馈页面点击提交之后，并没有创建文件？</h4><p>同学是不是在这个页面，填写好了文件路径提交之后，发现并没有创建新的php文件：<br><img src="https://nc0.cdn.zkaq.cn/md/5597/8191acc5413db61ee18d0ec29847dc79_96515.png" alt=""></p>
<p>这里有个需要注意的点就是<code>姓名</code>和<code>手机号</code>是需要正常填写的，这样后台才会去点击你提交的链接哦：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/6ebef6efe643faf7bbbf8f9171fc2e88_20190.png" alt=""></p>
<p>如果正常填写了还是不行，那么同学可以检查一下你的CSRF文件，要注意将<code>后台的地址</code>更改为咱们<code>CSRF靶场的地址</code>,以及上传的路径是 <code>/uploads</code>也就是经过实体编码后的<code>&amp;#47;uploads</code>：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/304c186e8cda28a41e02a61c6b5b3265_98672.png" alt=""></p>
<p>其次，上传的文件名可以稍微奇怪一些，因为靶场是有很多人同时在做滴，如果你上传一个比如<code>1.html 、2.html</code> ，很可能就会产生文件覆盖的问题哦，可以把文件命名成<code>funnnytest8.html</code>这种奇怪一点的名字（当然不要太奇怪QAQ）</p>
<h4 id="h4-4-csrf-ssrf-"><a name="4. CSRF与SSRF的区别？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. CSRF与SSRF的区别？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">CSRF</span><span class="pun">（跨站请求伪造），</span><span class="pln">CSRF</span><span class="pun">主要是让客户端的浏览器去访问目标站点执行一些操作。</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">SSRF</span><span class="pun">（服务端请求伪造），</span><span class="pln">SSRF</span><span class="pun">主要是让服务器去发起访问，目标主要是服务器所在的内网环境。</span></code></li></ol></pre><h4 id="h4-5-csrf-xss-"><a name="5. CSRF与XSS的区别？" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. CSRF与XSS的区别？</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">CSRF</span><span class="pun">主要是借用目标的</span><span class="pln">cookie</span><span class="pun">来完成一些操作，而无法直接获取目标的</span><span class="pln">cookie</span><span class="pun">。</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">XSS</span><span class="pun">主要是利用恶意代码去获取目标的</span><span class="pln">cookie</span><span class="pun">，盗取。</span></code></li></ol></pre><h4 id="h4-6-csrf-"><a name="6. CSRF图解" class="reference-link"></a><span class="header-link octicon octicon-link"></span>6. CSRF图解</h4><p><img src="https://nc0.cdn.zkaq.cn/md/5597/20230704/5afddac1-f47c-4a02-aaf2-9f6ab7244636.png" alt=""></p>
<h3 id="h3-0x2-7-5-"><a name="0x2.7.5 验证码绕过、密码找回漏洞" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x2.7.5 验证码绕过、密码找回漏洞</h3></div>
| 用户名 | 金币 | 积分 | 时间 | 理由 |
| 小玫瑰 |
1.60 |
0 |
2023-07-10 22:10:52 |
一个受益终生的帖子~~ |
| 小玫瑰 |
1.60 |
0 |
2023-07-10 22:10:49 |
一个受益终生的帖子~~ |