攻防世界web题 分享

 

分析题目要求

  • 注释中提示,需要将 $miwen 解密

分析其中的PHP内置函数

  • strrev(string): 反转字符串
  • strlen(string): 返回字符串的长度
  • substr(string, start, length): 返回字符串的一部分
    • string: 所需要的字符串
    • start: 在字符串何处开始
    • length: 可选。规定被返回字符串的长度。默认是直到字符串的结尾
  • ord(string): 返回字符串首个字符的 ASCII 值
  • chr(): 从指定的 ASCII 值返回对应的字符
  • str_rot13(string): 对字符串执行 ROT13 编码。
    • ROT13 编码把每一个字母在字母表中向前移动 13 个字母。数字和非字母字符保持不变
    • 编码和解码都是由该函数完成的。如果把已编码的字符串作为参数,那么将返回原始字符串
  • base64_encode(string): 使用 MIME base64 对数据进行编码

分析题目中的函数

  1. 循环开始:给encode一个参数 $str
  2. 将所传参数 $str 通过 strrev() 函数反转字符串操作并赋值给 $_o
  3. 循环遍历 变量 $_o
  4. 在for循环中首先依次取字符串 $_o 的第 $_0 个值,赋值给 $_c
  5. 将变量 $c 转化为 ASCII码 并 +1,赋值给 $_
  6. 将 $__ 转化为该ASCII码所对应的字符,赋值给 $_c
  7. 拼接字符串,赋值给 $_ , 循环结束。
  8. 将拼接好后的字符串 $_ 进行 base64编码
  9. 将编码后的值进行反转字符串操作
  10. 对反转后的字符串进行 rot13 加密
  11. 得出结果为 $miwen

思考:这题考得就是逆向解密,然后接着分析怎样逆向写出函数

 

我们逆着推 :

因为加密算法的最后一步是给字符串进行rot13加密,然后我们写解密算法时就用rot13解密,又因为rot13是把每一个字母后移13来作为当前字母,而字母总共有26位,所以rot13加密,解密算法都一样,因此我们对一个字母进行一次rot13编码后,再进行一次rot13编码,就相当于得到原来的数,比如一个字母为b,后移13,为o,再后移13,变为b。然后就像上面的思想一样往前推。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值