您好,登錄后才能下訂單哦!
這篇文章主要介紹了javascript的函數可不可以hook的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇javascript的函數可不可以hook文章都會有所收獲,下面我們一起來看看吧。
javascript的函數可以hook;hook是一種動態修改函數執行流程或返回結果的方法,JavaScript作為一種動態語言也可以進行hook操作,hook通常用來針對某些參數或者變量進行偵聽、打印輸出、替換等操作。
本教程操作環境:windows10系統、javascript1.8.5版、Dell G3電腦。
可以。
Hook是一種動態修改函數執行流程或返回結果的方法,在實際應用中非常廣泛。Javascript作為一種動態語言,也可以進行Hook操作。隨著Javascript語言的發展,Hook的方法也越來越多,
hook直譯的意思為鉤子,在逆向領域通常用來針對某些參數,變量進行偵聽,打印輸出,替換等操作。
示例如下:
示例代碼
function add(a,b){ return a + b }
hook代碼
這是一個很簡單加法函數,通過Hook能獲取到這兩個參數的值,相當于在return之前添加了一句代碼console.log(a,b),這樣便能輸出這兩個的值便于分析。那么可以使用如下的方式來復寫改函數,而這個方式在javascript也就是裝飾者模式
let _add = add add = function () { console.log('arguments', arguments) let result = _add.apply(this, arguments) console.log('result', result) return result // 如果不需要result 則可直接return _add() }
完整代碼
function add(a, b) { return a + b } let _add = add add = function () { console.log('arguments', arguments) let result = _add.apply(this, arguments) console.log('result', result) return result } add(1, 2)
再次調用add(1,2)便會輸出arguments參數以及結果3,一個很簡單HOOK就實現了。
不過這個例子可能過于簡單,我所要表達的意思是,通過Hook,定位到我們想Hook的函數與變量,通過一系列操作(函數復寫,元編程),只要觸發該函數或使用(取值,修改)該變量,便能將我們想要的結果(前后的結果(如 加密前,加密后))獲取到。這才是我們的目的。
書中給的例子想說明的,想為某個原函數(比如這里的add)添加一些功能,但該原函數可能是由其他開發者所編寫的,那么直接修改原函數本身將可能導致未知BUG,于是便可以用上面的方式進行復寫原函數的同時,還不破壞原函數。
關于“javascript的函數可不可以hook”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“javascript的函數可不可以hook”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。