设为首页 收藏本站
查看: 653|回复: 0

[经验分享] 让基于apache httpd的subversion实现通过mysql进行认证

[复制链接]

尚未签到

发表于 2018-11-26 13:24:49 | 显示全部楼层 |阅读模式
关于“subversion + httpd + mysql”这个话题在网上的文章很多,貌似没有自己再写的必要,但通过研读多篇中外相关的blog和网页后,我还是决定自己记录一下,确保下次再做时能有清晰准确的思路。

由于这篇文章的主要目的在于"通过mysql进行身份验证",所以关于subversion(svn)架设在apache httpd上就不多说了,本文基于以下前提:
1.debian lenny 发行版
2.svn on apache httpd 已经配置好
3.mysql-server数据库服务器已经安装好
3.通过apt-get install libapache2-mod-auth-mysql安装mod_auth_mysql
  这东东版本很多文档也零碎(http://freelamp.com/58349 中有提到)
我也搜到好两个:
http://modauthmysql.sourceforge.net/
http://www.heuer.org/mod_auth_mysql/
debian是基于sf那个修改的而来的,指令作了一些修改和扩充,网上很多资料都是"编译生成mod_auth_mysql.so ... ...",基本上用的是sf.net上那个3.0版了,虽然大同小异,但并不完全适用本文。


先说说原理:
*由httpd判断是否需要对location进行认证(require指令)
*然后通过配置文件中指定的认证模块完成这个认证过程,在这里,认证的模块是auth_mysql。
*auth_mysql模块通过访问指定的表及字段,检查用户提交的用户名及密码是否匹配用户表.
*如果有需要,auth_mysql模块还会验证组(group)
*接下来通过dav_svn模块检查AuthzSVNAccessFile文件进行存取控制。


步骤如下:
一、建单独的认证数据库
二、建httpd使用的数据库用户
三、建表
四、确认已经安装apache的mysql认证模块
五、修改httpd配置文件


一、认证数据库
这一步很简单,起个好名字就行.
mysql>CREATE DATABASE authz_db;



二、建数据库用户
mysql>mysql> GRANT SELECT,INSERT,UPDATE,DELETE ON authz_db.* TO 'mysqlauthuser'@'localhost' IDENTIFIED BY 'some_pass';



三、创建表
create table users
(
   uid                  int unsigned not null auto_increment,
   login                varchar(20) not null,
   password             varchar(50) not null,
   user_name            varchar(50) character set utf8 not null,
   enabled              bool not null default true,
   primary key (uid),
   unique key uidx_users_login (login)
)
type = MYISAM;



四、确认安装apache的mysql认证模块apt-get install libapache2-mod-auth-mysql
a2enmod auth_mysql



五、修改httpd配置文件
我把相关的apache配置指令在标签内,全局认证就没必要,下面我就是以虚拟主机中局部认证为例了

        ServerAdmin webmaster@localhost
        ServerName hostname
        DocumentRoot /var/www-sites/root-path
        
                DAV svn
                SVNParentPath /svn-repos/parent/path
                SVNListParentPath On
                SVNAutoversioning On
                SVNReposName "input as you like~~"
                AuthzSVNAccessFile /path/svn-repos.acl #备注1
                AuthBasicAuthoritative off  #备注2
                AuthMYSQL on
                AuthMySQL_Authoritative on
                AuthMySQL_Socket /path/to/mysqld.sock  #备注3
#                AuthMySQL_Host localhost
                AuthMySQL_User mysqlauthuser    #见第二步
                AuthMySQL_Password some_pass    #见第二步
                AuthMySQL_DB authz_db        #见第一步
                AuthMySQL_Password_Table users        #
                AuthMySQL_Username_Field login        #第三步创建表
                AuthMySQL_Password_Field password    #
                AuthMySQL_Empty_Passwords on
                AuthMySQL_Encryption_Types Crypt_MD5    #备注4
                AuthName "认证框提示内容~~"
                Require valid-user
                AuthType Basic
        



备注:
备注1:
AuthzSVNAccessFile 指向的是 authz 的策略文件,详细的权限控制可以在这个策略文件中指定。
如果这里暂时没用,就在前面+上#号注释掉

备注2
这东东折腾了好一会儿,直到在
http://www.pitr.net/index.php/2007/08/08/internal-error-pcfg_openfile-called-with-null-filename/
找到答案
While upgrading Apache to version 2.2.4-2 for a subversion upgrade (version 1.4.4dfsg1-1) I ran into errors with my auth_pgsql (or any other auth_mysql, auth_ldap or auth_* module) setup:

“Internal error: pcfg_openfile() called with NULL filename”

This is caused by auth_basic and stops the authentication and authorisation process. Adding the following directive to your auth_pgsql or auth_ldap config file solves the problem:

“AuthBasicAuthoritative Off”
It disables basic authorisation being authoritive for the authorisation process. The errors will still be visible in your logfiles, but the authorisation scheme works as normal.
大意貌似是auth_basic模块的问题。

备注3
本机上连接mysql可以不使用tcp,而是通过unix socket,性能更好一些。
在/etc/mysql/my.cnf中有定义,我本机上是/var/run/mysqld/mysqld.sock
如果不会弄这个,把AuthMySQL_Socket参数注释,改为用AuthMySQL_Host localhost也行

备注4
密码加密方式, 与php中的crypt()加密方法一致, 参看:
http://salomi.blog.51cto.com/389282/160326




至此,全部配置完毕,重启apache httpd即可生效

增加用户:
insert into users
  (login, password, user_name, reg_date, enabled)
values
  ('mylogin','??????????????????', 'username', NOW(), 1);

????????????串用php的crypt()方法生成




参考资料:(除了上面提到的url之外)
http://www.arune.se/tech:svnwithmysqlauth
这里还提到了如何与dokuwiki集成帐号的方法

http://www.uml.org.cn/pzgl/200902136.asp
这里是svn的其它一些高级应用






运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-639889-1-1.html 上篇帖子: apache fileupload上传附件时出现的错误 下篇帖子: Apache Rewrite规则详解[转]
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表