gpt4 book ai didi

php - 服务器端的 CURL HTTP 身份验证

转载 作者:IT王子 更新时间:2023-10-29 00:18:04 25 4
gpt4 key购买 nike

我正在使用 Zend 构建 Web 服务,我必须在向用户发送响应之前对他们进行身份验证。用户将使用 curl 向服务器页面发送请求,以 curl_setopt($curl, CURLOPT_USERPWD, 'key:pass');

的形式传递他的凭据

我使用 Zend 框架,因此服务器端页面表示如下:

http://www.example.com/app_name/public/controller/action/parameter

这里是用户请求的总代码(client.php):

<?php
$curl = curl_init('http://www.example.com/app/public/user/add/1');

curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl, CURLOPT_USERPWD, 'username:password');
curl_setopt($curl, CURLOPT_HTTPAUTH, CURLAUTH_ANY);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($curl, CURLOPT_USERAGENT, 'Sample Code');

$response = curl_exec($curl);
$resultStatus = curl_getinfo($curl);

if($resultStatus['http_code'] == 200) {
echo $response;
} else {
echo 'Call Failed '.print_r($resultStatus);
}

?>

现在我想要的是,我必须能够在服务器端(在我的 zend Controller 中)检索用户名和密码,以便我可以从数据库验证用户凭据并相应地发送响应。那么如何在另一个页面中进行身份验证呢?

最佳答案

Zend Framework 有一个现成的组件来处理 HTTP 身份验证。

检查例子在

如果您不想使用它,您仍然可以采用“老式”方式,如中所述

并手动检查 $_SERVER['PHP_AUTH_USER']$_SERVER['PHP_AUTH_PW']

关于php - 服务器端的 CURL HTTP 身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4957002/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com