记录一下Hash长度扩展攻击的几个题目

最近做了几个题目,又学到新的知识点,是有关Hash长度扩展攻击

参考了一波P牛的博客还有我们学校的博客:
http://www.cnblogs.com/pcat/p/5478509.html
http://www.bxsteam.xyz/2017/05/23/hash%e9%95%bf%e5%ba%a6%e6%89%a9%e5%b1%95%e6%94%bb%e5%87%bb/

正文

实验吧 让我进去

既然说是admin才能进去,那我就先抓个包,看一下包里面是否又要改的东西。。。。
发现有一个source=0,毫不犹豫把它改为1,
这里写图片描述
发包获得源代码

if (urldecode($username) === "admin" && urldecode($password) != "admin") {
        if ($COOKIE["getmein"] === md5($secret . urldecode($username . $password))
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 使用 RedisTemplate 删除 Hash 的示例如下: 1. 删除整个 Hash: ``` redisTemplate.opsForHash().delete("hashKey"); ``` 2. 删除 Hash 中的某个字段: ``` redisTemplate.opsForHash().delete("hashKey", "field1"); ``` 3. 删除多个 Hash 中的字段: ``` redisTemplate.opsForHash().delete("hashKey", Arrays.asList("field1", "field2")); ``` 请注意,如果您删除的 Hash 不存在,则不会发生错误。 ### 回答2: 使用RedisTemplate删除hash可以通过调用RedisTemplate的opsForHash()方法来实现。具体的示例代码如下: 1. 删除指定hash表中的一个或多个字段: ```java String hashKey = "user:1"; String field1 = "name"; String field2 = "age"; redisTemplate.opsForHash().delete(hashKey, field1, field2); ``` 2. 删除整个hash表: ```java String hashKey = "user:1"; redisTemplate.delete(hashKey); ``` 3. 判断hash表中是否存在某个字段,如果存在则删除: ```java String hashKey = "user:1"; String field = "name"; if(redisTemplate.opsForHash().hasKey(hashKey, field)){ redisTemplate.opsForHash().delete(hashKey, field); } ``` 4. 删除hash表中的所有字段: ```java String hashKey = "user:1"; Map<Object, Object> hash = redisTemplate.opsForHash().entries(hashKey); Set<Object> keys = hash.keySet(); redisTemplate.opsForHash().delete(hashKey, keys.toArray()); ``` 需要注意的是,删除hash表时,可以传入一个或多个字段作为参数,也可以传入一个字段数组。在删除之前,可以先进行判断是否存在某个字段,避免不必要的删除操作。另外,如果需要删除整个hash表,可以直接调用RedisTemplate的delete()方法来完成。 ### 回答3: Redis是一个开源的、基于内存的数据结构存储系统,它提供了丰富的数据结构操作,包括hash。在Java中,我们可以使用Redis的客户端库Jedis来操作Redis的数据结构。 要删除Redis中的hash,我们首先需要连接到Redis服务器,然后通过Jedis对象调用相关的方法。下面给出几个示例: 1. 删除单个hash键值对: ```java Jedis jedis = new Jedis("localhost", 6379); jedis.hdel("myhash", "field1"); // 删除myhash中的field1键值对 ``` 2. 删除多个hash键值对: ```java Jedis jedis = new Jedis("localhost", 6379); jedis.hdel("myhash", "field1", "field2", "field3"); // 删除myhash中的field1、field2和field3键值对 ``` 3. 删除整个hash: ```java Jedis jedis = new Jedis("localhost", 6379); jedis.del("myhash"); // 删除整个myhash ``` 需要注意的是,如果要操作的hash键不存在,删除操作将会被忽略。 以上是使用Java中的Jedis库来删除Redis中的hash几个示例。当然,还有其他方法可以实现相同的功能,具体取决于你使用的Redis客户端库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值