• 1
  • 2
分享
  • 【原创】使用 Python 一键配置 SVN 账号和属组信息
  • sylan215 2018-09-27 19:25:52 字数 3783 阅读 2455 收藏 2

虽然现在 Git 已经很普及,但是我相信用 SVN 的公司仍然不少,那么作为 SVN 配置管理员的话,就不可避免的涉及到账号维护的问题,今天我们就说说如何通过 Python 脚本实现用户的快捷维护。

如果手动维护用户,一般需要三个步骤:
1.手动添加用户
2.手动设置属组
3.通知用户设置结果

使用脚本后也是三步,但是效率却大大提升:
1.输入用户名
2.输入要设置的组名
3.按下回车,搞定

这里面设置用户和属组是关键点,也是我们需要自动化起来的操作,下面分别给出实现的代码:

def add_user(user_name):
    """如果用户不存在则调用htpasswd.exe添加用户"""
    htpasswd_path = cur_file_dir() + '\\bin\\htpasswd.exe -b '
    pwd_path = REP_PATH + '\\htpasswd '
    user_list = readfiles(REP_PATH + '\\htpasswd')
    for line in user_list.split('\n'):
        if ':' in line and user_name.lower() == line.split(':')[0]:
            print('用户 ' + user_name + ' 已存在,不需要创建')
            return "见之前邮件通知"
    pwd = ' sylan215@' + str(random.randrange(1000, 9999, 1))
    print(execut_ret(htpasswd_path + pwd_path + user_name + pwd)[1])
    return pwd.strip()

这段是创建用户的代码,下面做下说明:

cur_file_dir() 函数功能是获取执行脚本所在路径;
htpasswd.exe 是从 Apache 目录拷贝出来的工具,可以在指定文件添加指定的用户名和密码信息,命令行使用方法「htpasswd.exe -b [密码文件] [用户名] [密码]」,更多使用说明请 Google;
REP_PATH 是我定义的一个全局变量,是我 SVN 仓库的根目录,目录下会存放用户和组设置的配置文件;
htpasswd 文件就是上面说的用户信息存储文件;
pwd 是我通过随机数生成的以 sylan215@ 开头的 13 位密码;
execut_ret() 函数功能是执行指定程序并返回执行结果的,目前就是执行 htpasswd.exe 添加指定用户信息;

接着我们来看看设置组信息的代码:

def add_group(user_name, user_grp):
    """添加用户到指定用户组"""
    grp_path = REP_PATH + "\\groups.conf"
    grp_context = readfiles(grp_path)
    new_context = ""
    isadd = False
    for line in grp_context.split('\n'):
        if '=' in line and user_grp.lower() == line.split('=')[0].lower():
            if user_name.lower() in line.lower():
                print("用户 " + user_name + " 已经属于 " + user_grp)
                return False
            if line.split('=')[1] != '':
                new_line = line + "," + user_name
            else:
                new_line = line + user_name
            new_context = grp_context.replace(line, new_line)
            isadd = True
            break
    if isadd:
        writetofile(grp_path, new_context)
        print("用户 " + user_name + " 成功添加到组 " + user_grp)
        return True
    else:
        print("组设置失败,请检查组名是否正确")
        return True

对这个函数的说明:

本函数功能就是读取组设置文件 groups.conf,检查当前用户是否存在于目标组里面,如果存在直接返回,否则添加用户到组里面;
readfiles() 函数功能是一次读出目标文件的所有内容;
writetofile() 函数功能是把指定内容写入指定文件;

下面是最后的统一调用函数,以及入口函数实现:

def useradd(user_name, user_grp):
    """"添加用户+添加属组+邮件通知"""
    ret_grp = False
    pwd = add_user(user_name)
    if ',' in user_grp:
        for each_group in user_grp.split(','):
            if add_group(user_name, each_group):
                ret_grp = True
    elif add_group(user_name, user_grp):
        ret_grp = True
    if ret_grp:
        sendcontextmail(user_name, pwd, user_grp)
if __name__ == "__main__":
    while True:
        user_name = input("请输入用户名(多个用户请用英文逗号分隔):")
        user_group = input("请输入要加入的属组(多个组请用英文逗号分隔):")
        for usr in user_name.split(','):
            useradd(usr, user_group)

说明:

sendcontextmail() 函数是公用的邮件通知函数;
统一处理函数可以处理一个用户添加多个用户组的情况;
入口函数可以处理多个用户同时添加的情况,并且做了无限循环,这样把窗口挂在服务器上可以随取随用了;
上述代码是基于 Python3.4 验证通过的,其他版本应该同理;
上述说明是基于 Windows 进行实现的;
上述实现是基于 SVN 自带的账号和组管理系统的;

如果是基于 Windows 的账号和组设置体系,代码上比这个简单:

