RSS

分析DEDECMS 5.5 datalistcp.class.php包含

This entry was posted on Apr 03 2010

作者:st0p
轉載請註明出處http://www.st0p.org

老早就看到有人發的洞,一直想過寫分析來著,最近一直呆在UBUNTU下安裝東西。 老忘。
有時有些朋友加我,教他找洞。 這個好似是個累活,而且運氣佔很大一部分。 所以我還是盡量幫分析過程發出來吧,也方便我自己學習。
具體的EXP,請看: http://www.st0p.org/blog/archives/dedecms-5-5-datalistcp-class-php-contains-exp.html

以前呢,DEDECMS會把出錯的SQL信息,寫進mysql_error_trace.php,後來被大牛們爆出來了。 就改名為mysql_error_trace.inc了。
沒想到這次又被包含了。 看來記錄SQL信息也不是啥好事。

這個EXP的原理呢,是通過構造特殊的請求給plus/digg_ajax.php來達到寫入我們的語句到mysql_error_trace.inc,當然可以滿足我們這一步寫入到mysql_error_trace.inc的文件還有不少。 不過想要執行他就不可能了。 然後這次報出的洞呢就是運氣很好才能碰到的。
關鍵代碼存在於

/include/datalistcp.class.php

  1
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
  ...
 ( isset ( $needCode ) ? $needCode : $cfg_soft_lang ) ; $codefile = ( isset ( $needCode ) ? $needCode : $cfg_soft_lang ) ;

 //通過isset函數檢查$needCode是否已配置,如已配置則結果為$needCode,否則結果為$cfg_soft_lang
 //當我們偽造結果為aa/../../../data/mysql_error_trace時

 file_exists ( DEDEINC . '/code/datalist.' . $codefile . '.inc' ) ) if ( file_exists ( DEDEINC . '/code/datalist.' . $codefile . '.inc' ) )

 {

	 DEDEINC . '/code/datalist.' . $codefile . '.inc' ) ; require_once ( DEDEINC . '/code/datalist.' . $codefile . '.inc' ) ;
  //後綴是.inc
 }
 //檢查文件是否存在,存在則包含。  我們通過../成功跳轉到到data目錄,包含我們剛才構造過的mysql_error_trace.inc
 //成功運行我們mysql_error_trace.inc在構造的語句。    
 ... 

鬱悶,前幾次想寫分析的時候官方還沒補呢。 剛去官方看了下通過正則進行了修補

  1
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
  ( isset ( $needCode ) ? $needCode : $cfg_soft_lang ) ; $codefile = ( isset ( $needCode ) ? $needCode : $cfg_soft_lang ) ;

 preg_replace ( "/[\w-]/" , '' , $codefile ) ; $codefile = preg_replace ( "/[\w-]/" , '' , $codefile ) ;
  //通過正則過濾了。    
 file_exists ( DEDEINC . '/code/datalist.' . $codefile . '.inc' ) ) if ( file_exists ( DEDEINC . '/code/datalist.' . $codefile . '.inc' ) )

 {

	 DEDEINC . '/code/datalist.' . $codefile . '.inc' ) ; require_once ( DEDEINC . '/code/datalist.' . $codefile . '.inc' ) ;

 } 
Chinese (Simplified) flagItalian flagKorean flagChinese (Traditional) flagPortuguese flagEnglish flagGerman flagFrench flagSpanish flagJapanese flagArabic flagRussian flagGreek flagDutch flagBulgarian flagCzech flagCroatian flagDanish flagFinnish flagHindi flagPolish flagRomanian flagSwedish flagNorwegian flagCatalan flagFilipino flagHebrew flagIndonesian flagLatvian flagLithuanian flagSerbian flagSlovak flagSlovenian flagUkrainian flagVietnamese flagAlbanian flagEstonian flagGalician flagMaltese flagThai flagTurkish flagHungarian flag
  1. 106 Trackback(s)

  2. great fish food
  3. foundation crack repair in Potsdam OH
  4. facebook/sex
  5. bouncy castle north london
  6. ways to increase facebook fans
  7. clairvoyants
  8. antykwariaty
  9. Alpha Warranty
  10. make a website
  11. Domain Brokerage
  12. spinal injury
  13. accident in asda
  14. southern dunes villa
  15. http://www.fineheartenterprises.net/?page_id=28
  16. auckland drainlayer
  17. nba betting picks
  18. Best Sentey Case
  19. mlb picks
  20. inspirational quotes
  21. wypadanie włosów choroby
  22. security doors nz
  23. kullan myynti
  24. erect penis
  25. tienda online papel regalo
  26. rudraksha beads
  27. race car driving experience
  28. double glazing retrofit
  29. food photography tips
  30. photographers
  31. freefav
  32. tarot meaning
  33. psychic light
  34. free web hosting uk no ads
  35. temperature logger
  36. senuke x review
  37. campers world
  38. tatuaggi giapponesi
  39. Abdelmalik
  40. Sztabka złota is really awesomething
  41. Annabel
  42. Buy Proxies
  43. online fish store
  44. forklifts sale
  45. horse colors
  46. Sex Artikel
  47. free psychic chat
  48. Anaelle
  49. boats nz
  50. hiking stores
  51. psychics
  52. Aime
  53. psychic readings
  54. NBA Picks
  55. mannequin agence
  56. dress coupon
  57. best doors
  58. kmdali
  59. gold investment
  60. davey pumps
  61. prawo jazdy gdynia opinie
  62. szkola jazdy gdynia opinie
  63. franchises for sale nz
  64. tanie ksiazki
  65. antykwariat poleca
  66. Carrier Parts
  67. cute dog collars
  68. thermal imaging camera cost
  69. the silver melt value
  70. The best mattresses
  71. Mens leather jackets info
  72. Paladin Pvp Guide
  73. hunterpvp
  74. online psychic readings
  75. Dosimter Shop
  76. Best Value Mauritius Holidays
  77. Big Sea Mall
  78. Warlock Pvp Guide
  79. Living Social
  80. Grouply Deals
  81. All Hair Extensions
  82. toprczone
  83. Gold Secrets Guide
  84. Daily Deals
  85. Gatsby
  86. Noice
  87. Wooden Blinds
  88. mysecretglow
  89. Monster Beats By Dr Dre
  90. Gratio
  91. The Jump Manual
  92. Anti Aging Simply
  93. Loch Lomond Lodge
  94. Dynamic Insulation
  95. Rib Ride
  96. Monitor Wind
  97. CIM Course
  98. Dynamic Insulation
  99. Retro Jordans
  100. Nike Air Jordan 4
  101. one x
  102. chase bank
  103. chaseonlinebanking
  104. car insurance quotes
  105. calfless balkanize complex
  106. Phantom of the Opera Tickets
  107. raspberry ketone

You must be logged in to post a comment.