[红日安全]nday漏洞还原分析之dedecms后台getshell

\u672c\u6587\u7531\u7ea2\u65e5\u5b89\u5168\u6210\u5458\uff1a \u4e03\u6708\u706b \u7f16\u5199\uff0c\u5982\u6709\u4e0d\u5f53\uff0c\u8fd8\u671b\u65a7\u6b63\u3002

\u524d\u8a00

\u6700\u8fd1\u53d1\u73b0 dedecms \u7684 nday\u540e\u53f0getshell \uff0c\u4e8e\u662f\u6253\u7b97\u8fd8\u539f\u4e00\u4e0b\u3002\u6839\u636e\u65e5\u5fd7\u663e\u793a\uff0c\u653b\u51fb\u8005\u8bbf\u95ee\u4e86 dede/ad_add.php \u6587\u4ef6\u540e\uff0c\u8f6c\u800c\u8bbf\u95ee plus/ad_js.php \u6587\u4ef6\uff0c\u63d0\u4ea4\u7684 payload \u4e3a plus/ad js.php?nocache=1&aid=1& =whoami \u3002

\u524d\u671f\u51c6\u5907

DedeCMS V5.7 SP2\u6b63\u5f0f\u7248\u4e0b\u8f7d\uff1a http://updatenew.dedecms.com/base-v57/package/DedeCMS-V5.7-UTF8-SP2.tar.gz

\u6211\u4eec\u5148\u6765\u770b\u4e00\u4e0b dede/ad_add.php \u6587\u4ef6\u3002\u53ef\u4ee5\u770b\u5230\u8fd9\u662f\u4e00\u4e2a\u589e\u52a0\u5e7f\u544a\u7684\u9875\u9762\uff0c\u5982\u4e0b\u56fe\uff1a

\u5b9e\u9645\u4e0a\uff0c\u5b83\u5728\u540e\u53f0\u7684\u4f4d\u7f6e\u5bf9\u5e94\u5982\u4e0b\uff1a

\u63a5\u4e0b\u6765\uff0c\u7b14\u8005\u4f7f\u7528 TheFolderSpy \u8f6f\u4ef6\u5bf9\u7f51\u7ad9\u6587\u4ef6\u8fdb\u884c\u76d1\u63a7\uff0c\u8fd9\u6837\u80fd\u8ba9\u6211\u4eec\u5feb\u901f\u7684\u53d1\u73b0\u53d1\u751f\u4fee\u6539\u7684\u6587\u4ef6\uff0c\u4ece\u800c\u63d0\u9ad8\u5ba1\u8ba1\u6548\u7387\u3002 TheFolderSpy \u8bbe\u7f6e\u5982\u4e0b\uff1a

\u7136\u540e\uff0c\u5728\u5982\u4e0b4\u4e2a\u4f4d\u7f6e\u5206\u522b\u586b\u5165\u4e00\u4e9b\u6807\u8bc6\u4fe1\u606f\uff0c\u4ee5\u4fbf\u540e\u7eed\u5224\u65ad\u5230\u5e95\u662f\u54ea\u4e00\u5904\u53d1\u751f\u95ee\u9898\u3002\u586b\u5199\u4fe1\u606f\u5982\u4e0b\uff1a

\u70b9\u51fb\u786e\u5b9a\u6dfb\u52a0\u5e7f\u544a\u540e\uff0c\u53d1\u73b0 TheFolderSpy \u8f6f\u4ef6\u5e76\u6ca1\u6709\u76d1\u6d4b\u5230\u6709\u6587\u4ef6\u5185\u5bb9\u88ab\u4fee\u6539\u3002\u4e8e\u662f\u6211\u4eec\u7ee7\u7eed\u8bbf\u95ee plus/ad js.php?nocache=1&aid=1& =whoami \uff0c\u53d1\u73b0\u751f\u6210\u4e86\u4e00\u4e2a data\\cache\\myad-1.htm \u6587\u4ef6\uff0c\u5e76\u4e14\u6211\u4eec\u5728\u4e0a\u56fe\u7b2c\u4e09\u4e2a\u6846\u4e2d\u586b\u5199\u7684 phpinfo();3 \u88ab\u5199\u5165\u4e86\u8be5\u6587\u4ef6\u3002\u5982\u4e0b\u56fe\u6240\u793a\uff1a

