本文主要是介绍[CTF]-Reverse:Reverse做题笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Tea:
[HNCTF 2022 WEEK2]TTTTTTTTTea:
找出关键数据,运行脚本
#include <stdio.h>
int main(){unsigned int l,r;unsigned int v4[6]={-1054939302,-1532163725,-165900264,853769165,768352038,876839116};int flag[6]={0};unsigned int delta;unsigned int key[4]={0x00010203,0x04050607,0x08090a0b,0x0c0d0e0f};int i,j;for(i=0;i<6;i+=2){l=v4[i];r=v4[i+1];delta=-32*1640531527;for(j=0;j<32;j++){r -= (((l >> 5) ^ (l*16)) + l) ^ (key[(delta>>11)&3]+ delta);//*16==<<4 delta += 1640531527;l -= (((r >> 5) ^ (r*16)) + r) ^ (key[delta&3]+ delta);}flag[i]=l;flag[i+1]=r;}char *p = (char*)flag;for(i=0;i<24;i++){printf("%c",*p);p++;}
}
[MoeCTF 2022]ezTea:
运行脚本
#include <stdio.h>
#include <stdint.h>void encrypt (uint32_t* v, uint32_t* k) { // 主要加密函数,试着搞定它uint32_t v0 = v[0], v1 = v[1], sum = 0;uint32_t delta = 0xd33b470;for (int i = 0; i < 32; i++) {sum += delta;v0 += ((v1<<4) + k[0]) ^ (v1 + sum) ^ ((v1>>5) + k[1]);v1 += ((v0<<4) + k[2]) ^ (v0 + sum) ^ ((v0>>5) + k[3]);}v[0] = v0;v[1] = v1;
}void decrypt(uint32_t* v, uint32_t* k) {uint32_t v0 = v[0], v1 = v[1], sum = 0xd33b470*32, i;uint32_t delta = 0xd33b470;uint32_t k0 = k[0], k1 = k[1], k2 = k[2], k3 = k[3];for (i = 0; i<32; i++) {v1 -= ((v0 << 4) + k2) ^ (v0 + sum) ^ ((v0 >> 5) + k3);v0 -= ((v1 << 4) + k0) ^ (v1 + sum) ^ ((v1 >> 5) + k1);sum -= delta;}v[0] = v0; v[1] = v1;
}int main() {uint32_t k[4] = {1, 2, 3, 4};int8_t input[33] = {0x17, 0x65, 0x54, 0x89, 0xed, 0x65, 0x46, 0x32, 0x3d, 0x58, 0xa9, 0xfd, 0xe2, 0x5e,
0x61, 0x97, 0xe4, 0x60, 0xf1, 0x91, 0x73, 0xe9, 0xe9, 0xa2, 0x59, 0xcb, 0x9a, 0x99,
0xec, 0xb1, 0xe1, 0x7d};//scanf("%32s", input);for (int i = 0; i < 32; i+=8) {uint32_t v[2] = {*(uint32_t *)&input[i], *(uint32_t *)&input[i+4]};decrypt(v, k);for (int j = 0; j < 2; j++) { // 这一段主要是把 v 按单字节输出,另外可以了解一下 “大小端序” 在这题是如何体现的for (int k = 0; k < 4; k++) {printf("%c", v[j] & 0xff);v[j] >>= 8;}}}return 0;
}
[HGAME 2023 week1]a_cup_of_tea:
#include <stdio.h>
#include <string.h>
#include <emmintrin.h>
#include <stdint.h>void decrypt(unsigned int *v, unsigned int *k) {unsigned int v0 = v[0],v1 = v[1];int delta = -1412567261;int sum =delta*32;unsigned int k0 = k[0],k1 = k[1],k2 = k[2],k3 = k[3];for (int i = 0; i < 32; i++) {v1 -= ((v0 << 4) + k2) ^ (v0 + sum) ^ ((v0 >> 5) + k3);v0 -= ((v1 << 4) + k0) ^ (v1 + sum) ^ ((v1 >> 5) + k1);sum -= delta;}v[0] = v0;v[1] = v1;
}int __cdecl main() {int Buf2[8];unsigned int key[] = {0x12345678, 0x23456789, 0x34567890, 0x45678901};Buf2[0] = 778273437;Buf2[1] = -1051836401;Buf2[2] = -1690714183;Buf2[3] = 1512016660;Buf2[4] = 1636330974;Buf2[5] = 1701168847;Buf2[6] = -1626976412;Buf2[7] = 594166774;char buf[50] = {0};memcpy(buf, Buf2, sizeof Buf2);for(int i=0;i<=6;i+=2){decrypt((unsigned int *)&buf+i, key);}printf("%s", buf);return 0;
}
这篇关于[CTF]-Reverse:Reverse做题笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!