php使用Header函数,PHP_AUTH

5年以前  |  阅读数:764 次  |  编程语言:PHP 

本文实例讲述了php使用Header函数,PHP_AUTH_PW和PHP_AUTH_USER做用户验证的方法。分享给大家供大家参考,具体如下:

在php中,可以使用Header函数做一些有趣的事情,用户验证就是其中一个很有意思的功能。具体用法:


    Header("WWW-Authenticate: Basic realm="USER LOGIN"");
    Header("HTTP/1.0 401 Unauthorized");

在页首设计这两个Header函数,页面在载入前会出现一个登录框,要求输入用户名和密码。习惯了在页面登录的我们,是否觉得这样的登录很原始,又很新奇呢?

为了获取从这个对话框中传来的用户名和密码,需要用到php提供的两个特殊变量$PHP_AUTH_USER和$PHP_AUTH_PW,要这样使用这两个特殊变量好像需要在php.ini中设置相关的选项,不然就只能像下面这样引用:


    $_SERVER['PHP_AUTH_USER']
    $_SERVER['PHP_AUTH_PW']

获取到用户提交上来的用户名和密码之后,要怎样处理逻辑就跟我们一般的程序处理没有什么区别了。下面提供两个例程供参考:


    <?php
    if(!isset($PHP_AUTH_USER)) {
    Header("WWW-authenticate: basic realm="XXX"");
    Header("HTTP/1.0 401 Unauthorized");
    $title="Login Instructions";
    ?>
    <blockquote>
    In order to enter this section of the web site, you must be an XXX
    subscriber. If you are a subscriber and you are having trouble logging
    in,
    please contact <a href="mailto:support@xxx.com">support@xxx.com</a>.
    </blockquote>
    <?php
    exit;
    } else {
    mysql_pconnect("localhost","nobody","") or die("Unable to connect to SQL server");
    mysql_select_db("xxx") or die("Unable to select database");
    $user_id=strtolower($PHP_AUTH_USER);
    $password=$PHP_AUTH_PW;
    $query = mysql_query("select * from users where user_id='$user_id' and password='$password'");
    if(!mysql_num_rows($query)) {
    Header("WWW-authenticate: basic realm="XXX"");
    Header("HTTP/1.0 401 Unauthorized");
    $title="Login Instructions";
    ?>
    <blockquote>
    In order to enter this section of the web site, you must be an XXX
    subscriber. If you are a subscriber and you are having trouble
    logging in,
    please contact <a href="mailto:support@xxx.com">support@xxx.com</a>.
    </blockquote>
    <?php
    exit;
    }
    $name=mysql_result($query,0,"name");
    $email=mysql_result($query,0,"email");
    mysql_free_result($query);
    }
    ?>

另外一个参考的例程:


    <?php
    //assume user is not authenticated
    $auth = false;
    $user = $_SERVER['PHP_AUTH_USER'];
    $pass = $_SERVER['PHP_AUTH_PW'];
    if ( isset($user) && isset($pass) )
    {
    //connect to db
    include 'db_connect.php';
    //SQL query to find if this entered username/password is in the db
    $sql = "SELECT * FROM healthed_workshop_admin WHERE
    user = '$PHP_AUTH_USER' AND
    pass = '$PHP_AUTH_PW'";
    //put the SQL command and SQL instructions into variable
    $result = mysql_query($sql) or die('Unable to connect.');
    //get number or rows in command; if more than 0, row is found
    $num_matches = mysql_num_rows($result);
    if ($num_matches !=0)
    {
    //matching row found authenticates user
    $auth = true;
    }
    }
    if (!$auth)
    {
    header('WWW-Authenticate: Basic realm="Health Ed Presentation Admin"');
    header('HTTP/1.0 401 Unauthorized');
    echo 'You must enter a valid username & password.';
    exit;
    }
    else
    {
    echo 'Success!';
    }
    ?>

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《php操作office文档技巧总结(包括word,excel,access,ppt)》、《php日期与时间用法总结》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家PHP程序设计有所帮助。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例