由于在linux系统Apache+svn服务器,用户需要自定义密码怎么办呢?

1.创建脚本目录

mkdir -p /var/www/svn/svntools

2.创建apache配置文件

touch /etc/httpd/conf.d/alias.conf

3.输入以下内容:

Alias /svntools "/var/www/svn/svntools"  
    <Directory "/var/www/svn/svntools">  
            Require valid-user  
            AuthType Basic  
            AuthName "svn tools"  
            AuthUserFile "/var/www/svn/passwd"

</Directory>

4.创建修改密码的php脚本,当然不一定是php脚本,js脚本也可轻易做到等等

  1. <?php
  2. $username = $_SERVER["PHP_AUTH_USER"]; //获取当前用户名
  3. $authed_pass = $_SERVER["PHP_AUTH_PW"]; //获取当前用户密码
  4. $input_oldpass = (isset($_REQUEST["oldpass"]) ? $_REQUEST["oldpass"] : ""); //输入的原密码
  5. $newpass = (isset($_REQUEST["newpass"]) ? $_REQUEST["newpass"] : ""); //输入的新密码
  6. $repeatpass = (isset($_REQUEST["repeatpass"]) ? $_REQUEST["repeatpass"] : ""); //输入的重复密码
  7. $action = (isset($_REQUEST["action"]) ? $_REQUEST["action"] : ""); //以hide方式提交到服务器的action
  8. if($action!="modify"){
  9. $action = "view";
  10. }
  11. else if($authed_pass!=$input_oldpass){
  12. $action = "oldpasswrong";
  13. }
  14. else if(empty($newpass)){
  15. $action = "passempty";
  16. }
  17. else if($newpass!=$repeatpass){
  18. $action = "passnotsame";
  19. }
  20. else{
  21. $action = "modify";
  22. }
  23. ?>
  24. <html>
  25. <head>
  26. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  27. <title>SVN密码修改</title>
  28. </head>
  29. <body>
  30. <?php
  31. //action=view 显示普通的输入信息
  32. if ($action == "view"){
  33. ?>
  34. <style type="text/css">
  35. <!--
  36. table {
  37. border: 1px solid #CCCCCC;
  38. background-color: #f9f9f9;
  39. text-align: center;
  40. vertical-align: middle;
  41. font-size: 9pt;
  42. line-height: 15px;
  43. }
  44. th {
  45. font-weight: bold;
  46. line-height: 20px;
  47. border-top-width: 1px;
  48. border-right-width: 1px;
  49. border-bottom-width: 1px;
  50. border-left-width: 1px;
  51. border-bottom-style: solid;
  52. color: #333333;
  53. background-color: f6f6f6;
  54. }
  55. input{
  56. height: 18px;
  57. }
  58. .button {
  59. height: 20px;
  60. }
  61. -->
  62. </style>
  63. <br><br><br>
  64. <form method="post">
  65. <input type="hidden" name="action" value="modify"/>
  66. <table width="220" cellpadding="3" cellspacing="8" align="center">
  67. <tr>
  68. <th colspan=2>SVN密码修改</th>
  69. </tr>
  70. <tr>
  71. <td>用户名:</td>
  72. <td align="left"> <?=$username?></td>
  73. </tr>
  74. <tr>
  75. <td>原密码:</td>
  76. <td><input type=password size=12 name=oldpass></td>
  77. </tr>
  78. <tr>
  79. <td>用户密码:</td>
  80. <td><input type=password size=12 name=newpass></td>
  81. </tr>
  82. <tr>
  83. <td>确认密码:</td>
  84. <td><input type=password size=12 name=repeatpass></td>
  85. </tr>
  86. <tr>
  87. <td colspan=2>
  88. <input onclick="return loginIn(this.form)" class="button" type=submit value="修 改">
  89. <input name="reset" type=reset class="button" value="取 消">
  90. </td>
  91. </tr>
  92. </table>
  93. </form>
  94. <?
  95. }
  96. else if($action == "oldpasswrong"){
  97. $msg="原密码错误!";
  98. }
  99. else if($action == "passempty"){
  100. $msg="请输入新密码!";
  101. }
  102. else if($action == "passnotsame"){
  103. $msg="两次输入密码不一致,请重新输入!";
  104. }
  105. else{
  106. $passwdfile="/var/www/svn/project/conf/passwd";
  107. $command='"htpasswd" -b '.$passwdfile." ".$username." ".$newpass;
  108. system($command, $result);
  109. if($result==0){
  110. $msg="用户[".$username."]密码修改成功,请用新密码登陆.";
  111. }
  112. else{
  113. $msg="用户[".$username."]密码修改失败,请和管理员联系!";
  114. }
  115. }
  116. if (isset($msg)){
  117. ?>
  118. <script language="javaScript">
  119. <!--
  120. alert("<?=$msg?>");
  121. window.location.href="<?=$_SERVER["PHP_SELF"]?>"
  122. //-->
  123. </script>
  124. <?
  125. }
  126. ?>
  127. </body>
  128. </html>

