svn的web管理后台服务svnWebUI

背景

用户需要使用web管理页面管理svn,根据网上的资料了解到国产开源的管理后台有两个,一个是svnadmin,另一个是svnwebui。对比功能和部署方式的不同,最后选择svnwebui,原因是部署方便,只需要部署jar包和java环境即可,无需其它服务,而svnadmin需要部署php、数据库服务,所以我选择最方便的工具先试用。

系统环境

麒麟v10,X64
JDK 17
Svn 1.45.5

服务部署

项目地址:https://gitee.com/cym1102/svnWebUI/#svnwebui,当前版本1.9.0,项目地址里面有更详细的说明。

下载软件

wget -O svnWebUI.jar https://gitee.com/cym1102/svnWebUI/releases/download/1.9.0/svnWebUI-1.9.0.jar 

启动服务后自动重启svn服务,这个比较坑,需要做一些适配,在适配完成之前项目暂时不可用,这比较坑,官方文档也没有这个说明,所以启动服务前必须提前备份。生产环境部署该服务要提前发个通知。
1.因为项目的仓库地址默认为/home/svnWebUI,如果不指定路径,那么启动服务器后svn也会重启并指定路径为/home/svnWebUI/repo,这时候原有仓库就不可用了,后期需要复制原有仓库到priject.home指定path的repo这层目录里,比如我这里priject.home指定的是/home/svn,那么svn的仓库根路径就变成/home/svn/repo。
2.项目启动后原有项目的svnserver.conf的内容会重新生成,指定的passwd和authz两个文件的路径会变成…/…/passwd和…/…/authz,这时候用户将无权限访问仓库,需要在后台导入用户并按照原有策略赋权后用户才能正常访问仓库。

启动:
server.port:指定服务端口,后期用这个端口访问后台
priject.home:仓库目录

nohup java -jar -Dfile.encoding=UTF-8 svnWebUI.jar --server.port=6060 --priject.home=/home/svn >/dev/null &

启动后做一下适配,将原有仓库的目录负责到/home/svn/repo目录,之后就可以登录后台使用服务了

使用方法

  1. 登录
    地址:http://IP:6060
    账密:第一次登录需要设置管理员账号密码
  2. 系统配置
    都是默认的,svn只要正常会自动识别,状态是已启动就对了
  3. 添加仓库
    进入仓库管理
    添加仓库:新建仓库使用这个功能,支持中英文名称
    导入库:将原有仓库目录复制到/home/svn/repo,确定即可看到仓库
  4. 添加用户
    进入用户管理
    添加用户:新建用户使用这个功能,密码不能含有特殊字符
    导入用户:使用原有仓库的passwd导入
  5. 添加组
    进入小组管理
    添加小组:新建小区使用这个功能,支持中英文名称
    导入小组:导入原有仓库authz文件,但是我测试了没有生效,原因不详
  6. 赋权
    进入仓库管理
    全体授权:
    禁用:所有用户无访问该仓库的权限,需要访问仓库使用用户授权或小组授权
    只读:所有用户对该仓库有只读权限,这个优先级高于用户授权和小组授权,所以这里给只读后所有用户都会有只读权限
    读写:所有用户对该仓库有读写权限,这个优先级高于用户授权和小组授权,所以这里给只读后所有用户都会有读写权限
  7. 用户授权
    前置条件:先要对当前管理员账号添加所有权限,否则在授权时无法选择路径,只能选择根目录
    添加用户:勾选需要授权的用户,可选多个,然后选择路径,对不同的路径分配对应权限。权限分只读、读写、禁止。如果不需要细分权限,选择根目录即可。
    注意:如果全体授权里已分配权限,那么其优先级将高于用户权限,比如全部授权里面赋予了读写权限,用户授权里即使对某用户设置禁用也是无效的,该用户依然可以访问仓库。
  8. 小组授权
    前置条件:先要对当前管理员账号添加所有权限,否则在授权时无法选择路径,只能选择根目录
    添加小组:勾选需要授权的小组,可选多个,然后选择路径,对不同的路径分配对应权限。权限分只读、读写、禁止。如果不需要细分权限,选择根目录即可。
    注意:如果全体授权里已分配权限,那么其优先级将高于小组权限,比如全部授权里面赋予了读写权限,小组授权里即使对某小组设置禁用也是无效的,该小区内的用户依然可以访问仓库。

