欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript注入技巧

 更新時間:2007年06月22日 00:00:00   作者:  
作者: kostis90gr
翻譯: 黯魂[S.S.T]
本文已發(fā)表于《黑客防線》6月刊,版權(quán)屬于《黑客防線》及腳本安全小組,轉(zhuǎn)載請保持文章完整性,謝謝 :)

這份指南僅僅是出于報告目的,如果任何人把它用于違法目的,我不負責(zé)任.

通過使用javascript注入,用戶不用關(guān)閉網(wǎng)站或者把頁面保存在他的PC上就可以改變網(wǎng)站中的內(nèi)容.這是由他的瀏覽器的地址欄完成的.

命令的語法看上去像這樣:

Copy code
javascrit:alert(#command#)

比方說如果你想看到在網(wǎng)站http://www.example.com里面的一個警告框,那么首先在地址欄輸入URL(www.example.com),當(dāng)頁面加載完之后,清空URL并輸入javascrit:alert("Hello World")作為一個新的URL.這樣將彈出一個警告框顯示Hello World.可是,一些人會用這個技巧改變頁面內(nèi)的幾乎任何內(nèi)容.例如一個圖片.讓我們設(shè)想有一個網(wǎng)站的logo圖片.通過查看頁面源代碼(可以使用瀏覽器中的"查看源代碼"做到),我們發(fā)現(xiàn)一句HTML代碼:

Copy code
<IMG Name="hi" src="hello.gif">

得到信息:有一個圖片被命名為hi,且源文件為hello.gif.我們想要改變它為bye.jpeg并存儲到我們的站點http://www.mysite.com上.所以我們的圖片的完整URL是http://www.mysite.com/bye.jpeg 要使用javascript注入,我們需要在地址欄中輸入:

Copy code
javascript:alert(document.hi.src="[url]http://www.mysite.com/bye.jpeg"[/url])

你將看到一個提示框說http://www.mysite.com/bye.jpeg,并且在那之后圖片將會被改變.注意雖然那些變化只是暫時的!如果你刷新頁面或者再次進入,你造成的變化將丟失,因為你改變的不是服務(wù)器上的站點,而是你PC上的.

使用同樣的方法,我們可以查看或改變變量的值.比如我們在網(wǎng)站中找到這樣一些源代碼:

Copy code
<SCRIPT LANGUAGE="JavaScript"> 
var a="test" 
</SCRIPT>

意思是給變量a賦值test.為了查看變量的值,我們將輸入:

Copy code
javascript:alert(a)

然后為了把它從test改為hello,則輸入:

Copy code
javascript:alert(a="hello")

但是javascript注入主要用來改變表單的屬性.下面是我們已有的部分代碼:

Copy code
<form name="format" action="send.php" method="post"> 
<input type="hidden" name="mail" value="[email]someone@somewhere.com[/email]"> 
<input type="text" name="name"> 
<input type="submit" value="submit"></form>

我們想要表單發(fā)送到我們的郵箱,而不是代碼中的郵箱someone@somewhere.com,這個想法可以被這個命令完成:

Copy code
javascript:alert(document.format.mail.value="[email]me@hacker.com[/email]")

到現(xiàn)在你已經(jīng)知道我總是按層次來講述,下面我們就從大到小開始:
1)從document開始
2)輸入我們想要改變的對象名(比如document.hi.src)或者它所屬的屬性并且重新賦值(比如document.format.mail.value)
3)最后結(jié)束于我們想要改變的特征(比如源路徑:document.hi.src,或者變量值:document.format.mail.value)
4)用"."號分隔單詞.
5)當(dāng)我們想要改變特征值的時候,使用"="號和新的特征值.
*注意:當(dāng)新的特征值為字符串時需要使用雙引號""括起來(比如:document.format.mail.value="me@hacker.com")如果我們想要把它變?yōu)橐粋€變量的值,則不需要使用雙引號"".比如我們想改變變量a的值,使其等于變量b的值,會輸入javascript:alert(a=b).

但是,大多數(shù)頁面中的屬性都沒有名字,例如:

Copy code
<form action="send.php" method="post"> 
<input type="hidden" name="mail" value="[email]someone@somewhere.com[/email]"> 
<input type="text" name="name"> 
<input type="submit" value="submit"></form>

在這個代碼中,表單沒有名字.利用上面的所有信息,命令可能看上去像這樣:

Copy code
javascript:alert(document. .mail.value="[email]me@hacker.com[/email]")

在這種情況下我們將不得不計算所有的表單來發(fā)現(xiàn)這個表單的序號.我會用一個例子來講解:
復(fù)制代碼 代碼如下:
<form action="send.php" method="post"> 
<input type="text" name="name"> 
<input type="submit" value="submit"></form> 
<form action="send.php" method="post"> 
<input type="hidden" name="mail" value="someone@somewhere.com"> 
<input type="text" name="name"> 
<input type="submit" value="submit"></form> 
<form action="send.php" method="post"> 
<input type="text" name="name"> 
<input type="submit" value="submit"></form>


在以上代碼中我們看見了3個表單,但是我們只對第二個感興趣.因此我們想要的表單序號就是2.千萬別忘記我們是從1開始計算的,我們說1,2,3,4...但是在javascript中卻是從0開始計算的.它是0,1,2,3...所以真正的表單序號是1,不是2.通常我們要先找到表單序號再減一.

