路径遍历(拿到www-data用户权限)

1.通过扫描
靶场IP:192.168.174.134
攻击机IP:192.168.174.135
2.使用 nmap -sV 靶场IP 命令扫描主机服务信息以及服务版本
在这里插入图片描述
这里能看到默认了80端口。
也可以使用 nmap -T4 -A -v 靶场IP 命令快速扫描主机全部信息。
3、在这里插入图片描述
如果该端口号不是默认的80端口可以不用加上端口号,从刚才扫描的信息可以知道靶场默认的是80端口,所以在这里可以省略端口号了。
在这里插入图片描述在这里插入图片描述分析nmap、nikto扫描信息,探测哪一个文件或目录是存在该站点的。
使用浏览器打开该站点
在这里插入图片描述还有一个dbadmin目录好像是一个数据管理的界面,使用浏览器打开。
在这里插入图片描述点击test
在这里插入图片描述出现了一个类似数据库管理的系统
使用owasp-zap web漏洞扫描器进行漏洞扫描,挖掘web应用程序中的漏洞。
在这里插入图片描述
在这里插入图片描述在http输入靶场IP点击攻击
在这里插入图片描述然后漏洞扫描器会对当前的站点进行爬取,爬取之后自动发送到主动扫描的模块中对该站点进行主动扫描挖掘漏洞。
点击Spider查看爬取页面。

在这里插入图片描述在页面爬取结束之后,点击警报
在这里插入图片描述红色的旗帜表示高危漏洞,黄色的表示中微漏洞,浅黄色的是低微漏洞(可能并不具有任何利用价值)。
我们查看路径遍历漏洞,然后用浏览器打开url
在这里插入图片描述在这里插入图片描述通过这里发现该站的存在路径遍历漏洞的。
这里存在一个测试代码
在这里插入图片描述把password改为shadow,但并没有返回shadow内容,因为服务器把shadow设置为了不可读的。
在这里插入图片描述在这里插入图片描述在这里插入图片描述弱口令:字母型:admin 数字型:123456
这里尝试admin登陆,直接登陆进去
在这里插入图片描述在这里插入图片描述
kali中也有写入webshell的代码。
查看webshell代码
在这里插入图片描述查看webshell内容,并将IP改为攻击机IP,端口改为4444
在这里插入图片描述创建一个名为shell.php的数据库
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在上面填入对应的shell
使用gedit命令打开一个文件
在这里插入图片描述写入字段
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述想到之前的代码我们访问usr
在这里插入图片描述
在这里插入图片描述nc会反弹回shell
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HashMap的几种遍历方式如下: 1. Entry遍历:使用entrySet()方法可以同时遍历Map里面的Key和Value。可以通过迭代器或者foreach循环来实现。例如: ```java HashMap<String, Integer> map = new HashMap<>(); // 添加键值对 map.put("A", 1); map.put("B", 2); map.put("C", 3); // 使用entrySet()方法遍历 for (Map.Entry<String, Integer> entry : map.entrySet()) { String key = entry.getKey(); Integer value = entry.getValue(); // 处理key和value } ``` 2. keySet遍历:使用keySet()方法可以遍历Map里面的Key。可以通过迭代器或者foreach循环来实现。例如: ```java HashMap<String, Integer> map = new HashMap<>(); // 添加键值对 map.put("A", 1); map.put("B", 2); map.put("C", 3); // 使用keySet()方法遍历 for (String key : map.keySet()) { Integer value = map.get(key); // 处理key和value } ``` 3. foreach遍历:在JDK8及以上版本中,可以直接使用foreach循环来遍历HashMap的键值对。例如: ```java HashMap<String, Integer> map = new HashMap<>(); // 添加键值对 map.put("A", 1); map.put("B", 2); map.put("C", 3); // 使用foreach遍历 map.forEach((key, value) -> { // 处理key和value }); ``` 4. keySet foreach遍历:在JDK8及以上版本中,可以使用keySet()方法获取键的集合,然后使用foreach循环遍历。例如: ```java HashMap<String, Integer> map = new HashMap<>(); // 添加键值对 map.put("A", 1); map.put("B", 2); map.put("C", 3); // 使用keySet foreach遍历 for (String key : map.keySet()) { Integer value = map.get(key); // 处理key和value } ``` 以上是HashMap的几种常见遍历方式。根据具体的需求,可以选择适合的遍历方式来操作HashMap的键值对。 #### 引用[.reference_title] - *1* *3* [Java - 关于HashMap通过keySet遍历kv的二次调用问题](https://blog.csdn.net/Zong_0915/article/details/120905738)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [HashMap的七种遍历方式](https://blog.csdn.net/maojian_ohhey/article/details/115431835)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值