php digest,PHP http Digest认证在 chrome 内核浏览器中不弹出认证框怎么解决??

php摘要认证(digest) 在 firefox 中 或 ie浏览器 中都能够正常弹出认证窗口,但是在 chrome内核的浏览器(例如:360安全浏览器) 中无法弹出认证窗口(广告过滤插件等已经关掉了)。

PHP 代码:

$realm = 'ftl.com';

$qop = 'auth';

$nonce = md5(time());

header('WWW-Authenticate: Digest realm=' . $realm . ' qop=' . $qop . ' nonce=' . $nonce);

header('HTTP/1.1 401 Unauthorized');

echo '你取消了验证!';

exit;

上面这段代码在 360安全浏览器中 显示:

bVEKmC?w=531&h=197

查看头部信息:

bVEKmV?w=663&h=660

在 Request Headers 中没有 Authorization 头的相关信息。

然而在 firefox 中同一段代码的显示界面如下:

bVEKnp?w=397&h=173

验证成功后查看头部信息如下:

bVEKnA?w=466&h=509

在请求头中也有 Authorization 头。

怎样在 chrome 内核的浏览器中完成 digest 认证(PHP 官网教程的代码在也会出现这个问题)??

最后,贴出完整的测试代码:

Javscript 部分:

var url = 'php/xhr.php';

var xhr = new XMLHttpRequest();

xhr.open('post' , url , true , 'test' , '123456');

xhr.setRequestHeader('Content-Type' , 'Application/x-www-form-urlencoded');

xhr.send(null);

xhr.onload = function(){

console.log('服务端反馈会数据:' , this.response);

}

PHP 部分:

$users = array('test' => '123456');

if (!isset($_SERVER['PHP_AUTH_DIGEST'])) {

authenticate();

exit;

}

$digest = explode(',' , trim_all($_SERVER['PHP_AUTH_DIGEST'] , true));

$rel = array();

array_walk($digest , function($val){

global $rel;

$arr = explode('=' , $val);

$rel[$arr[0]] = $arr[1];

unset($arr);

});

unset($digest);

// 安全部分

$secure_part = $rel['username'] . ':' . $rel['realm'] . ':' . $users[$rel['username']];

// 报文部分

$header_part = $_SERVER['REQUEST_METHOD'] . ':' . $rel['uri'];

// 摘要计算

$response = md5($secure_part) . ':' . $rel['nonce'] . ':' . $rel['nc'] . ':' . $rel['cnonce'] . ':' . $rel['qop'] . ':' . md5($header_part);

$response = md5($response);

// 验证

if ($rel['response'] === $response) {

echo '验证成功!';

} else {

//authenticate();

echo '验证失败!';

}

// 认证函数

function authenticate(){

$realm = 'ftl.com';

$qop = 'auth';

$nonce = md5(time());

header('WWW-Authenticate: Digest realm=' . $realm . ' qop=' . $qop . ' nonce=' . $nonce);

header('HTTP/1.1 401 Unauthorized');

echo '你取消了验证!';

exit;

}

/*

* 过滤

* 基本过滤:空格 \r \n 字符串

* 加强过滤:单引号 双引号

*/

function trim_all($str = '' , $isStripQuote = false){

$str = preg_replace('/^( |\r|\n)+/' , '' , $str);

$str = preg_replace('/( |\r|\n)+$/' , '' , $str);

$str = preg_replace('/(\W)( |\r|\n)+/' , '$1' , $str);

$str = preg_replace('/( |\r|\n)+(\W)/' , '$2' , $str);

if ($isStripQuote) {

$str = preg_replace('/"|\'/' , '' , $str);

}

return $str;

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值