python-django-mongodb-组织树递归查询

对组织树进行递归查询.


提供当前组织树节点的上级组织id. 我这里简称 p_id.

def get(request, *args, **kwargs):
    if request.method == 'GET':
        need_set = {
            "p_id",
        }
        parser_dict = {}
        for item in need_set:
            item_res = request.GET.get(item, None)
            if not item_res:
                return JsonResponse({'code': 1})
            else:
                parser_dict.update({item: item_res})
        if len(parser_dict):
            res_all = (parser_role_tree.find_role_all({"org_id": {'$exists': True}}))  # 获取当前的全部的 组织树信息
            recursion_list = get_list(res_all=res_all, p_id=parser_dict['p_id'])  # 递归查询当前的 下级信息
            for item in res_all:
                if item['org_id'] == parser_dict['p_id']:  # 上级组织
                    item.update({'sons': recursion_list})
                    return JsonResponse({"data":item}, safe=False)
            return JsonResponse({"msg":1}, safe=False)



def get_list(res_all, p_id):  # 只需要传进来全部数据 和你需要判断的组织id 或者 上级id
    list_a = []
    for item in res_all:  # 遍历全部组织树信息
        if item['p_id'] == p_id:  # 判断 组织id是否等于传经的 p_id 或者 org_id
            list_a.append(item)  # 符合添加
            item.update({'sons': get_list(res_all=res_all, p_id=item['org_id'])})
    return list_a

提供当前组织树节点的本级组织id. 我这里简称 org_id.


def get(request, *args, **kwargs):
    if request.method == 'GET':
        need_set = {
            "org_id",
        }
        parser_dict = {}
        for item in need_set:
            item_res = request.GET.get(item, None)
            if not item_res:
                return JsonResponse({'code': 1})
            else:
                parser_dict.update({item: item_res})
        if len(parser_dict):
            res_all = (parser_role_tree.find_role_all({"org_id": {'$exists': True}}))  # 获取当前的全部的 组织树信息
            recursion_list = get_list(res_all=res_all, p_id=parser_dict['org_id'])  # 递归查询当前的 下级信息
            for item in res_all:
                if item['org_id'] == parser_dict['org_id']:  # 本级组织
                    item.update({'sons': recursion_list})
                    return JsonResponse({'data': item}, safe=False)
            return JsonResponse({'msg': '查询失败'}, safe=False)


def get_list(res_all, p_id):  # 只需要传进来全部数据 和你需要判断的组织id 或者 上级id
    list_a = []
    for item in res_all:  # 遍历全部组织树信息
        if item['p_id'] == p_id:  # 判断 组织id是否等于传经的 p_id 或者 org_id
            list_a.append(item)  # 符合添加
            item.update({'sons': get_list(res_all=res_all, p_id=item['org_id'])})
    return list_a

结果展示


{
    "data": {
        "_id": "8796e0d2a75ee0d84c1fbcb5ac4e7cc5",
        "org_id": "1649237314",
        "org_name": "1",
        "p_id": "99999",
        "create_time": 1649237314,
        "update_time": 1649237314,
        "sons": [
            {
                "_id": "bbd7664aa4b1d7fbfaa0256b05a78fd1",
                "org_name": "6",
                "p_id": "1649237314",
                "org_id": "a34b95fa8d2b491b1cd91b122ab7a92b",
                "create_time": 1649237591,
                "update_time": 1649237591,
                "sons": [
                    {
                        "_id": "e0771f7fde8ef8fdffac57ea8ba01958",
                        "org_name": "6",
                        "p_id": "a34b95fa8d2b491b1cd91b122ab7a92b",
                        "org_id": "f4d194ba8b772aebdeab2732daa72011",
                        "create_time": 1649238526,
                        "update_time": 1649238526,
                        "sons": [
                        ]
                    },
                    {
                        "_id": "fa69c4a650b9454a22ab13c781ede848",
                        "org_name": "7",
                        "p_id": "a34b95fa8d2b491b1cd91b122ab7a92b",
                        "org_id": "ca93ed9207956708a4dad3e8f1ac3b52",
                        "create_time": 1649238531,
                        "update_time": 1649238531,
                        "sons": [
                            {
                                "_id": "912872c3548a75c505de3dfd60288902",
                                "org_name": "7",
                                "p_id": "ca93ed9207956708a4dad3e8f1ac3b52",
                                "org_id": "ac5b45ffe0a17239809282ef714d77f6",
                                "create_time": 1649239187,
                                "update_time": 1649239187,
                                "sons": [
                                ]
                            }
                        ]
                    }
                ]
            }
        ]
    }
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python-Django 是一个流行的 Web 开发框架,而多功能 Web 应用渗透测试系统则是指的一个系统能够对各种不同类型的 Web 应用进行渗透测试,同时还具备多种功能。 Python-Django 的优势在于其简单易用、灵活性高以及开发效率高。使用 Python-Django 开发一个多功能 Web 应用渗透测试系统具备以下几个方面的优势: 1. 强大的渗透测试功能:Python-Django 可以实现对 Web 应用中可能存在的漏洞进行渗透测试,比如 SQL 注入、跨站脚本攻击等,提供了一系列的工具和库来实现这些功能。 2. 可扩展性:Python-Django 框架本身就具备良好的可扩展性,可以根据实际需求添加新的功能或模块,满足不同用户的要求。 3. 用户权限管理:Web 应用渗透测试系统需要具备用户权限管理的功能,以便不同用户可以根据其角色进行权限管理和操作。Python-Django 提供了丰富的用户认证和授权机制,可以很方便地实现用户权限管理。 4. 数据库支持:Web 应用渗透测试系统需要对各种渗透测试数据进行存储和管理,Python-Django 提供了对多种数据库的支持,如 MySQL、SQLite、PostgreSQL 等,可以根据实际需要选择合适的数据库。 综上所述,使用 Python-Django 开发一个多功能的 Web 应用渗透测试系统可以实现强大的渗透测试功能,具备良好的可扩展性和用户权限管理,并提供了丰富的数据库支持。这将使得渗透测试人员可以更加高效和便捷地进行各种类型的渗透测试工作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值