山东大学软件学院项目实训——V-Track:虚拟现实环境下的远程教育和智能评估系统(七)

项目记录——week8/9/10/11

本篇仍然介绍系统后端开发过程,主要介绍系统配置、导航栏等系统管理

均只展示后端方法实的核心代码

后台系统配置管理API设计

概述

本设计文档提供了系统配置管理 API 的详细设计,包括系统配置分页查询、添加、查看、修改、删除、列举和初始化。这些 API 旨在提供管理员对系统配置的全面管理功能。

API 详细设计
  1. 系统配置分页查询

    • 描述: 分页查询系统配置。
    • 请求方法: POST
    • 请求参数: AdminSysConfigPageReq 包含当前页码和每页记录数。
    • 响应格式: 返回系统配置分页列表。
    • 示例代码:
      public Result<Page<AdminSysConfigPageResp>> page(AdminSysConfigPageReq req) {
          SysConfigExample example = new SysConfigExample();
          Criteria c = example.createCriteria();
          Page<SysConfig> page = dao.page(req.getPageCurrent(), req.getPageSize(), example);
          Page<AdminSysConfigPageResp> respPage = PageUtil.transform(page, AdminSysConfigPageResp.class);
          return Result.success(respPage);
      }
      

  2. 系统配置添加

    • 描述: 添加新的系统配置。
    • 请求方法: POST
    • 请求参数: AdminSysConfigSaveReq 包含系统配置信息。
    • 响应格式: 返回操作结果。
    • 示例代码:
      public Result<String> save(AdminSysConfigSaveReq req) {
          SysConfig record = BeanUtil.copyProperties(req, SysConfig.class);
          if (dao.save(record) > 0) {
              return Result.success("操作成功");
          }
          return Result.error("操作失败");
      }
      

  3. 系统配置查看

    • 描述: 查看指定系统配置的详细信息。
    • 请求方法: POST
    • 请求参数: 主键ID。
    • 响应格式: 返回系统配置详情。
    • 示例代码:
      public Result<AdminSysConfigViewResp> view(Long id) {
          return Result.success(BeanUtil.copyProperties(dao.getById(id), AdminSysConfigViewResp.class));
      }
      

  4. 系统配置修改

    • 描述: 修改指定的系统配置信息。
    • 请求方法: POST
    • 请求参数: AdminSysConfigEditReq 包含更新后的系统配置信息。
    • 响应格式: 返回操作结果。
    • 示例代码:
      public Result<String> edit(AdminSysConfigEditReq req) {
          SysConfig record = BeanUtil.copyProperties(req, SysConfig.class);
          if (dao.updateById(record) > 0) {
              return Result.success("操作成功");
          }
          return Result.error("操作失败");
      }
      

  5. 系统配置删除

    • 描述: 删除指定的系统配置。
    • 请求方法: POST
    • 请求参数: 主键ID。
    • 响应格式: 返回操作结果。
    • 示例代码:
      public Result<String> delete(Long id) {
          if (dao.deleteById(id) > 0) {
              return Result.success("操作成功");
          }
          return Result.error("操作失败");
      }
      

  6. 列举系统配置

    • 描述: 根据条件列举系统配置。
    • 请求方法: POST
    • 请求参数: AdminSysConfigListReq 包含查询条件。
    • 响应格式: 返回系统配置列表。
    • 示例代码:
      public Result<List<AdminSysConfigListResp>> list(AdminSysConfigListReq req) {
          SysConfigExample example = new SysConfigExample();
          example.setOrderByClause("sort asc, id desc");
      
          Criteria c = example.createCriteria();
          if (ObjectUtil.isNotEmpty(req.getConfigType())) {
              c.andConfigTypeEqualTo(req.getConfigType());
              if (req.getConfigType().equals(3)) {
                  c.andConfigKeyLike(VodPlatformEnum.byCode(Integer.valueOf(dao.getByConfigKey("vodPlatform").getConfigValue())).getTag());
                  example.or(example.createCriteria().andConfigKeyLike(PageUtil.rightLike("vod")));
              }
              if (req.getConfigType().equals(4)) {
                  c.andConfigKeyLike(StoragePlatformEnum.byCode(Integer.valueOf(dao.getByConfigKey("storagePlatform").getConfigValue())).getTag());
                  example.or(example.createCriteria().andConfigKeyLike(PageUtil.rightLike("storage")));
              }
              if (req.getConfigType().equals(5)) {
                  c.andConfigKeyLike(SmsPlatformEnum.byCode(Integer.valueOf(dao.getByConfigKey("smsPlatform").getConfigValue())).getTag());
                  example.or(example.createCriteria().andConfigKeyLike(PageUtil.rightLike("sms")));
              }
          }
          if (ObjectUtil.isNotEmpty(req.getContentType())) {
              c.andContentTypeEqualTo(req.getContentType());
          }
          if (StrUtil.isNotBlank(req.getConfigName())) {
              c.andConfigNameLike(PageUtil.like(req.getConfigName()));
          }
          if (StrUtil.isNotBlank(req.getConfigKey())) {
              c.andConfigKeyLike(PageUtil.like(req.getConfigKey()));
          }
          if (ObjectUtil.isNotEmpty(req.getConfigShow())) {
              c.andConfigShowEqualTo(req.getConfigShow());
          }
          if (StrUtil.isNotBlank(req.getRemark())) {
              c.andRemarkLike(PageUtil.like(req.getRemark()));
          }
      
          List<SysConfig> configList = dao.listByExample(example);
          return Result.success(BeanUtil.copyProperties(configList, AdminSysConfigListResp.class));
      }
      

  7. 初始化系统配置

    • 描述: 初始化系统配置。
    • 请求方法: POST
    • 请求参数: 无
    • 响应格式: 返回操作结果。
    • 示例代码:
      public Result<String> init() {
          Map<String, String> configMap = dao.listByExample(new SysConfigExample()).stream().collect(Collectors.toMap(SysConfig::getConfigKey, SysConfig::getConfigValue));
          VodConfig vodConfig = BeanUtil.objToBean(configMap, VodConfig.class);
          // 初始化
          VodUtil.init(vodConfig);
          return Result.success("操作成功");
      }
      

