Wechall刷题(三)Crypto - Transposition I//The Beginning//hi

Crypto - Transposition I

首先此题的解决方案为:Wechall - Training: Crypto - Transposition I

此题目中涉及到的工具为:Transposition Cipher Solver

收获

  • 对置换密码的了解,大致过程为:加密:先分组(最后不足补齐);分别按组进行置换(置换矩阵)。解密使用逆置换矩阵即可

问题:

  • 密钥的选取?以及确定密钥之后如何确定置换矩阵?这个过程自动化(代码)实现的可能性?
  • 分组长度一定是密文长度的因子嗷!但不一定是明文长度的因子

The Beginning

这个题目简直耗费我太多时间,最大的原因在于:无知。话不多说,阐述解题经验吧

解决思路:

  • 这是一道“远程登录服务器,在远程服务器上进行简单的linux文件操作”的题目(由于对SSH的不了解,我以为这是对SSH的不同级别的攻击,或者是破解服务器端不同权限密码,想多了。。)

  • 按照题目给出的线索,“enable logfile Email”貌似不用管,我认为是可以及时通过邮件通知自己在服务器端的状态;“SET your SSH account”就是设置自己的SSH密码,也是登录远程服务器的私钥,输入两次;下边的答案是写出所有的level对应的solution,并用逗号分隔即可

  • 首先一分钟之内在linux终端下输入

    ssh -p 19198 leeham@warchall.net
  • 可以使用pwd(print working directory )命令查看当前工作路径;

  • ls -a: 查看当前路径下的所有文件;可以找到WELCOME.txt,使用 vim WELCOME.txt打开文件,阅读题目提示;提示所有的答案会在“/home/level”或“/home/user/yournick/level”中

  • cd /home/level:进入第一个提示目录;然后ls -a查看所有的文件,看到有0,1,2,3没有4,5;那么在这个目录下分别进入0,1,2,3想办法找到对应的solution。cd /home/user/leeham/level进入第二个提示目录;然后la -a看到有4,5,6但是我们只需要4,5哦,小心上瘾的去破解6哟

  • 首先进入0目录:vim README.txt即可找到答案;level 0: bitwarrior

  • 进入1目录:vim README.txt没有答案,说到“follow the black cursor”;进入/home/level/1/blur/pill/hats可以看到black gray white,想必提示的意思应该是在gray吧,进入gray,再继续读取目录即可得到答案;level 1: LameStartup

  • 进入2目录:”bash_history”这个东西提示了各个文件夹里边都存放了什么内容(建议了解Bash_Hiostory);其实根据这个内容,我们就可以知道答案在.porb/.solution中,那么直接去找就可以了;level 2: HiddenIsConfig

  • 进入3目录:直接阅读bash_history就可以了;level 3: RepeatingHistory

  • 进入4目录:阅读README.txt就可以了(可能还有一些其他问题,但是由于我的文件在服务器那边已经修改,所以无法全部还原);可以得到答案level 4: AndIknowchown

  • 进入5目录:通过README了解到需要先将/home/user/leeham/level这个目录设置权限,仅对自己可读写,使用到chmod命令;五分钟之后阅读solution.txt即可得到答案(感觉出题人很叼啊)level 5: OhRightThePerms

  • 最终答案:bitwarrior,LameStartup,HiddenIsConfig,RepeatingHistory,AndIknowchown,OhRightThePerms

此题中涉及到的命令:

  • ls -a; ls -l ls命令
  • chmod … file linux中chmod的用法
  • vim file

收获:

  • 图解SSH,很清楚
  • SSH与telnet和R命令集的区别:telnet 明文传输,明文密码和数据;R命令 登陆和执行命令病等处系统的操作整合在一起;SSH 加密协议,密码加密传送,执行命令数据加密
  • 隐藏文件的读取
  • bash_history的功能

hi

解题思路:使用python计算(17591026060782+2)*17591026060781/2;(我当时用的java,而且复用的别人大整数加法的代码,但是跑了大半天都没有跑出来,后来才知道python不限位数orz….无知是罪)

收获:

  • 学python!学python!学python!

  • 关于java代码中得到的收获不在这里赘述,另移篇幅

你可能感兴趣的:(ctf)