Foxnic-Web 代码生成 (10) —— 生成菜单与授权
概述
模块代码生成之后,我们需要为配置菜单。配置菜单是一系列的过程,包括创建资源、创建菜单并关联资源,并将菜单授权给指定的角色。
本文中的示例代码均可在 https://gitee.com/LeeFJ/foxnic-samples 项目中找到,本文对照 webfull 项目讲解。
完整示例
Foxnic-Web 项目提供代码生成的完整示例,请大家参考:
######
生成菜单
生成菜单包含若干步骤,涉及到资源、菜单、角色等系统表。示例项目 webfull 中的 generator 模块下的 MenuGenerator 类已经实现菜单生成与授权的全过程。以下是菜单生成时使用的部分代码:
/**
* 超级管理员角色ID
* */
public static final String SUPER_ADMIN_ROLE_ID="110352963290923110";
public static void main(String[] args) {
MenuGenerator mg=null;
// 创建一个 MenuGenerator,并传入必要的参数
mg=new MenuGenerator(WebFullTables.WEBFULL_EXAMPLE_REIMBURSEMENT.$TABLE, ReimbursementServiceProxy.class, ReimbursementPageController.class);
// 生成菜单
mg.generate("643084271635922944");
}
上面的代码中,我们可以看到,MenuGenerator 使用一个常量指定了默认授权的角色。MenuGenerator 类在生成菜单时需要传入数据表元数据对象、Proxy 类、PageController 类,以提取资源路径。
生成菜单时调用 generate 方法,该方法需要传入一个上级菜单ID作为参数。由于 generate 方法会操作多表,改方法在内部使用了事务管控,不会因为某个步骤失败而产生垃圾数据。
generate 方法执行后会在控制台输出 batchId , 这个 batchId 也被存入菜单表中,batchId 可以用于以生成菜单的回滚。
回滚菜单
生成菜单时也有可能因为一些误操作而生成了错误的菜单,这时我们就需要撤销已经生成的菜单、资源以及角色授权。我们需要找到 batchId,然后调用 MenuGenerator.removeByBatchId() 。如下代码所示:
public static void main(String[] args) {
MenuGenerator mg=null;
mg=new MenuGenerator(WebFullTables.WEBFULL_EXAMPLE_REIMBURSEMENT.$TABLE, ReimbursementServiceProxy.class, ReimbursementPageController.class);
//mg.generate("643084271635922944");
mg.removeByBatchId("608188281577799680");
}
小结
本节主介绍了如何生成模块菜单,以及如果模块菜单生成错误,如何通过 batchId 回滚撤销已经生成的菜单。MenuGenerator 并没有要求提供更多细节的菜单属性,这些配置请到系统管理的菜单管理维护。
相关项目
https://gitee.com/LeeFJ/foxnic
https://gitee.com/LeeFJ/foxnic-web
https://gitee.com/LeeFJ/foxnic-samples