后台头部导航管理 API 设计

概述

本设计文档提供了头部导航管理 API 的详细设计,包括头部导航分页查询、添加、查看、修改、删除等功能。这些 API 旨在提供管理员对网站头部导航的全面管理功能。

API 详细设计
  1. 头部导航分页查询

    • 描述: 分页查询头部导航。
    • 请求方法: POST
    • 请求参数: AdminWebsiteNavPageReq 包含当前页码、每页记录数及导航标题(可选)。
    • 响应格式: 返回头部导航分页列表。
    • 示例代码:
      public Result<Page<AdminWebsiteNavPageResp>> page(AdminWebsiteNavPageReq req) {
          WebsiteNavExample example = new WebsiteNavExample();
          Criteria c = example.createCriteria();
          if (StringUtils.hasText(req.getNavTitle())) {
              c.andNavTitleLike(PageUtil.rightLike(req.getNavTitle()));
          }
          example.setOrderByClause("sort asc, id desc");
          Page<WebsiteNav> page = dao.page(req.getPageCurrent(), req.getPageSize(), example);
          Page<AdminWebsiteNavPageResp> respPage = PageUtil.transform(page, AdminWebsiteNavPageResp.class);
          return Result.success(respPage);
      }
      
      

  2. 头部导航添加

    • 描述: 添加新的头部导航。
    • 请求方法: POST
    • 请求参数: AdminWebsiteNavSaveReq 包含头部导航信息。
    • 响应格式: 返回操作结果。
    • 示例代码:
      public Result<String> save(AdminWebsiteNavSaveReq req) {
          WebsiteNav record = BeanUtil.copyProperties(req, WebsiteNav.class);
          if (dao.save(record) > 0) {
              return Result.success("操作成功");
          }
          return Result.error("操作失败");
      }
      

  3. 头部导航查看

    • 描述: 查看指定头部导航的详细信息。
    • 请求方法: POST
    • 请求参数: 主键ID。
    • 响应格式: 返回头部导航详情。
    • 示例代码:
      public Result<AdminWebsiteNavViewResp> view(Long id) {
          return Result.success(BeanUtil.copyProperties(dao.getById(id), AdminWebsiteNavViewResp.class));
      }
      

  4. 头部导航修改

    • 描述: 修改指定的头部导航信息。
    • 请求方法: POST
    • 请求参数: AdminWebsiteNavEditReq 包含更新后的头部导航信息。
    • 响应格式: 返回操作结果。
    • 示例代码:
      public Result<String> edit(AdminWebsiteNavEditReq req) {
          WebsiteNav record = BeanUtil.copyProperties(req, WebsiteNav.class);
          if (dao.updateById(record) > 0) {
              return Result.success("操作成功");
          }
          return Result.error("操作失败");
      }
      

  5. 头部导航删除

    • 描述: 删除指定的头部导航。
    • 请求方法: POST
    • 请求参数: 主键ID。
    • 响应格式: 返回操作结果。
    • 示例代码:
      public Result<String> delete(Long id) {
          if (dao.deleteById(id) > 0) {
              return Result.success("操作成功");
          }
          return Result.error("操作失败");
      }
      

  • 16
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值