我們將用這個序號來補全我們的命令:
復(fù)制代碼 代碼如下:
javascript:alert(document.forms[1].mail.value="me@hacker.com")


像這樣,你就能改變沒有名字的圖片或者鏈接了.
對于圖片:
復(fù)制代碼 代碼如下:
javascript:alert(document.images[3].src="#你想改變的目標(biāo)圖片URL#") 

對于鏈接: 
復(fù)制代碼 代碼如下:
javascript:alert(document.links[0].)


最后,我們可以用這個技巧編輯cookies.

下面的命令由triviasecurity.net的Dr_aMado所編寫,但是我修改了一點以至于在用戶編輯它之前就能顯示cookie.你只需要復(fù)制它們到地址欄:
復(fù)制代碼 代碼如下:
javascript:alert(window.c=functiona(n,v,nv){c=document.cookie;c=c.substring(c.indexOf(n)+n.length,c.length);c=c.substring(1,((c.indexOf(";")>-1)?c.indexOf(";") :c.length));nc=unescape(c).replace(v,nv);document.cookie=n+"="+escape(nc);return unescape(document.cookie);});alert('The cookie is: "'+document.cookie+'"');alert(c(prompt("The name of the cookie:",""),prompt("Change this value:",""),prompt("with this:","")));


作為結(jié)束,我必須強調(diào)我們所做的改變僅僅是在用戶端!就像是把網(wǎng)站保存在了你的PC上,然后修改它.盡管如此,使用這個技巧你仍然可以欺騙一個頁面(例如cookies)或者通過一個頁面的安全驗證.例如一些頁面會檢測用戶從哪發(fā)送的數(shù)據(jù).如果數(shù)據(jù)從http://www.test.com/form.php發(fā)送到http://www.test.com/check.php,check.php可能會檢測數(shù)據(jù)是否是從http://www.test.com/form.php上的表單發(fā)送的.除此之外,如果你打算登錄一個頁面中你自己的javascript代碼,通過使用一些像這樣的技巧,你將能夠改變類似不變的圖片!可是你需要用到比這里講到的更深層次的知識.

要是有任何問題和建議,請發(fā)郵件給我:kostis90gr@gmail.com

相關(guān)文章

  • event.currentTarget與event.target的區(qū)別介紹

    event.currentTarget與event.target的區(qū)別介紹

    event.currentTarget與event.target的區(qū)別想大家在使用的時候不是很在意,本文以測試代碼來講解它門之間的不同
    2012-12-12
  • 中高級前端必須了解的JS中的內(nèi)存管理(推薦)

    中高級前端必須了解的JS中的內(nèi)存管理(推薦)

    這篇文章主要介紹了中高級前端必須了解的JS中的內(nèi)存管理,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • JavaScript學(xué)習(xí)教程之cookie與webstorage

    JavaScript學(xué)習(xí)教程之cookie與webstorage

    這篇文章主要給大家介紹了關(guān)于JavaScript學(xué)習(xí)教程之cookie與webstorage的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • JavaScript Base64編碼和解碼,實現(xiàn)URL參數(shù)傳遞。

    JavaScript Base64編碼和解碼,實現(xiàn)URL參數(shù)傳遞。

    JavaScript Base64編碼和解碼,實現(xiàn)URL參數(shù)傳遞。...
    2006-09-09
  • 微信小程序記住密碼的功能簡單幾步實現(xiàn)

    微信小程序記住密碼的功能簡單幾步實現(xiàn)

    軟件中的“記住密碼”選框不知道大家平時會不會勾選,反正對于一個重度懶癌患者的我來說就沒有不勾選的時候,畢竟隔一段時間就重新輸入一遍難記又難輸?shù)馁~號密碼,想想就讓人頭皮發(fā)麻。今天教大家用代碼在微信小程序中實現(xiàn)這個簡單的小功能
    2023-01-01
  • JavaScript使用Ajax上傳文件的示例代碼

    JavaScript使用Ajax上傳文件的示例代碼

    本篇文章主要介紹了JavaScript使用Ajax上傳文件的示例代碼,詳細的介紹了兩種上傳方式,感興趣的小伙伴可以了解一下
    2017-08-08
  • 微信分享調(diào)用jssdk實例

    微信分享調(diào)用jssdk實例

    這篇文章主要為大家詳細介紹了微信分享調(diào)用jssdk實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • JavaScript 中文轉(zhuǎn)拼音實現(xiàn)代碼 有些bug

    JavaScript 中文轉(zhuǎn)拼音實現(xiàn)代碼 有些bug

    在做項目時候遇到一個小小的顯示客戶部門名稱(拼音)的業(yè)務(wù),就是在部門名稱下有相應(yīng)的拼音,而在現(xiàn)有的數(shù)據(jù)庫中沒有相應(yīng)字段,并且部門數(shù)量比較多,添加起來比較費時,就想能否在js中實現(xiàn),在頁面中處理。
    2010-03-03
  • UniApp開發(fā)H5接入微信登錄的全過程

    UniApp開發(fā)H5接入微信登錄的全過程

    uni-app是一個使用Vue.js開發(fā)跨平臺應(yīng)用的前端框架,下面這篇文章主要給大家介紹了關(guān)于UniApp開發(fā)H5接入微信登錄的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • layui數(shù)據(jù)表格 table.render 報錯的解決方法

    layui數(shù)據(jù)表格 table.render 報錯的解決方法

    今天小編就為大家分享一篇layui數(shù)據(jù)表格 table.render 報錯的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09

最新評論