免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5886 | 回复: 19
打印 上一主题 下一主题

svn用户使用mysql验证 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-10-15 15:01 |只看该作者 |倒序浏览
30可用积分
请问svn用户能用mysql数据库验证吗?

[ 本帖最后由 timdcn 于 2009-10-19 16:45 编辑 ]

最佳答案

查看完整内容

http://snakeskin.javaeye.com/blog/147324SVN的安装和配置技术准备 检查软件包your_package是否安装 #rpm -qa | grep your_package 安装your_package软件包 #rpm -ivh your_package 或者 #rpm -Uvh your_package步骤1、检查并安装SVN以及相关软件包 请确认下面软件包有没有安装,如果没有安装,请到rhel5/centos5光盘找到这些软件包并安装 openssl-0.9.8b-8.3.el5 openssl-devel-0.9.8b-8.3.el5 mod_ssl-2.2.3-6.el5 mod_auth_my ...

论坛徽章:
5
寅虎
日期:2015-01-20 09:16:52亥猪
日期:2015-01-21 14:43:44IT运维版块每日发帖之星
日期:2015-12-17 06:20:00每日论坛发贴之星
日期:2015-12-17 06:20:00每周论坛发贴之星
日期:2015-12-20 22:22:00
2 [报告]
发表于 2009-10-15 15:01 |只看该作者
http://snakeskin.javaeye.com/blog/147324

SVN的安装和配置
技术准备
检查软件包your_package是否安装
#rpm -qa | grep your_package
安装your_package软件包
#rpm -ivh your_package
或者
#rpm -Uvh your_package
步骤1、检查并安装SVN以及相关软件包
请确认下面软件包有没有安装,如果没有安装,请到rhel5/centos5光盘找到这些软件包并安装
openssl-0.9.8b-8.3.el5
openssl-devel-0.9.8b-8.3.el5
mod_ssl-2.2.3-6.el5
mod_auth_mysql-3.0.0-3.1
mysql-server-5.0.22-2.1
mysql-5.0.22-2.1
mysql-devel-5.0.22-2.1
subversion-1.4.2-2.el5
mod_dav_svn-1.4.2-2.el5
如果安装正常的话,应该在/etc/httpd/modules目录下能找到这些模块
mod_authz_svn.so
mod_dav_svn.so
mod_auth_mysql.so
步骤2、初始化repository
创建svn的项目库父路径,我把/svn/repos做为svn的项目库父路径。这个目录是任意的,如果是多个项目库则必须在同一个父路径下
#mkdir /svn/repos
我们通过如下命令初始化一个svn项目库TelecomRepositorys
#svnadmin create /svn/repos/TelecomRepositorys
重复上面的命令创建多个项目库,如
#svnadmin create /svn/repos/OtherRepositorys
或者你指定SVN库的存储方式
#svnadmin create --fs-type fsfs /svn/repos/TelecomRepositorys
或者
#svnadmin create --fs-type bdb /svn/repos/TelecomRepositorys
默认是bdb(Berkeley DB)的存储方式,不过一般人更喜欢fsfs的存储库方式
步骤3、创建登陆用户文件[如果用数据库认证的话,此步可忽略]
在/svn目录下创建登陆用户文件.htpasswd以及2个用户test1,test2
#htpasswd -c /svn/.htpasswd test1
#htpasswd /svn/.htpasswd test2
步骤4:创建认证数据库[如果用登陆用户文件认证的话,此步可忽略]
登陆mysql
#mysql -u root -p
创建数据库svn_auth
mysql>create database svn_auth;
mysql>user svn_auth;
创建用户svn
mysql>GRANT ALL PRIVILEGES ON *.* TO svn@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;
创建表users
mysql> CREATE TABLE users (
->   user_name CHAR(30) NOT NULL,
->   user_passwd CHAR(20) NOT NULL,
->   PRIMARY KEY (user_name)
-> );
添加2个测试帐号
mysql> insert into users values('test1', ENCRYPT('password'));
mysql> insert into user values('test2', ENCRYPT('password'));
mysql>commit;

步骤5、SVN访问控制
在/svn目录下创建访问控制文件文件svnaccess,名字任意,不过在以后的配置过程中你必须使用正确的名字,文件内容为
[groups]   
# harryharry_and_sally = harry,sally     
[/]   
*=rw  
我们可以看到最后2行才是有效的,意思是对所有的项目,所有人都有读写(rw)的权限,当然我们还可以对某个项目单独进行限制,设置如下
[groups]   
# harryharry_and_sally = harry,sally     
  
