


JavaScript - PHP http Digest 認証の Chrome カーネル ブラウザで認証ボックスがポップアップ表示されない問題を解決するにはどうすればよいですか? ?
php摘要认证(digest)
在 firefox 中 或 ie浏览器
中都能够正常弹出认证窗口,但是在 chrome内核的浏览器(例如:360安全浏览器)
中无法弹出认证窗口(广告过滤插件等已经关掉了)。
<code>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;</code>
上面这段代码在 360安全浏览器中
显示:
查看头部信息:
在 Request Headers
中没有 Authorization 头的相关信息。
然而在 firefox
中同一段代码的显示界面如下:
验证成功后查看头部信息如下:
在请求头中也有 Authorization
头。
怎样在 chrome 内核的浏览器中完成 digest 认证(PHP 官网教程的代码在也会出现这个问题)??
最后,贴出完整的测试代码:
Javscript
部分:
<code>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); }</code>
PHP
部分:
<code> $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; } </code>
回复内容:
php摘要认证(digest)
在 firefox 中 或 ie浏览器
中都能够正常弹出认证窗口,但是在 chrome内核的浏览器(例如:360安全浏览器)
中无法弹出认证窗口(广告过滤插件等已经关掉了)。
<code>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;</code>
上面这段代码在 360安全浏览器中
显示:
查看头部信息:
在 Request Headers
中没有 Authorization 头的相关信息。
然而在 firefox
中同一段代码的显示界面如下:
验证成功后查看头部信息如下:
在请求头中也有 Authorization
头。
怎样在 chrome 内核的浏览器中完成 digest 认证(PHP 官网教程的代码在也会出现这个问题)??
最后,贴出完整的测试代码:
Javscript
部分:
<code>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); }</code>
PHP
部分:
<code> $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; } </code>

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP へのログインは非常に簡単な作業です。使用する関数は 1 つだけです。 cronjob などのバックグラウンド プロセスのエラー、例外、ユーザー アクティビティ、ユーザーが実行したアクションをログに記録できます。 CakePHP でのデータのログ記録は簡単です。 log()関数が提供されています

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。
