基于PHP的用户认证

如果希望在每一段脚本上都进行口令保护,可以结合使用header()语句、$PHP_AUTH_USER和$PHP_AUTH_PW来建立基本的认证方案,通常的基于服务器的提问/响应顺序。
首先,用户从服务器上请求一个文件。如果这个文件在服务器上是被保护的,则在响应的头部向用户返回一个401(示经授权的用户)字符串。浏览器收到这个响应后,弹出要求用户输入用户名/口令的对话框。然后,用户在对话框中输入一个用户名和口令,点击OK按钮将信息返回服务器供认证使用。如果用户名和口令有效,被保护的文件将向用户开放,只要用户还在使用文件,认证会一直有效。
一段简单的PHP脚本文件通过向用户发送一个适当的能够引起自动显示用户名/口令对话框的HTTP头部就可以模仿HTTP的提问/响应系统,PHP把用户在用户名/口令对话框中输入的信息存储在$PHP_AUTH_USER和$PHP_AUTH_PW中,使用这二个变量,就可以与存储在文本文件、数据库等文件中的用户名/口令进行比较。
下面例子采用了二个硬编码的值进行认证,但无论用户名和口令放在什么地方,其原理都是相同的。

<?
/* 检查$PHP_AUTH_USER和$PHP_AUTH_PW中的值*/
if ((!isset($PHP_AUTH_USER)) || (!isset($PHP_AUTH_PW))) {
  /* 如果没有值,则发送一个能够引发对话框出现的头部*/
  header(’WWW-Authenticate: Basic realm="My Private Stuff"’);
  header(’HTTP/1.0 401 Unauthorized’);
  echo ’Authorization Required.’;
  exit;
} else if ((isset($PHP_AUTH_USER)) && (isset($PHP_AUTH_PW))){
  /* 变量中有值,检查它们是否正确*/
  if (($PHP_AUTH_USER != "validname") || ($PHP_AUTH_PW != "goodpassword")) {
   /* 如果输入的用户名和口令中有一个不正确,则发送一个能够引发对话框出现的头部 */
   header(’WWW-Authenticate: Basic realm="My Private Stuff"’);
   header(’HTTP/1.0 401 Unauthorized’);
   echo ’Authorization Required.’;
   exit;
  } else if (($PHP_AUTH_USER == "validname") || ($PHP_AUTH_PW == "goodpassword")) {
   /* 如果二个值都正确,显示成功的信息 */
   echo "<P>You’re authorized!</p>";
  }
}
?>

需要注意的是,如果使用的是基于文件的保护机制,它并不能保证目录中所有的文件的安全。它可能保护大部分的文件,如果你认为它能够保护给定目录中的所有文件,你的这种认识就需要变变了。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值