SQL Server中包含了幾個可以訪問系統註冊表的擴充預存程序.但實際上這幾個擴充預存程序是未公開的,
從sql server 7.0就有了, 在SQL server 2000中仍然保留,他們以後可能會刪除.但是這幾個預存程序卻提供
了在當前的SQL Server版本中訪問系統註冊表的能力, 而且很多人利用SQL Server來進行攻擊系統時,
往往都會用到這幾個擴充預存程序.所以最好在SQL Server中禁用他們.
xp_regenumvalues 以多個記錄集方式返回所有索引值
使用方法:
xp_regenumvalues 註冊表根鍵, 子鍵
比如說,想看看HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows/CurrentVersion/Run 的所有索引值:
use master
exec xp_regenumvalues 'HKEY_LOCAL_MACHINE','SOFTWARE/Microsoft/Windows/CurrentVersion/Run'
xp_regread 返回制定鍵的值
使用方法:
xp_regread 根鍵,子鍵,索引值名
use master
exec xp_regread 'HKEY_LOCAL_MACHINE','SOFTWARE/Microsoft/Windows/CurrentVersion','CommonFilesDir'
xp_regwrite 寫入註冊表
使用方法:
xp_regwrite 根鍵,子鍵, 值名, 實值型別, 值
use master
exec xp_regwrite 'HKEY_LOCAL_MACHINE','SOFTWARE/Microsoft/Windows/CurrentVersion','TestValueName','reg_sz','hello'
注意實值型別有2種REG_SZ 表示字元型,REG_DWORD 表示整型
xp_regdeletevalue 刪除某個值
使用方法:
xp_regdeletevalue 根鍵,子鍵,值名
use master
exec xp_regdeletevalue 'HKEY_LOCAL_MACHINE','SOFTWARE/Microsoft/Windows/CurrentVersion','TestValueName'
xp_regdeletekey 刪除鍵,包括該鍵下所有值
使用方法:
use master
xp_regdeletekey 'HKEY_LOCAL_MACHINE','SOFTWARE/Microsoft/Windows/CurrentVersion/Testkey'