免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2282 | 回复: 3
打印 上一主题 下一主题

[登陆] 无法实现用户名,密码验证,请帮忙 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-11-12 15:48 |只看该作者 |倒序浏览
if(!isset($PHP_AUTH_USER))
        { Header("WWW-Authenticate:Basic realm="$REMOTE_ADDR 管理员登陆"");
          Header("HTTP/1.0 401 Unauthorized");
          echo "对不起,您没有权限n";
          exit();}
        else{ if($PHP_AUTH_USER)!="123") || (md5($PHP_AUTH_PW)!="123"))
                { Header("WWW-Authenticate:Basic realm="用户名或者密码错误"");
                        Header("HTTP/1.0 401 Unauthorized");
                        exit();}
        }

代码是一点问题都没有的,我放到别人的服务器上就能很好的运行
我的服务器是windows2003+IIS+php4,怎么就不行呀?但是其它的PHP程序就能运行
难道和系统设置有关吗?应该怎么样解决?谢谢!

[ 本帖最后由 HonestQiao 于 2005-11-12 20:57 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2005-11-12 17:43 |只看该作者
查手册的结果:好像要Apache模块,IIS不行的.

论坛徽章:
0
3 [报告]
发表于 2005-11-12 18:48 |只看该作者
那请问修改一下IIS,或是在添加一个什么东西行吗?

论坛徽章:
1
技术图书徽章
日期:2013-12-05 23:25:45
4 [报告]
发表于 2005-11-12 21:00 |只看该作者
http://w.yi.org/ftp/FAPM/PHP/php ... ures.http-auth.html


PHP Manual
后退                前进
章 17. 用 PHP 进行 HTTP 认

PHP 的 HTTP 认机制仅在 PHP 以 Apache 模块方式运行时才有效,因此该功能不适用于 CGI 版本。在 Apache 模块的 PHP 脚本中,可以用 header() 函数来向客户端浏览器发送“Authentication Required”信息,使其弹出一个用户名/密码输入窗口。当用户输入用户名和密码后,包含有 URL 的 PHP 脚本将会再次和预定义变量 PHP_AUTH_USER、PHP_AUTH_PW 和 AUTH_TYPE 一起被调用,这三个变量分别被设定为用户名,密码和认类型。预定义变量保存在 $_SERVER 或者 $HTTP_SERVER_VARS 数组中。系统仅支持“基本的”认。请参阅 header() 函数以获取更多信息。

    PHP 版本问题: Autoglobals 全局变量,包括 $_SERVER等,在 PHP 4.1.0 以后版本有效, $HTTP_SERVER_VARS 从 PHP 3 开始有效。

以下是在页面上强迫客户端认的脚本范例:

例子 17-1. HTTP 认范例
<?php
  if (!isset($_SERVER['PHP_AUTH_USER'])) {
    header('WWW-Authenticate: Basic realm="My Realm"');
    header('HTTP/1.0 401 Unauthorized');
    echo 'Text to send if user hits Cancel button';
    exit;
  } else {
    echo "<p>Hello {$_SERVER['PHP_AUTH_USER']}.</p>";
    echo "<p>You entered {$_SERVER['PHP_AUTH_PW']} as your password.</p>";
  }
?>

    兼容性问题: 在编写 HTTP 头信息代码时请格外小心。为了对所有的客户端保证兼容性,关键字“Basic”的第一个字母必须大写为“B”,分界字符串必须用双引号(不是单引号)引用;并且在头信息行 HTTP/1.0 401 中,在 401 前必须有且仅有一个空格。

在以上例程中,我们仅仅只打印出了 PHP_AUTH_USER 和 PHP_AUTH_PW 的值,但在实际运用中,您可能需要对用户名和密码的合法性进行检查。或许进行数据库的查询,或许从 dbm 文件中检索。

请注意由 Internet Explorer 浏览器本身的问题带来的错误。它对头信息的顺序显得似乎有点吹毛求疵。目前在 HTTP/1.0 401 头之前发送 WWW-Authenticate 头信息能解决该问题。

在 PHP 4.3.0 中,为了防止有人通过编写脚本来从用传统外部机制认的页面上获取密码,当外部认对特定页面有效,并且 安全模式 被开启时,PHP_AUTH 变量将不会被设置。但无论如何,REMOTE_USER 可以被用来辨认外部认的用户,即使用 $_SERVER['REMOTE_USER'] 变量。

    设置问题: PHP 用 AuthType 选项来判断外部认机制是否有效。

注意,这仍然不能防止有人通过未认的 URL 来从同一服务器上认的 URL 上偷取密码。

Netscape Navigator 和 Internet Explorer 浏览器都会在收到 401 的服务端返回信息时清空所有的本地浏览器整个域的 Windows 认缓存。这能够有效的注销一个用户,并迫使他们重新输入他们的用户名和密码。有些人用这种方法来使登录状态“过期”,或者作为“注销”按钮的响应行为。

例子 17-2. 强迫重新输入用户名和密码的 HTTP 认的范例
<?php
  function authenticate() {
    header('WWW-Authenticate: Basic realm="Test Authentication System"');
    header('HTTP/1.0 401 Unauthorized');
    echo "You must enter a valid login ID and password to access this resourcen";
    exit;
  }

  if (!isset($_SERVER['PHP_AUTH_USER']) ||
      ($_POST['SeenBefore'] == 1 && $_POST['OldAuth'] == $_SERVER['PHP_AUTH_USER'])) {
   authenticate();
  }
  else {
   echo "<p>Welcome: {$_SERVER['PHP_AUTH_USER']}<br>";
   echo "Old: {$_REQUEST['OldAuth']}";
   echo "<form action='{$_SERVER['PHP_SELF']}' METHOD='POST'>n";
   echo "<input type='hidden' name='SeenBefore' value='1'>n";
   echo "<input type='hidden' name='OldAuth' value='{$_SERVER['PHP_AUTH_USER']}'>n";
   echo "<input type='submit' value='Re Authenticate'>n";
   echo "</form></p>n";
  }
?>

该行为对于 HTTP 基本认标准来说并不是必须的,因此您不能依靠这种方法。对 Lynx 浏览器的测试表明 Lynx 在收到 401 的服务端返回信息时不会清空认文件,因此只要对认文件的检查要求没有变化,只要用户点击“后退”按钮,再点击“前进”按钮,其原有资源仍然能够被访问。不过,用户可以通过按“_”键来清空他们的认信息。

同时请注意,在 PHP 4.3.3 之前,由于微软 IIS 的限制,HTTP 认无法工作在 IIS 服务器的 CGI 模式下。为了能够使其在 PHP 4.3.3 以上版本能够工作,您需要编辑 IIS 的设置“目录安全”。点击“编辑”并且只选择“匿名访问”,其它所有的复选框都应该留空。

另一个限制,在您使用 IIS 的 ISAPI 模式的时候,您无法使用 PHP_AUTH_* 变量,而只能使用 HTTP_AUTHORIZATION。例如,考虑如下代码:list($user, $pw) = explode(':', base64_decode(substr($_SERVER['HTTP_AUTHORIZATION'], 6)));。

    IIS 注意事项:: 要 HTTP 认能够在 IIS 下工作, PHP 配置选项 cgi.rfc2616_headers 必须设置成 0(默认值)。

    注: 如果安全模式被激活,脚本的 UID 会被加到 WWW-Authenticate 头信息的 realm 部分。

后退        起点        前进
特点        上一级        Cookies
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP