Apache基于MySQL的身份验证

来源:互联网 发布:网络安全局 编辑:程序博客网 时间:2024/05/19 02:23

本文介绍在Apache中实现用户身份验证的方法,讨论如何在MySQL数据库中保存验证信息,然后通过mod_auth_mysql模块实现身份验证。

一、概述

   前文讨论了在身份验证中使用数据库的方法,具体介绍了mod_auth_db模块和DB文件的使用。这里要介绍的是如何使用非常流行的MySQL数据库保存身份验证信息,再通过mod_auth_mysql访问MySQL数据库实现身份验证。 

  1.1 关于MySQL 

   MySQL是一种优秀的数据库服务器,具有体积小速度快的特点。MySQL以GPL方式发行,它的主页在http://www.mysql.com/。MySQL缺少某些昂贵的大型数据库所提供的功能,比如存储过程、触发子等等,但它具备了大多数中小型工程所需要的基本功能。另外,它还有一些非常实用的特色,比如可用于SQL命令的正则表达式等。 

   由于MySQL是免费的,而且其表现又如此不俗,在UNIX家族的操作系统上它是很受欢迎的数据库——特别是对于那些预算有限的用户来说。另外请注意,MySQL也有在Windows上运行的版本。 

  1.2 关于mod_auth_mysql模块 

   我们可以使用mod_auth_mysql模块把用户名字和密码保存到MySQL数据库,然后直接使用它们进行身份验证。 

   使用这种方法除了能够提高数据访问速度之外,还有其他许多好处。例如,假设用户信息原来保存在数据库中,使用文本文件进行密码验证时必须把用户名字和密码再复制一份,这样你就得在两个地方维护同样的数据,如果这两份数据不是同步更新,用户就有可能不能登录。 

   反过来,如果使用的是mod_auth_mysql,我们就可以直接用数据库中的用户信息进行身份验证,此时用户信息只需一份就足够了,用户名字和密码可以用SQL命令更新,不会出现使用文本文件时可能遇到的问题。另外,要修改用户所属的组也很方便。 



二、安装和配置

   要获得mod_auth_mysql模块或者查看它的详细资料,请访问http://bourbon.netvision.net.il/mod_auth_mysql/。 

   mod_auth_mysql可以编译成DSO(Dynamic Shared Object,动态共享对象),然后只需通过配置指令即可将它安装到服务器上。关于DSO的更多说明,请参见Apache指南:新手安装必读。 

   配置mod_auth_mysql模块时,我们必须告诉它要用哪一个数据库来进行身份验证,以及哪一个表、什么字段包含了验证用的信息。下面是配置mod_auth_mysql时必须了解的配置指令:  

 Auth_MySQL_Info [host] [user] [password]


   这个指令声明数据库在哪一个服务器上运行以及访问这个数据库应该使用的用户名字和密码。只有当数据库不在localhost(即本地机器)上运行或者访问数据库的不是httpd用户时,我们才需要使用这个指令。 

   如果所有的身份验证操作都使用同一个数据库,那么你可以使用下面这个指令:  


 Auth_MySQL_General_DB [数据库名字]


   否则,如果对不同目录的身份验证操作使用不同的数据库,你可以忽略这个指令,然后在各个的目录中指定所用数据库。 

   下面介绍的几个指令既可用于httpd.conf配置文件,也可用于各个目录的.htaccess文件。请参见Using .htaccess Files with Apache了解更多信息。 

   注意在为目录设置密码保护时可以应用通常使用的指令,如下所示:  
  

      AuthType Basic 
  

      AuthName "Members Only" 
  

      require group admin


Auth_MySQL_DB [数据库名字]:声明使用哪一个数据库中的信息进行身份验证。 

Auth_MySQL_Password_Table [密码表的名字]:声明数据库中哪一个表包含密码信息。除非特别声明,否则默认包含用户名字的字段是“username”,包含密码的字段是“password”。但我们可以按照下面介绍的方法指定另外的字段。 

Auth_MySQL_Group_Table [保存组信息的表]:一般地,我们可以把用户所属组的信息(groups字段)和用户名字、密码保存到同一个表中。但是如果有必要把它保存到独立的表,这里可以指定该表的名字。 

Auth_MySQL_Username_Field [用户名字字段]:如果保存用户名字信息的字段不是“username”,可以用这个指令指定实际使用的字段名字。 

Auth_MySQL_Password_Field [密码字段]:如果保存密码的字段不是“password”,可以用这个指令指定实际使用的字段名字。 

Auth_MySQL_Group_Field [用户所属组的字段]:如果保存组信息的字段不是“groups”,可以用这个指令指定实际使用的字段名字。 

Auth_MySQL_Encrypted_Passwords on/off:告诉mod_auth_mysql模块保存在数据库中的密码是否经过加密。默认on,即假定数据库中保存的密码是经过加密的。 
   还有其他一些指令,不过经常要用到的就是上面这些。下面是.htaccess文件的一个例子:  
  

      Auth_MySQL_Info localhost db_user db_password 
  

      Auth_MySQL_DB   authentication 
 

      Auth_Mysql_Password_Table     passwords 
  

      AuthType Basic 
  

      AuthName "Members Only" 
  

      require valid-user 

 

   上例假定保存用户名字的字段是username,密码经过加密再保存到password字段。

三、其他
   只要按照上面介绍的方法设置好了.htaccess文件,访问该目录下面的页面时就会出现密码输入窗口。对于用户来说,不同的密码保护实现方法并没有什么差别。 

   你可以使用任何自己熟悉的数据库管理工具管理用户信息,目前似乎还没有象dbmmanage一样从命令行管理数据库里用户信息的简单工具。 

   但我们可以通过Perl和DBI操作数据库。下一篇文章要讨论的就是用Perl管理密码文件的诸多优点。用Perl管理密码的方法实在很多,所以让它单独成文应该是比较合适的。 

   结束语:使用mod_auth_mysql,我们可以把用户名字、密码和所属组信息保存到MySQL数据库。MySQL是一种小型、快速、免费的数据库服务器,大多数流行的操作系统上都有MySQL的相应版本。

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 虎牙直播不兼容语音怎么办 为什么手机打开游戏就死机怎么办 2007cad打开时时死机怎么办 手机qq总是无响应怎么办 英雄联盟登录服务器未响应怎么办 苹果7p照相死机怎么办 小米手机qq打不开怎么办啊 电脑qq老是闪退怎么办 微信摄像卡住了怎么办 电脑打开应用程序没反应怎么办 宇飞来手机锁了怎么办 宇飞来手机忘记密码怎么办 vivo手机突然开不了机怎么办 苹果六关不了机怎么办 微信老是无响应怎么办 打游戏被骂了怎么办 微信运动跳转排行榜失败怎么办 小恩爱账号忘了怎么办 华为账号更换后游戏账号怎么办 注册游戏账号需要身份证怎么办 英雄联盟被裁决了怎么办 百度网盘密码重置不了怎么办 sap密码输入被锁怎么办 dnf二级密码错10怎么办 大网卡网速慢了怎么办 小米路由器无线速度慢怎么办 小米手机无线速度慢怎么办 电脑网卡驱动没了怎么办 电脑显示网卡驱动不正常怎么办 微信别人拒收消息怎么办 电脑无线网卡速度慢怎么办 网吧吃鸡更新慢怎么办 手机号注册不了微信怎么办 小米账号密码忘了怎么办 小米手机账号密码忘了怎么办 华为手机账号密码忘记了怎么办 老年机开不了机怎么办 天谕没有顺网登陆怎么办 苹果密保问题忘了怎么办 密保手机没用了怎么办 qq密保手机没用了怎么办