Eova中默认已经提供了现成的用户模块. 未来的事情谁也不知道,可是命运往往都是不由自主的. 需求背景: 某互联网公司陆晶所,现有30W用户,现有一套后台管理系统,全部采用手工定制化开发,一般开发一个中小型模块,大约需要2-4周时间.项目经理-凯瑞,发现项目开发进度严重滞后,这种简单的数据维护系统还要搞这么久,于是经朋友推荐决定使用Eova来进行快速开发,加快项目进度. 所以就让手下的程序员-凯文,研究一下Eova,是否能满足该公司各种开发需求,经过研究,凯文发现Eova的确挺方便,能快速搞定公司的项目需求,可以缩短成吨的时间. 不过,公司已经有30W用户了,希望这些用户可以直接通过Eova构建的系统能直接登录. 那么问题来了,Eova已经提供了用户表,用户登录,用户管理,咋办?咋办?咋办? 难道友谊的小船,说翻就翻了吗? * * * * * 可以覆盖重写IndexController中的所有方法来 定制自己想要的功能 ~~~ public class OSSController extends IndexController { // 例如:登录时,在user 身上挂载 其它业务对象,以便表达式动态获取值,实现复杂的逻辑 @Override protected void loginInit(Controller ctrl, User user) throws Exception { super.loginInit(ctrl, user); // 添加自定义业务信息到当前用户中 UserInfo info = UserInfo.dao.findById(user.get("id")); if (info != null) { user.put("info", info); // 页面或表达式 调用用户信息 ${user.info.nickname} } // 还可以将相关信息放入session中,在Aop中可以获取,(表达式只能${user.xxx}) // ctrl.setSessionAttr("UserInfo", info); } ~~~ 同理,如果不想执行默认的登录逻辑 举个栗子: 通过其它数据库的用户表 比如已有用户数据表,想用业务库中的手机号+验证码进行登录,不用eova默认帐号,密码进行登录. 直接覆盖重写doLogin()方法,修改登录逻辑为 查自己的用户表,判断手机号是否存在,然后短信API校验正确性,然后登录成功,将用户put到eova_user上,见上文源码. PS:需要将角色ID冗余到业务用户表中,方便后续进行角色判定(分角色数据过滤等场景). 需要拓展的功能可能有: 1. 白名单设置 2. 黑名单设置 3. 上次登录时间 4. 单点登录 5. ...... 均可通过 继承,覆盖,重写 实现个性化定制,只有你想不到了,没有你做不到的! > PS:初级开发者不要尝试覆盖重写权限相关逻辑,可能会导致系统瘫痪,或者无法兼容后续新版本 * * * * * 上面讲述如何定制化开发系统模块!下面说说前端界面的定制套路! 用户管理是最常见会需要定制的功能. 用户管理难点:(自定义拓展时,请认真考虑如下问题) 1. 多库,跨库 2. 跨库事务 3. 用户业务属性动态拓展 4. 未知需求 Eova默认的用户管理业务逻辑介绍:(V1.6) 默认为1V1主子模式 用户主表(eova.eova_user)新增时,自动新增子表的用户详细信息(demo.user_info) 用户主表删除自动删除关联的用户详情表 子表禁止新增,禁止删除 如果觉得默认实现不好,或者不满足需求时,可以考虑自定义用户管理 其它可选的方案有: **单表模版->View** eova.eova_user u left join demo.user_info i where u.id = i.uid View 单表模版,跨库 连2表(好处,在一个界面展现) View新增,修改通过AOP自定义逻辑 **单表模版->Aop** demo.user_info 单表模版 增加虚拟字段,帐号,密码,新增,修改,通过AOP强化,将 帐号密码入 eova.eova_user表 **完全自定义** 手工按需开发 * * * * * V1.6-beta4 开始新增特性-可配置自定义登录 配置文件:/src/main/resources/default/eova.config ~~~ #登录用户数据源 login.user.ds = eova #登录用户表名 login.user.table = eova_user #登录用户ID字段 login.user.id = id #登录用户帐号字段 login.user.account = login_id #登录用户密码字段 login.user.password = login_pwd #登录用户角色ID字段 login.user.rid = rid ~~~ 可以自由配置用什么库的什么表来登录,然后帐号,密码,角色ID 分别是啥字段都可以配置!