基础的功能先写道这里,后续会继续使用系统并完善文档。

写在最后

本系统应该是个人开发者做的,虽然目前有些功能还有缺失,比如批量授权等,但是核心功能经过测试已经很好的满足管理需要了,各位用户对系统有建议和意见可以发邮件给作者,强烈建议出一点点费用鼓励作者继续完善系统,在这里感谢作者的付出,祝svnWebUI越来越强大。

Read more

基于深度学习的纺织品缺陷检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Django+web+训练代码+数据集)

基于深度学习的纺织品缺陷检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Django+web+训练代码+数据集)

视频演示 基于深度学习的纺织品缺陷检测系统 目录 视频演示 1. 前言 2. 项目演示 2.1 用户登录界面 2.2 主界面布局 2.3 个人信息管理 2.4 多模态检测展示 2.5 检测结果保存 2.6 多模型切换 2.7 识别历史浏览 2.8 管理员管理用户信息 2.9 管理员管理识别历史 3.模型训练核心代码 4. 技术栈 5. YOLO模型对比与识别效果解析 5.1 YOLOv5/YOLOv8/YOLOv11/YOLOv12模型对比 5.2 数据集分析

PyWebIO表单进阶之路:从入门到上线只需这6个关键步骤

第一章:PyWebIO 表单快速构建 PyWebIO 是一个轻量级 Python 库,允许开发者无需前端知识即可通过纯 Python 代码构建交互式 Web 界面。特别适用于快速搭建数据采集表单、参数配置页面或简易管理后台,极大提升原型开发效率。 基础表单元素使用 PyWebIO 提供了多种内置函数来创建表单控件,如文本输入、下拉选择、复选框等。所有输入均可通过 input() 系列函数直接获取值。 # 示例:创建包含姓名、年龄和兴趣的表单 from pywebio.input import input, select, checkbox from pywebio.output import put_text name = input("请输入您的姓名:") age = input("请输入您的年龄:"

Web CNC控制工具零基础配置指南:从安装到多场景应用

Web CNC控制工具零基础配置指南:从安装到多场景应用 【免费下载链接】cncjsA web-based interface for CNC milling controller running Grbl, Marlin, Smoothieware, or TinyG. 项目地址: https://gitcode.com/gh_mirrors/cn/cncjs CNCjs作为一款开源CNC控制器,提供了强大的Web界面操控能力,支持Grbl、Marlin等多种控制系统,帮助用户轻松实现CNC设备的远程管理与精准控制。本文将从核心功能解析、场景化部署到进阶应用拓展,全方位带您掌握这款轻量化Web CNC解决方案。 一、核心功能解析:重新认识CNCjs的强大之处 1.1 多控制器兼容系统:如何解决不同CNC设备的适配难题? CNCjs实现了与主流数控系统的深度整合,包括Grbl、Marlin、Smoothieware和TinyG控制器。这种兼容性架构允许用户在同一界面下管理不同品牌的CNC设备,无需为每种控制器单独配置软件环境。 1.2 3D工具路径可视化:

ASP.NET Core 10中的Blazor WebAssembly性能优化实践

ASP.NET Core 10中的Blazor WebAssembly性能优化实践 前言 Blazor WebAssembly作为一种将.NET应用带到浏览器端的技术,在近年来得到了广泛的关注和应用。然而,随着应用规模的增大,性能问题逐渐凸显。在ASP.NET Core 10中,有一些新的特性和方法可以帮助我们更好地优化Blazor WebAssembly应用的性能。 原理 Blazor WebAssembly应用的性能瓶颈主要在于下载大小、初始加载时间以及运行时的性能。在ASP.NET Core 10中,通过以下原理来优化性能: 1. 代码压缩与打包优化:采用更高效的压缩算法,减小应用程序的下载体积。 2. 懒加载:对于一些不常用的组件或功能,采用懒加载的方式,只在需要时才加载相关代码。 3. 运行时优化:改进了JIT编译在浏览器端的性能,提高代码执行效率。 实战 1. 首先创建一个简单的Blazor WebAssembly项目: // 创建Blazor WebAssembly项目 dotnet new blazorwasm