教学计划
1、角色管理
a. 添加角色功能
b. 角色分页查询
2、用户管理
a. 添加用户功能
b. 用户分页查询
3、修改Realm中授权方法(查询数据库)
4、使用ehcache缓存权限数据
a. 添加ehcache依赖
b. 配置缓存管理器
5、系统菜单根据登录人展示
a. 调整页面ajax请求地址
b. 服务端查询菜单数据
1 角色管理
1.1 添加角色功能
1.1.1 页面调整
页面:WEB-INF/pages/admin/role_add.jsp
第一步:修改页面,使用ztree勾选效果(checkbox)
第二步:修改ajax方法的请求URL地址
第三步:为保存按钮绑定事件,提交表单
1.1.2 服务端实现
创建角色管理Action、Service、Dao
Service代码:
配置struts.xml
1.2 角色分页查询
修改role.jsp页面中datagrid的URL地址
在RoleAction中提供分页查询方法:
2 用户管理
2.1 添加用户
页面:WEB-INF/pages/admin/userinfo.jsp
2.1.1 页面调整
第一步:发送ajax请求,获取角色数据,在回调函数中动态展示角色数据,展示为checkbox
<tr>
<td>选择角色:</td>
<td colspan="3" id="roleTD">
<script type="text/javascript">
$(function(){
//页面加载完成后,发送ajax请求,获取所有的角色数据
$.post('roleAction_listajax.action',function(data){
//在ajax回调函数中,解析json数据,展示为checkbox
for(var i=0;i<data.length;i++){
var id = data[i].id;
var name = data[i].name;
$("#roleTD").append('<input id="'+id+'" type="checkbox" name="roleIds" value="'+id+'"><label for="'+id+'">'+name+'</label>');
}
});
});
</script>
</td> </tr>
第二步:在RoleAction中提供listajax方法,查询所有角色,返回json数据
第三步:为保存按钮绑定事件,提交表单
2.1.2 服务端实现
在UserAction中提供add方法,保存一个用户
Service代码:
配置struts.xml
2.2 分页查询
第一步:修改userlist.jsp页面中datagrid的URL地址
在数据表格中,修改field,由电话修改为角色
第二步:在UserAction中提供分页查询方法
第三步:在User类中提供getRoleNames方法,getBirthdayString方法
3 修改Realm中授权方法(查询数据库)
在FunctionDao中扩展方法,根据用户id查询对应的权限
4 使用ehcache缓存权限数据
ehcache是专门缓存插件,可以缓存Java对象,提高系统性能。
ehcache提供的jar包:
第一步:在pom.xml文件中引入ehcache的依赖
第二步:在项目中提供ehcache的配置文件
第三步:在spring配置文件中配置缓存管理器对象,并注入给安全管理器对象
5 系统菜单根据登录人动态展示
第一步:修改index.jsp页面中ajax方法的请求地址
第二步:在Action中提供findMenu方法
第三步:在Service中提供方法
Dao代码:
注意:需要在Function类中提供getpId方法
总结
今天的内容比较难,学了比较久,敲代码更久,因为没弄懂。今天遇到的问题还算比较少,就是在修改添加用户和添加角色功能时候,点击保存,什么反应都没有,调试了很久,复制了新的页面就好了,原来是本来页面就存在问题。