小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Token的設(shè)計(jì)方法

 quasiceo 2015-06-24

Token的設(shè)計(jì)方法

2013/7/11 4:11:15
從安全性方面考慮,有些接口需要對(duì)來源進(jìn)行判斷。例如從客戶端上傳圖片至服務(wù)器端,我們需要驗(yàn)證來源以辨別其訪問是否合法。
以下是常規(guī)的token設(shè)計(jì)思路,我們?cè)谡?qǐng)求的來源頁面(A頁面)生成出一個(gè)時(shí)間戳,將該時(shí)間戳與自定義的唯一標(biāo)識(shí)符合并組成一個(gè)新的字符串作為token。在提交信息給服務(wù)器時(shí),將時(shí)間戳和token一同交至服務(wù)器端。
A頁面:
1 <?php $timestamp = time();?>
2 <input type="text" name="timestamp" value="<?php echo $timestamp;?>" />
3 <input type="text" name="token" value="<?php echo md5('unique_salt' . $timestamp);?>" />
服務(wù)器端(B頁面)將接收到的時(shí)間戳按照A頁面的方法與唯一標(biāo)識(shí)符合并組成token,如果B頁面生成的token與A頁面生成的token一致,則可以判定A頁面的來源是可靠的。
B頁面:
1 $verifyToken = md5('unique_salt' . $_POST['timestamp']);
2 if($_POST['token'] == $verifyToken){
3      //token 驗(yàn)證正確
4 } 

之所以利用時(shí)間戳來制造token有兩方面優(yōu)勢(shì),一個(gè)是生成字符串的隨機(jī)性,另一個(gè)是可以根據(jù)該字符串做初步的時(shí)效性驗(yàn)證。

以上只是基礎(chǔ)的思路,但是這種方法的驗(yàn)證會(huì)涉及到一個(gè)問題:當(dāng)你的源碼泄露時(shí),其他人就可以根據(jù)你的唯一標(biāo)識(shí)符unique_salt來構(gòu)造出token使其通過驗(yàn)證。

因此,我們可以嘗試采用安全性更為嚴(yán)密的方法來構(gòu)造token:Session+時(shí)間戳

我們可以在請(qǐng)求的來源頁面(A頁面)隨機(jī)生成一個(gè)字符串RandomStr,并將其保存在session['unique_salt']中,再利用RandomStr與時(shí)間戳結(jié)合生成一個(gè)token。提交數(shù)據(jù)時(shí),將該token與時(shí)間戳一起提交至服務(wù)器端(B頁面),此時(shí),服務(wù)器將根據(jù)session['unique_salt']+接收的時(shí)間戳來生成token,并用來源頁面提交的token作對(duì)比,如果一致則判定A頁面的來源是可靠的。

通過這種方法,即使你的源碼被泄露,但是由于session['unique_salt']的隨機(jī)性,其他人也無法構(gòu)造出正確的token來通過服務(wù)器驗(yàn)證。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多