Ajax 板


LINE

※ 引述《mrbigmouth (大嘴先生)》之銘言: : (function(global) { : var i; : for (i in global) { : console.log(i+":"); : console.dir(global[i]); : } : }(this)) 感謝 mrbigmouth 大大 這已經很接近我想要得結果了 我想作的是這種事情: (function(global) { var i; for (i in global) { eval("var "+i+"=null;"); } console.log("ERR HERE"); })((new Function("return this;"))()); console.log('OK HERE'); 用閉包的區域變數,蓋掉全域變數,製造一個「乾淨」的環境出來跑別人的CODE。 假設我不讓他用console,就把console = null; 這樣他就執行不到了。 只留下我想讓他跑的部份 但是,目前還有漏掉 像是 Function 、 Date 這種物件就沒蓋到 還有 node.js 的 require也還在 像這種東西我還在找方法列舉他 一旦能列舉,就能夠用 var Function = null;的方式去蓋掉了 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 125.227.87.115
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Ajax/M.1432118921.A.676.html
1F:→ mmis1000: 別自幹sandbox,你的方法有洞,會被拿到require惡搞 05/20 19:03
2F:→ mmis1000: (0).constructor.constructor('return this')() 05/20 19:50
3F:→ mmis1000: 這一行能拿到真正的global,而且一個關鍵字都沒 05/20 19:51
4F:→ LaPass: =口=||| 05/20 20:01
5F:→ danny8376: JS很複雜的wwww 05/20 22:13
6F:→ LaPass: 那要在JS底下運行腳本,是不是都沒辦法了啊..... (或是用 05/20 22:57
7F:→ LaPass: JS自幹一個編譯器出來,但效能應該會很悲劇) 05/20 22:57
8F:→ mmis1000: nodejs有一些現成的sandbox模組 05/20 23:35
9F:→ mmis1000: https://github.com/bcoe/sandcastle 像這個 05/20 23:38
10F:→ mmis1000: 不過仍然不能保證100%安全,畢竟nodejs本身的andbox就是 05/20 23:41
11F:→ mmis1000: 有洞的,而這些也只是試圖把動堵起來 05/20 23:41
12F:→ LaPass: 可是瀏覽器上沒辦法跑node.js 05/20 23:42
13F:→ mmis1000: error.capturestacktrace 主要是這東西的問題 05/20 23:42
14F:→ mmis1000: 那用一個不同domain的iframe去跑 05/20 23:43
15F:→ LaPass: server端可能還比較好解決,因為可以用其他語言去搞個js編 05/20 23:43
16F:→ LaPass: 譯器去跑,網頁就沒辦法... 而且我需要他跑出來的結果。 05/20 23:45
17F:→ LaPass: iframe也不是那麼好解決 05/20 23:45
18F:→ mmis1000: 或是用web worker之類 05/20 23:45
19F:→ mmis1000: 反正一定要在完全不同scope下,不然等著被玩 05/20 23:47
20F:→ mmis1000: 可以一個幫助的script,把危險code eval在worker裡 05/20 23:50
21F:→ LaPass: orz..... 這個我知道..... 05/20 23:50
22F:→ mmis1000: 讓他甚麼都看不到 05/20 23:50
23F:→ LaPass: 來試試看worker好了 05/20 23:51
25F:→ mmis1000: 來個實驗... 05/21 02:35
26F:→ mmis1000: https://github.com/eligrey/jsandbox 現成的東西 05/21 03:59
27F:→ LaPass: 好東西!!OAO!! 05/21 10:49
28F:→ LaPass: http://f23ko.com/JSTEST/websocket.html 我自己寫了一個 05/22 01:29
29F:→ LaPass: 來試試看,這樣OK XD 05/22 01:29







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BabyMother站內搜尋

TOP