可能出现问题

(1).php文件放置位置 ? /var/www/svn/svntools/svnpass.php

(2).访问路径?http://ip:port/svntools/svnpass.php

(3).apache端口冲突?修改/etc/httpd/conf/httpd.conf中的端口号

(4).php文件乱码问题?查看php文件格式是否为utf8

(5).修改passwd权限问题? chown root:root passwd chmod 777 * -R  chmod -R passwd 777 chmod 777 passwd -R

(6).
如查看apache日志中有如下错误[Wed Jun 13 09:34:34.462360 2018] [core:notice] [pid
22132] AH00094: Command line: '/usr/sbin/httpd -D FOREGROUND'
sudo: unable to open audit system: Permission denied
sudo: pam_open_session: System error
sudo: policy plugin failed session initialization

sudo: unable to open audit system: Permission denied?

解决方法1:setenforce 0 :用于关闭selinux防火墙,但重启后失效。

[root@localhost ~]# setenforce 0

[root@localhost ~]# /usr/sbin/sestatus 1、关闭firewall防火墙,保证apache能够访问正常。2、没有关闭selinux,时出现了如上错误。
解决方法2: 永久关闭修改selinux的配置文件,重启后生效。
打开 selinux 配置文件
[root@localhost ~]# vim /etc/selinux/config
修改 selinux 配置文件
将SELINUX=enforcing改为SELINUX=disabled,保存后退出
# This file controls the state of SELinux on the system.
# SELINUX= can take one of these three values:
#     enforcing - SELinux security policy is enforced.
#     permissive - SELinux prints warnings instead of enforcing.
#     disabled - No SELinux policy is loaded.
SELINUX=enforcing
# SELINUXTYPE= can take one of three two values:
#     targeted - Targeted processes are protected,
#     minimum - Modification of targeted policy. Only selected processes are protected.
#     mls - Multi Level Security protection.
SELINUXTYPE=targeted
此时获取当前selinux防火墙的安全策略仍为Enforcing,配置文件并未生效。
[root@localhost ~]# getenforce
Enforcing
重启
[root@localhost ~]# reboot
验证
[root@localhost ~]# /usr/sbin/sestatus
SELinux status:                 disabled
[root@localhost ~]# getenforce

Disabled

(7)如果出现用户权限不足?
首先 查看你的apache用户或者nginx php-fpm用户
可以使用 ps -ef  | grep httpd 命令来查看  其他同理
经查我的apache用户为apache用户
然后 visudo   或者 vim /etc/sudoers 找到
## Allow root to run any commands anywhere
root    ALL=(ALL)       ALL这一行 在下边追加

    1. apache ALL=(root)  NOPASSWD:ALL

