个性化定制系统模块

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表

完全自定义
手工按需开发

文章导航