79 基于 PHP 的用户认证
程序员文章站
2022-05-12 17:34:21
...
如果希望在每一段脚本上都进行口令保护,可以结合使用header()语句、$PHP_AUTH_USER
和$PHP_AUTH_PW来建立基本的认证方案,通常的基于服
务器的提问/响应顺序都如下所示:
1、用户从服务器上请求一个文件。如果这个文件在服
一个401(示经授权的用户)字符串。
2、浏览器收到这个响应后,弹出要求用户输入用户
名/口令的对话框。
钮将信息返回服务器供认证使用。
4、如果用户名和口令有效,被保护的文件将向用户开放,
只要用户还在使用文件,认证会一直有效。
起自动显示用户名/口令对话框的HTTP头部就可以模仿HTT
P的提问/响应系统,PHP把用户在用户名/口令对话框中输
入的信息存储在$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;
} elseif ((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;
} elseif (($PHP_AUTH_USER == "validname") || ($PHP_AUTH_PW == "goodpassword")) {
/* 如果二个值都正确,显示成功的信息 */echo"You're authorized!
";
}
}
?>
需要注意的是,如果你使用的是基于文件的保护机制,
它并不能保证目录中所有的文件的安全。它可能保护大
部分的文件,如果你认为它能够保护给定目录中的所有
文件,你的这种认识就需要变变了。
').addClass('pre-numbering').hide();
$(this).addClass('has-numbering').parent().append($numbering);
for (i = 1; i ').text(i));
};
$numbering.fadeIn(1700);
});
});
以上就介绍了79 基于 PHP 的用户认证,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
推荐阅读
-
用PHP抓取淘宝商品的用户晒单评论+图片实例,
-
linux环境下PHP怎么将用户上传的word文件转换成html文件
-
php 进阶:写一个用户在线显示的程序_PHP教程
-
基于php的CMS中展示文章类实例分析_PHP
-
memcache 用PHP写的基于Memcache的Queue实现代码
-
php 用curl模拟登陆后 如果多用户的话操作 如何保存他们登陆的cookies?不写文件的情况下
-
基于php iconv函数的使用详解
-
详细介绍php redis实现文章发布系统(用户投票系统)的实例
-
PHP基于cookie与session统计网站访问量并输出显示的方法
-
wiki: 基于php的dokuwiki