[TelecomRepositorys:/]   
test1=r  
*=rw  
意思是对于项目库TelecomRepositorys,用户test1只有读权限,其他人有读写权限
步骤6、Apache和SVN集成
编辑apache的配置文件/etc/httpd/conf/httpd.conf文件或者/etc/httpd/conf.d/subversion.conf文件
如果你使用登陆文件认证的方式(步骤3),添加如下内容
<Location /svn>  
DAV svn                           
SVNParentPath /svn/repos                           
AuthzSVNAccessFile /svn/svnaccess                           
AuthType Basic                           
AuthName "SVN Repositorys"                           
AuthUserFile /svn/.htpasswd                           
Require valid-user      
</Location>  
如果你使用数据库认证的方式(步骤4),添加如下内容
<Location /svn>                     
DAV svn                       
SVNParentPath /svn/repos                       
AuthzSVNAccessFile /svn/svnaccess                       
AuthName "SVN Repositorys"                       
AuthType Basic                       
AuthMYSQLEnable on                       
AuthMYSQLUser svn                       
AuthMySQLPassword password                       
AuthMYSQLDB svn_auth                       
AuthMYSQLUserTable users                       
AuthMYSQLNameField user_name                       
AuthMYSQLPasswordField user_passwd                       
Require valid-user               
</Location>   
我们可以看到/svn/svnaccess,/svn/.htpasswd是我们创建的文件,如果名字自定义的话,请在http.conf配置正确,同样需要正确配置的还有数据库用户svn,数据库svn_auth,表名users等等。

步骤7、安全访问设置[必须设置,否则svn无法访问]
修改目录的属主和访问权限
#chown apache.apache -R /svn
#chmod 755 -R /svn
修改SELinux的设置
禁用SELinux(强烈不推荐)或者在SELinux图形管理界面中勾上Disable SELinux protection for httpd daemon这个选项,否则apache这个虚拟用户无法访问/svn目录,当然你也可以用更好的方法设置apache的访问权限.
步骤8、重新启动Apache服务器
执行如下命令
#service httpd restart
  或者
#/etc/init.d/httpd restart
键入下面的url看是否能正确的访问svn。
http://localhost/svn/TelecomRepositorys

论坛徽章:
0
3 [报告]
发表于 2009-10-15 15:02 |只看该作者
cu的高手哪去了,怎么我的问题都没人回答啊??

论坛徽章:
0
4 [报告]
发表于 2009-10-19 09:04 |只看该作者
学学

论坛徽章:
0
5 [报告]
发表于 2009-10-19 14:46 |只看该作者
3楼你好。我现在的问题是用你这个方法是可以验证的。但是我用bugzilla的数据表,里面的密码加密方式是SHA-256,这个加密方式mod_auth_mysql好像不支持,请问有办法解决吗

论坛徽章:
5
寅虎
日期:2015-01-20 09:16:52亥猪
日期:2015-01-21 14:43:44IT运维版块每日发帖之星
日期:2015-12-17 06:20:00每日论坛发贴之星
日期:2015-12-17 06:20:00每周论坛发贴之星
日期:2015-12-20 22:22:00
6 [报告]
发表于 2009-10-19 14:48 |只看该作者

回复 #5 timdcn 的帖子

这个我不是很清楚啊,我这里的svn用的不是数据库的用户,所以没有怎么弄过这个

论坛徽章:
0
7 [报告]
发表于 2009-10-19 14:51 |只看该作者

回复 #6 gamester88 的帖子

能帮忙看下嘛,这个问题我网上找了好久,都没找到解决方案呢

论坛徽章:
5
寅虎
日期:2015-01-20 09:16:52亥猪
日期:2015-01-21 14:43:44IT运维版块每日发帖之星
日期:2015-12-17 06:20:00每日论坛发贴之星
日期:2015-12-17 06:20:00每周论坛发贴之星
日期:2015-12-20 22:22:00
8 [报告]
发表于 2009-10-19 15:00 |只看该作者

回复 #7 timdcn 的帖子

看看这个可以帮你不

http://www.svn8.com/svnpz/20090624/6765.html

论坛徽章:
0
9 [报告]
发表于 2009-10-19 15:06 |只看该作者

回复 #8 gamester88 的帖子

这个我已经看过了,用bugzilla的用户表,是没法验证svn的。

论坛徽章:
5
寅虎
日期:2015-01-20 09:16:52亥猪
日期:2015-01-21 14:43:44IT运维版块每日发帖之星
日期:2015-12-17 06:20:00每日论坛发贴之星
日期:2015-12-17 06:20:00每周论坛发贴之星
日期:2015-12-20 22:22:00
10 [报告]
发表于 2009-10-19 15:28 |只看该作者

回复 #9 timdcn 的帖子

那我就不知道了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP