php url跨站,php 防跨站表單提交

1 crub.class.php

class Crumb {

CONST SALT = "your-secret-salt";

static $ttl = 1; //$ttl表示這個隨機串的有效時間(秒)

static public function challenge($data) {

return hash_hmac('md5', $data, self::SALT);

}

static public function issueCrumb($uid, $action = -1) {

$i = ceil(time() / self::$ttl);

return substr(self::challenge($i . $action . $uid), -12, 10);

}

static public function verifyCrumb($uid, $crumb, $action = -1) {

//var_Dump( $uid);

$i = ceil(time() / self::$ttl);

if(substr(self::challenge($i . $action . $uid), -12, 10) == $crumb ||

substr(self::challenge(($i - 1) . $action . $uid), -12, 10) == $crumb)

return true;

return false;

}

}

應用示例

構造表單

在表單中插入一個隱藏的隨機串crumb

處理表單 demo.php

對crumb進行檢查

if(Crumb::verifyCrumb($uid, $_POST['crumb'])){

//按照正常流程處理表單

}else{

//crumb校驗失敗,錯誤提示流程

}

如果是ajax,也可以應用crumb,以jquery的ajax提交為例:

$.ajax({

type: "POST",

url: "some.php",

data: "name=blah&crumb=<?php echo Crumb::issueCrumb($uid)?>",

success: function(msg){

alert( "Data Saved: " + msg );

}

});

同理,crumb也可以在get方式的ajax請求中應用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值