附件给了一个网页,没想到逆向也有这种题目,直接进入网页打开源代码
然后就现学现卖,查几个函数
getElementById() ----返回指定id元素
fromCharCode() ----将 Unicode 编码转为一个字符
charCodeAt() -----返回字符串第一个字符的 Unicode 编码,也可以指定,题目里这是指定了第0位
大致看了一下,除了加密代码看不懂,代码流程是,读取字符串,加密,最后的的if语句意思是,加密后的字符串是PyvragFvqrYbtvafNerRnfl@syner-ba.pbz
查了些wp,了解到了
var rotFlag = flag.replace(/[a-zA-Z]/g, function©{return String.fromCharCode((c <= “Z” ? 90 : 122) >= (c = c.charCodeAt(0) + 13) ? c : c - 26);});
这句代码的意思就是将字符后移13位,越界了就转到26个字母的开头(超过Z循环回A),循环进行,最后得到了字符串PyvragFvqrYbtvafNerRnfl@syner-ba.pbz
如果你聪明的话是可以直接看出规律来的,我是笨比,没看出来,看了大佬的代码才反应过来.
在区分大小写的情况下,只有26个字母.从中间那个字母往前减去13都是越界的,因为26是对称的,所以向上数13个字母(超过a就从转到尾部z继续数)就等于向下数13个字母,所以,只要越界就加13,不越界就减13.不属于英文字母的就不动他,因为有提示
形如:flag{123456@flare-on.com}
当然你动手算几遍也能看出来这个规律
脚本
#include <iostream>
using namespace std;
int main(){
int index = 0;
char v12[] ="PyvragFvqrYbtvafNerRnfl@syner-ba.pbz";
char flag[44];
for(int i=0;i<strlen(v12);i++){
if(v12[i] >= 'A' && v12[i]<='Z' ){
if(v12[i] - 13 <'A')
flag[index++] = v12[i]+13;
else
flag[index++]=v12[i]-13;
}else if(v12[i] >='a' && v12[i] <='z'){
if(v12[i] - 13 <'a'){
flag[index++] = v12[i]+13;
}else{
flag[index++] = v12[i]-13;
}
}else
flag[index++]=v12[i];
}
flag[index] = '\0';
cout<<"结果是: "<<flag<<endl;
system("pause");
return 0;
}