用户svn密码自定义的更多相关文章

  1. win10怎么修改svn的用户和密码

    win10怎么修改svn的用户和密码(一般为默认),其他的系统也差不多 方法/步骤 1.方法一: 1.双击我的电脑在c盘找到auth文件夹 C:\Users\系统帐户名\AppData\Roaming ...

  2. 添加linux中svn的用户和密码

    1:首先找到svn路径 find / -iname "svn" 一般找到svn路径之后就可以找到配置文件位置啦 svn/svnrepos/jgcp/conf 2:进入目录之后修改a ...

  3. 配置svn用户及密码

    配置账户及密码   格式: user=passwd 配置新的账户 [root@mysql conf]# vim passwd 创建两个账户 [root@mysql conf]# egrep -v &q ...

  4. 系统开发中使用拦截器校验是否登录并使用MD5对用户登录密码进行加密

    项目名称:客户管理系统 项目描述: 项目基于javaEE平台,B/S模式开发.使用Struts2.Hibernate/Spring进行项目框架搭建.使用Struts中的Action 控制器进行用户访问 ...

  5. 忘记SVN密码怎么办

    1:下载TSvnPwd.exe 2:使用wireshark抓包.例如: PROPFIND /svn/dev2/!svn/vcc/default HTTP/1.1Host: 192.168.156.1: ...

  6. 如何删除eclipse中已经保存的svn密码

    一.打开eclipse--->点击Window--->点击Perference,打开eclipse配置,输入svn,然后点击svn,找到下方svn接口,查看下svn是什么类型的接口,如果是 ...

  7. django用户认证系统——自定义认证后台8

    Django auth 应用默认支持用户名(username)进行登录.但是在实践中,网站可能还需要邮箱.手机号.身份证号等进行登录,这就需要我们自己写一个认证后台,用于验证用户输入的用户信息是否正确 ...

  8. svn密码 在服务端 到底是明文保存,还是密文保存

    svn密码 在服务端 到底是明文保存,还是密文保存 之前在ubuntu上搭建svn服务端,记得密码就是明文保存的, 但最近项目,我们老大说,他搭建的是加密后的,我就比较纳闷了, 经过偷偷的瞄一下,不就 ...

  9. Django项目:CRM(客户关系管理系统)--45--37PerfectCRM实现King_admin添加用户时密码加密

    #views # ————————02PerfectCRM创建ADMIN页面———————— from django.shortcuts import render # ————————04Perfe ...

随机推荐

  1. @noi.ac - 492@ casino

    目录 @description@ @solution@ @solution@ @part - 1@ @part - 2@ @part - 3@ @accepted code@ @details@ @d ...

  2. Wunder Fund Round 2016 (Div. 1 + Div. 2 combined)

    现在水平真的不够.只能够做做水题 A. Slime Combining 题意:就是给n个1给你.两个相同的数可以合并成一个数,比如说有两个相同的v,合并后的值就是v+1 思路:直接模拟栈 #inclu ...

  3. mac 安装 adb

    安装命令 brew cask install android-platform-tools 测试安装情况 adb devices 设备打开开发者模式 略 查看log并过滤出设备id adb logca ...

  4. 5-1rquests模拟登陆知乎之httpcode

    1,状态码: 400错误:请求无效 (Bad request);出现这个请求无效报错说明请求没有进入到后台服务里 2,requests库:python常用的库,有空仔细阅读一下官方文档

  5. 报错:org.springframework.beans.factory.BeanCreationException

    报错码为以下内容,把自己走的坑贴出来,免得大家如同样的坑.以下解决方法仅供参考. ERROR [RMI TCP Connection(3)-127.0.0.1] - Context initializ ...

  6. SVN提示update更新成功,但是本地文件却没有更新

    问题描述:将仓库的最新版本代码check out到本地后,然后最某个文件做了修改,保存后想通过svn的update来重新得到最新的版本,发现失效. 原因:经过多方查找原因,主要看了以下两篇文档 htt ...

  7. 配置DNS代理

  8. H3C 因特网域名结构树

  9. ES6,ES7重点介绍

    1. 字符串模板 <!--旧版拼接字符串--> var str = '我是时间:'+new Date(); <!--新版拼接字符串--> let str = `我是时间${ne ...

  10. 【codeforces 749A】Bachgold Problem

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...