\u6211\u4eec\u53ef\u4ee5\u89c2\u5bdf\u5230\u8be5\u6587\u4ef6\u8def\u5f84\u4e3a data\\cache \uff0c\u90a3\u4e48\u5e94\u8be5\u662f\u4e2a\u7f13\u5b58\u6587\u4ef6\uff0c\u800c\u4e14\u6587\u4ef6\u540e\u7f00\u4e3a htm \u3002\u7531\u4e8e\u653b\u51fb\u8005\u901a\u8fc7\u8bbf\u95ee plus/ad_js.php \u9875\u9762\u80fd getshell \uff0c\u90a3\u4e48\u5f88\u6709\u53ef\u80fd\u662f\u7a0b\u5e8f\u5728\u67d0\u5904\u5c06\u8fd9\u4e2a\u7f13\u5b58\u6587\u4ef6\u7ed9\u5305\u542b\u4e86\u3002\u63a5\u4e0b\u6765\u6211\u4eec\u5bf9 plus/ad_js.php \u6587\u4ef6\u8fdb\u884c\u8be6\u7ec6\u5206\u6790\u3002

\u6f0f\u6d1e\u5206\u6790

plus/ad_js.php \u6587\u4ef6\u4ee3\u7801\u5982\u4e0b\uff1a

\u8fd9\u91cc\u5173\u6ce8 \u7b2c9\u884c \u548c \u7b2c15\u884c \uff0c\u53ef\u4ee5\u6e05\u6670\u7684\u770b\u5230\u7a0b\u5e8f\u5305\u542b\u4e86\u6211\u4eec\u4e4b\u524d\u76d1\u63a7\u5230\u751f\u6210\u7684 htm \u6587\u4ef6\uff0c \u7b2c12-14\u884c \u4e3b\u8981\u662f\u5bf9\u8981\u5199\u5165 htm \u6587\u4ef6\u7684\u5185\u5bb9\u8fdb\u884c\u5904\u7406\uff0c\u5177\u4f53\u4ee3\u7801\u5982\u4e0b\uff1a

\u4ed4\u7ec6\u89c2\u5bdf\u8fd9\u6bb5\u4ee3\u7801\uff0c\u7a0b\u5e8f\u5c06\u4ece\u6570\u636e\u5e93\u4e2d dede_myad \u67e5\u8be2\u7684\u7ed3\u679c\u5b58\u5728 $row \u53d8\u91cf\u4e2d(\u4e0a\u56fe\u7b2c3\u884c)\uff0c\u7136\u540e\u5c06\u8868 dede_myad \u4e2d\u7684 normbody \u6216 expbody \u5b57\u6bb5\u7684\u503c\u4f5c\u4e3a $adbody \u5199\u5165\u7f13\u5b58\u6587\u4ef6 $cacheFile \uff0c\u5e76\u5728\u6700\u540e include $cacheFile; \u3002\u800c \u7b2c16-18\u884c \u53ea\u662f\u5bf9 $adbody \u5185\u5bb9\u8fdb\u884c\u7b80\u5355\u7684\u5904\u7406\u3002\u6211\u4eec\u518d\u4ece\u6570\u636e\u5e93\u4e2d\uff0c\u67e5\u770b dede_myad \u8868\u7684\u5185\u5bb9\uff0c\u5982\u4e0b\u56fe\uff1a

\u53ef\u4ee5\u770b\u5230 normbody \u6216 expbody \u5b57\u6bb5\uff0c\u5bf9\u5e94\u7684\u5c31\u662f\u6211\u4eec\u521a\u521a\u586b\u5199\u7684\u7b2c3\u4e2a\u548c\u7b2c4\u4e2a\u6807\u8bc6\u4fe1\u606f\u3002\u6211\u4eec\u73b0\u5728\u518d\u6765\u770b\u770b normbody \u6216 expbody \u5b57\u6bb5\u7684\u503c\u662f\u5982\u4f55\u5199\u5165\u7684\u3002\u518d\u6b21\u56de\u5230 dede/ad_add.php \u6587\u4ef6\uff0c\u9488\u5bf9\u521a\u521a\u586b\u5199\u7684\u5e7f\u544a\u5185\u5bb9\u53d1\u8d77\u63d0\u4ea4\uff0c\u6293\u5305\u5982\u4e0b\uff1a

