php resf验证,PHP rest API身份验证

我为PHP应用程序构建了一个宁静的API。目前,API只会接受json响应。请求,路由和响应都由框架处理,但我需要构建自定义的认证机制。

我想添加两项以增加安全性并避免重播攻击:时间戳和随机数。

除了这两个项目之外,我还希望进行一次完整性检查,以确保从安全性或可用性的角度来看,我没有错过任何其他显而易见的事情。

entity_id应该放在标题中而不是请求中吗?

这是我到目前为止的认证:

function authenticate_request()

{

$request = json_decode(file_get_contents('php://input'));

$request_headers = apache_request_headers();

if ( ! isset($request_headers['X-Auth']) OR ! isset($request_headers['X-Auth-Hash'])) {

return false;

}

$user = User::get_by('public_key', $request_headers['X-Auth']);

if ( ! $user) {

return false;

}

// every request must contain a valid entity

if (isset($request->entity_id) && $request->entity_id > 0) {

$this->entity_id = $request->entity_id;

} else {

return false;

}

$entity = Entity::find($this->entity_id);

if ( ! $entity) {

return false;

}

// validate the hash

$hash = hash_hmac('sha256', $request, $user->private_key);

if ($hash !== $request_headers['X-Auth-Hash']) {

return false;

}

return true;

}示例卷曲请求:

$public_key = '123';

$private_key = 'abc';

$data = json_encode(array('entity_id' => '3087', 'date_end' => '2012-05-28'));

$hash = hash_hmac('sha256', $data, $private_key);

$headers = array(

'X-Auth: '. $public_key,

'X-Auth-Hash: '. $hash

);

$ch = curl_init('http://localhost/myapp/api/reports/');

curl_setopt($ch,CURLOPT_HTTPHEADER,$headers);

curl_setopt($ch,CURLOPT_POSTFIELDS, $data);

curl_setopt($ch,CURLOPT_RETURNTRANSFER,true);

$result = curl_exec($ch);

curl_close($ch);

print_r($result);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值