- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我使用 Zend Rest Controller 开发 Web 服务,现在我需要在用户访问我的页面之前对他们进行身份验证。
为此,我计划使用带有 curl 的 HTTP 身份验证,如下所示:
curl_setopt($ch, CURLOPT_USERPWD, "myusername:mypassword");
我这样称呼那个 curl 页面:
curl -u myusername:mypassword http://localhost/controller/action/page.xml
我有一个很大的疑问。
我需要将用户名和密码存储在 .htpasswd 文件中吗?如果是这样,我需要如何检索参数并验证它们?
最佳答案
如果您使用 .htaccess,网络服务器将默默地为您处理所有事情。您可以假设(除非您犯了错误)此人已获得授权。
但是如果您想使用 http 身份验证并获取用户名和密码以在您自己的登录系统中使用,那么您需要编写被调用的脚本,如下所示。
http://php.net/manual/en/features.http-auth.php
除了通过用户名和密码发送外,curl 确实与它无关。它只是充当 http 客户端,就像网络浏览器一样。
您如何执行身份验证归结为您要实现的目标。 http auth 是一个简单的身份验证系统。
直流
我给你的链接告诉你如何去做。您正在调用的页面必须发回身份验证请求,否则 curl 将不会转发身份验证详细信息。
如果您使用 .htaccess 和 .htpasswd 文件,您将看不到身份验证,因为网络服务器将删除这些 header 。如果您使用的是像我提供的链接中那样的自定义 http 身份验证,那么您只能在发送身份验证请求后才能访问它们,这意味着第一次加载页面时您将无法访问它们。
我的意思是.. 首先 curl 请求没有任何凭证的页面,如果它得到页面然后它停止,如果它收到凭证请求然后发送它们。
这意味着如果您希望 http://localhost/controller/action/page.xml
查看凭据,则它必须要求提供这些凭据。如果它看起来像一个静态页面,那么它不会要求提供凭据。
你是不是要输入 http://localhost/controller/action/page.php
直流
过程是这样的...
curl ---> page.php (first request)
curl <--- page.php (first reply) "Please identify yourself" ('401 unauthorised' http code)
curl username:password ---> page.php (second request now includes user auth)
curl <--- page.php (second reply) ok here is the page (if id succesfull)
好的,正如 promise 的一些工作示例
首先创建2个php脚本
auth.php 是我在上面发布的链接中提供的示例的修改副本
<?php
if (!isset($_SERVER['PHP_AUTH_USER'])) {
header('WWW-Authenticate: Basic realm="My Realm"');
header('HTTP/1.0 401 Unauthorized');
echo "User name and password is required. Please try again.\n";
} else {
// we now have access to the user and password :)
echo "Hello {$_SERVER['PHP_AUTH_USER']}\n";
echo "You entered {$_SERVER['PHP_AUTH_PW']} as your password.\n";
}
?>
curlfetch.php 是您其他帖子中脚本的副本
<?php
$curl = curl_init('http://localhost/auth.php');
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl, CURLOPT_USERPWD, 'key:123456');
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);
}
?>
在您的服务器上创建并保存这些脚本
现在在没有密码的情况下测试脚本 1
curl http://localhost/auth.php
这导致...
User name and password is required. Please try again.
现在尝试输入密码
curl -u user:pass http://localhost/auth.php
这导致...
Hello user
You entered pass as your password.
现在尝试第二个脚本,注意我们不提供脚本中提供的用户名或密码
curl http://localhost/curlfetch.php
这导致...
Hello key
You entered 123456 as your password.
现在作为引用尝试从浏览器调用这两个脚本
直流
关于php - 使用 Zend 进行 curl http 身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4942417/
在 JSF2 应用程序中遇到验证属性的问题时,有两种主要方法。 使用 Annotation 在 ManagedBean 上定义验证 @ManagedBean public class MyBean {
我想实现一个不常见的功能,我认为 jquery 验证插件将是最好的方法(如果您在没有插件的情况下建议和回答,我们也会欢迎)。我想在用户在输入字段中输入正确的单词后立即隐藏表单。我试过这个: $("
我有几个下拉菜单(类名为month_dropdown),并且下拉菜单的数量不是恒定的。我怎样才能为它们实现 NotEqual 验证。我正在使用 jQuery 验证插件。 这就是我写的 - jQuery
我设法制作了这个网址验证代码并且它起作用了。但我面临着一个问题。我认为 stackoverflow 是获得解决方案的最佳场所。 function url_followers(){ var url=do
我目前正在使用后端服务,该服务允许用户在客户端应用程序上使用 Google Games 库登录。 用户可以通过他们的 gplay ID 向我们发送信息,以便登录或恢复旧帐户。用户向我们发送以下内容,包
我正在尝试验证输入以查看它是否是有效的 IP 地址(可能是部分地址)。 可接受的输入:172、172.112、172.112.113、172.112.113.114 Not Acceptable 输入
我从 Mongoose 验证中得到这条消息: 'Validator failed for path phone with value ``' 这不应该发生,因为不需要电话。 这是我的模型架构: var
我一直在尝试使用Python-LDAP (版本 2.4.19)在 MacOS X 10.9.5 和 Python 2.7.9 下 我想在调用 .start_tls_s() 后验证与给定 LDAP 服务
我正在处理一个仅与 IE6 兼容的旧 javascript 项目(抱歉...),我想仅在 VS 2017 中禁用此项目的 ESLint/CSLint/Javascript 验证/CSS 验证。 我知道
我正在寻找一种方法来验证 Spring 命令 bean 中的 java.lang.Double 字段的最大值和最小值(一个值必须位于给定的值范围之间),例如, public final class W
我正在尝试在 springfuse(JavaEE 6 + Spring Framework (针对 Jetty、Tomcat、JBoss 等)) 和 maven 的帮助下构建我的 webapps 工作
我试图在我们的项目中使用 scalaz 验证,但遇到了以下情况: def rate(username: String, params: Map[String, String]): Validation
我有一个像这样的 Yaml 文件 name: hhh_aaa_bbb arguments: - !argument name: inputsss des
我有一个表单,人们可以单击并向表单添加字段,并且我需要让它在单击时验证这些字段中的值。 假设我单击它两次并获取 2 个独立的字段集,我需要旋转 % 以确保它在保存时等于 100。 我已放入此函数以使其
在我的页面中有一个选项可以创建新的日期字段输入框。用户可以根据需要创建尽可能多的“截止日期”和“起始日期”框。就像, 日期_to1 || date_from1 日期到2 ||日期_from2 date
我有一个像这样的 Yaml 文件 name: hhh_aaa_bbb arguments: - !argument name: inputsss des
有没有办法在动态字段上使用 jquery 验证表单。 我想将其设置为必填字段 我正在使用 Jsp 动态创建表单字段。 喜欢 等等...... 我想使用必需的表单字段验证此表单字段。 最佳答
嗨,任何人都可以通过提供 JavaScript 代码来帮助我验证用户名文本框不应包含数字,它只能包含一个字符。 最佳答案 使用正则表达式: (\d)+ 如果找到匹配项,则字符串中就有一个数字。 关于J
我有两个输入字段holidayDate和Description(id=tags) $(document).ready(function() {
我遇到了这个问题,这些验证从电子邮件验证部分开始就停止工作。 我只是不明白为什么即使经过几天的观察,只是想知道是否有人可以在这里指出我的错误? Javascript部分: function valid
我是一名优秀的程序员,十分优秀!