\u7136\u540e\u6211\u4eec\u518d\u770b dede/ad_add.php \u6587\u4ef6\u4ee3\u7801\uff1a

\u6b64\u65f6\u6574\u4e2a\u6f0f\u6d1e\u53d1\u751f\u7684\u6d41\u7a0b\u4fbf\u5341\u5206\u6e05\u6670\u4e86\uff0c\u7a0b\u5e8f\u5c06\u6765\u81ea\u7528\u6237\u7684\u6570\u636e $normbody[\'htmlcode\ \u4ec5\u4ec5\u53ea\u662f\u7528 addslashes \u51fd\u6570\u5904\u7406\uff0c\u5e76\u6ca1\u6709\u5bf9\u4ee3\u7801\u8fdb\u884c\u5206\u6790\uff0c\u7136\u540e\u4fbf\u76f4\u63a5\u5b58\u50a8\u5728\u6570\u636e\u5e93 dede_myad \u8868\u7684 normbody \u5b57\u6bb5\uff0c\u5bfc\u81f4\u7528\u6237\u53ef\u4ee5\u5c06PHP\u4ee3\u7801\u5b58\u50a8\u5728\u6570\u636e\u5e93\u4e2d\u3002\u5982\u679c\u653b\u51fb\u8005\u6b64\u65f6\u8bbf\u95ee plus/ad_js.php \u6587\u4ef6\uff0c\u5219\u8c03\u7528 normbody \u5b57\u6bb5\u5e76\u5199\u5165\u7f13\u5b58\u6587\u4ef6\uff0c\u6700\u7ec8\u5229\u7528\u6587\u4ef6\u5305\u542b\u8be5getshell\u3002

\u6f0f\u6d1e\u5229\u7528

\u5728\u660e\u767d\u4e86\u4e0a\u8ff0\u5206\u6790\u6d41\u7a0b\uff0c\u60f3\u5229\u7528\u8be5\u6f0f\u6d1e\u4fbf\u5341\u5206\u7b80\u5355\u3002\u6211\u4eec\u5728\u5e7f\u544a\u5185\u5bb9\u5904\u63d2\u5165 --><?php phpinfo();?><!--

\u7136\u540e\u8bbf\u95ee\u5982\u4e0b\u94fe\u63a5( \u8fd9\u91cc\u7684aid\u503c\u4e3a\u7b2c\u51e0\u4e2a\u5e7f\u544a )\uff1a

http://localhost/dedecms/plus/ad_js.php?nocache=1&aid=3

\u603b\u7ed3

\u672c\u6587\u4ece\u4ee3\u7801\u5ba1\u8ba1\u7684\u89d2\u5ea6\uff0c\u5bf9\u6f0f\u6d1e\u8fdb\u884c\u8be6\u7ec6\u5206\u6790\uff0c\u501f\u52a9\u6587\u4ef6\u76d1\u63a7\u8f6f\u4ef6\u8fc5\u901f\u5b9a\u4f4d\u6f0f\u6d1e\u6240\u5728\u3002\u6216\u8bb8\u5927\u5bb6\u53ef\u4ee5\u5229\u7528\u8fd9\u79cd\u65b9\u5f0f\uff0c\u53d1\u73b0\u66f4\u591a\u7684\u540e\u53f0 getshell \u5229\u7528\u59ff\u52bf\uff0c\u671f\u5f85\u5927\u5bb6\u6316\u6398\u3002\u6700\u540e\uff0c\u5e0c\u671b\u5927\u5bb6\u591a\u591a\u4ea4\u6d41\uff0c\u5171\u540c\u8fdb\u6b65\u3002\u5982\u679c\u5927\u5bb6\u6709\u4ec0\u4e48\u597d\u7684\u4ee3\u7801\u5ba1\u8ba1\u6280\u5de7\uff0c\u8fd8\u671b\u4e0d\u541d\u5206\u4eab\uff0c\u611f\u8c22\u5927\u5bb6\u7684\u9605\u8bfb\u3002