def useradd(username, usergroup):
    """添加 windows 账号,并设置属组"""
    pwd = ' sylan215@' + str(random.randrange(1000, 9999, 1))
    retinfo = execut_ret('net.exe user ' + username + pwd + ' /add')
    if '命令成功完成' not in retinfo[0]:
        print('用户已创建失败:' + retinfo[1])
    print('用户创建成功:' + username)
    print('随机密码:' + pwd)
    for groupname in usergroup.split(','):
        retinfo = execut_ret('net.exe localgroup ' +
                             groupname + ' ' + username + ' /add')
        if '命令成功完成' not in retinfo[0]:
            print('设置用户属组失败:' + retinfo[1])
        print('用户已加入属组:' + groupname)

    sendcontextmail(username, pwd, usergroup)

好了,通过这么少的代码就可以瞬间搞定用户配置问题,维护起来是不是 so easy 了(如果有同学需要完整代码,请在公众号后台撩我哈)。

本文首发于公众号「sylan215」,十年测试老兵的原创干货,关注我,涨姿势!

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          •   性能测试框架搭建+接口测试+渗透测试+测试开发+测试面试指南,点击下方链接填写测试行业调查问卷,任选两个带回家。链接:http://vote.51testing.com/  Jenkins作为目前持续集成中使用较为广泛的工具,在实际生产过程中通过结合众多的插件,从而实现工程的持续构建、持续部署。  而传统构建的应用场景大多数运行在虚拟机或者独立的服务器上,在资源开销和管理维护较为复杂。相比于独立的服务器/虚拟机而言,容器不仅部署方便,且占用资源较少。  Docker作为目前作为业内最火的一个容器解决方案之一,通过将两者结合,从而实现服务的轻量化,并通过Docker管理Jenkins的资源。...
            1 1 1932
            分享
          • 1、接口测试:是测试系统组件间接口的一种测试。主要用于检测外部系统于系统之间以及系统内部各个子系统之间的交互点。重点测试的时数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等等,这要求对业务逻辑有一定程度上的理解,对数据流向有较好的定位。2、接口测试的分类:系统与系统之间的调用(如分享时,微信会提供接口给“跑向珠峰”);上层服务对下层服务的调用;服务之间的调用(如添加一条数据时,会先调用数据查询的服务,查询改数据是否是重复数据)。不同类型的接口测试方法可能不一致,但总体来说,不管是哪种类型,被测接口即为服务方,测试手段为客户方,接口测试的目的就是:通过我们的测试手段,去验证满足其声...
            0 0 1354
            分享
          • 测试同学在做安全测试时,相信多少都会遇到SQL注入与盲注的漏洞,那么今天我们就来分享下SQL注入与盲注的相关知识,希望对大家有所启发。一、SQL盲注的定义SQL注入,简单理解,也就是将用户输的的内容当代码执行了,应用程序没有对用户输入的内容进行判断和过滤,攻击者通过将构造的恶意SQL语句作为查询参数,使其在后台服务器上解析执行,最终导致数据库信息被篡改或泄露,这个过程就成为SQL注入。盲注,其实是SQL注入的一种, 攻击者在没有获得任何错误回显消息的情况下,通过使用一系列的布尔型或时间型查询,逐渐推断出数据库中的敏感信息。 简单理解下,盲注的表现就是,同一个接口,同一个参数,传不符合常规的值,...
            0 1 2933
            分享
          • 【全国】博为峰51Testing企业培训,打造精品内训课程!51企业内训服务   迅速提升企业测试团队综合能力51Testing资深讲师团队走进企业,根据业务及团队实际需求,量身打造专属个性化培训课程,“专药专治”有效提升测试团队战斗力。提升测试团队能力,为软件质量保驾护航。课程体系量身定制,内容多样化,补缺团队技术短板!测试基础类:软件工程、质量和测试基础;需求开发、管理和工程;ISTQB初级(测试工程师)& 高级(测试经理);测试技术(通用课程)测试设计类:软件测试需求分析与系统测试用例设计、ISTQB高级(测试分析师)、ISTQB高级(测试技术分析师)、单元、...
            0 0 1627
            分享
          • 一:需求分析了解熟悉业务,分析需求测试点确认功能(业务功能,辅助功能,数据约束,易用性需求,编辑约束,参数需求,权限需求,性能约束);场景分析(考虑场景调用者和系统内部各个场景之间联系);挖掘隐性需求(常用业务流程以及各分支)。二:测试计划编写目的此文档根据项目需求文档,制定测试策略、评估测试风险,确定所需的资源,并对测试的工作量进行估计,进行人员和进度安排,并且列出测试项目的可交付元素。参考文档详细设计文档,设计原型。测试概要(1)测试目标通过测试,达到以下目标:测试已实现的产品是否达到设计的要求,包括:各个功能点是否以实现,业务流程是否正确。产品规定的操作和系统运行稳定。Bug数和缺陷率控...
            12 14 3223
            分享
      • 51testing软件测试圈微信