一、项目运行 环境配置:
Jdk1.8 + Tomcat8.5 + mysql + Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)
项目技术:
JSP +Spring + SpringMVC + MyBatis + html+ css + JavaScript + JQuery + Ajax 等等
用户管理注册登录控制层:
@Controller
@RequestMapping("/user")
public class UserController {
@Autowired
private UserService userService;
/**
* 注册
* @param user
* @return
*/
@RequestMapping("/register")
@ResponseBody
public String register(User user){
Map<String,Object> map = new HashMap<String,Object>();
//调用注册的方法
if(userService.addUser(user)>0){
map.put(SystemConstant.SUCCESS,true);
map.put(SystemConstant.MESSAGE,"恭喜你,注册成功!");
}else{
map.put(SystemConstant.SUCCESS,false);
map.put(SystemConstant.MESSAGE,"很遗憾,注册失败,请重新尝试!");
}
return JSON.toJSONString(map);
}
/**
* 登录
* @param
* @return
*/
@RequestMapping("/login")
@ResponseBody
public String login(String loginName, String password, HttpSession Session){
Map<String,Object> map = new HashMap<String,Object>();
//调用注册的方法
User loginUser = userService.login(loginName, password);
//登录判断
if(loginUser!=null){
//将密码清空
loginUser.setPassword(null);
map.put(SystemConstant.SUCCESS,true);
//保存登录用户信息到session中
Session.setAttribute(SystemConstant.FRONT_LOGIN_USER,loginUser);
}else{
map.put(SystemConstant.SUCCESS,false);
map.put(SystemConstant.MESSAGE,"用户名或密码错误,请重新登录!");
}
return JSON.toJSONString(map);
}
/**
* 根据用户名查询用户信息
* @param loginName
* @return
*/
@RequestMapping("/checkName")
@ResponseBody
public String checkName(String loginName){
Map<String,Object> map = new HashMap<String,Object>();
//调用注册的方法
if(userService.findUserByName(loginName)!=null){
map.put(SystemConstant.EXISI,true);
map.put(SystemConstant.MESSAGE,"用户名存在,请重新输入");
}else{
map.put(SystemConstant.EXISI,false);
}
return JSON.toJSONString(map);
}
}
房间管理控制层:
@Controller
@RequestMapping("/room")
public class RoomController {
@Resource
private RoomService roomService;
@Resource
private RoomTypeService roomTypeService;
/**
* 查询房间详情
* @param id
* @param model
* @return
*/
@RequestMapping("/{id}.html")
public String detail(@PathVariable Integer id, Model model){
//调用查询房间详情的方法
Room room = roomService.findById(id);
//将数据放到模型中
model.addAttribute("room",room);
return "detail";
}
/**
* 查询全部房间列表
* @param model
* @return
*/
@RequestMapping("/list.html")
public String list(Model model){
//调用查询所有房型列表的方法
List<RoomType> roomTypeList = roomTypeService.findRoomTypeList(null);
//创建查询条件类
RoomVo roomVo = new RoomVo();
roomVo.setStatus(3);//可预订
//查询房间列表
List<Room> roomList = roomService.findRoomListByPage(roomVo);
//将数据放到模型中
model.addAttribute("roomTypeList",roomTypeList);
model.addAttribute("roomList",roomList);
return "hotelList";
}
/**
* 根据房型查询房间列表
* @param model
* @return
*/
@RequestMapping("/list/{id}")
public String list(@PathVariable Integer id,Model model){
//调用查询所有房型列表的方法
List<RoomType> roomTypeList = roomTypeService.findRoomTypeList(null);
//创建查询条件类
RoomVo roomVo = new RoomVo();
roomVo.setRoomtypeid(id);//房型ID
roomVo.setStatus(3);//可预订
//查询房间列表
List<Room> roomList = roomService.findRoomListByPage(roomVo);
//将数据放到模型中
model.addAttribute("roomTypeList",roomTypeList);
model.addAttribute("roomList",roomList);
model.addAttribute("typeId",id);//将当前选中的房型ID保存到模型中,目的是在页面中回显选中的文本(改变选中的颜色)
return "hotelList";
}
}
订单管理控制层:
@Controller
@RequestMapping("/orders")
public class OrdersController {
@Resource
private OrdersService ordersService;
/**
* 添加订单
* @param orders
* @return
*/
@RequestMapping("/addOrders")
@ResponseBody
public String addOrders(Orders orders){
Map<String,Object> map = new HashMap<String,Object>();
//调用添加订单的方法
if(ordersService.addOrders(orders)>0){
map.put(SystemConstant.SUCCESS,true);
map.put(SystemConstant.MESSAGE,"酒店预订成功");
}else{
map.put(SystemConstant.SUCCESS,false);
map.put(SystemConstant.MESSAGE,"酒店预订失败,请重试!");
}
return JSON.toJSONString(map);
}
}
角色管理控制层:
/**
* 角色管理
*/
@RequestMapping("/admin/role")
@RestController
public class RoleController {
@Autowired
private RoleService roleService;
@Autowired
private EmployeeService employeeService;
@Autowired
private MenuService menuService;
/**
* 角色列表查询
* @return
*/
@RequestMapping("/list")
public DataGridViewResult list(RoleVo roleVo){
//设置分页信息
PageHelper.startPage(roleVo.getPage(),roleVo.getLimit());
//调用分页查询的方法
List<Role> roleList = roleService.findRoleList(roleVo);
//创建分页对象
PageInfo<Role> pageInfo = new PageInfo<Role>(roleList);
//返回数据
return new DataGridViewResult(pageInfo.getTotal(),pageInfo.getList());
}
//添加部门信息
@RequestMapping("/addRole")
public String addRole(Role role){
//创建map存放信息
Map<String,Object> map = new HashMap<String, Object>();
int addRole = roleService.addRole(role);
if(addRole>0){
map.put(SystemConstant.SUCCESS,true);
map.put(SystemConstant.MESSAGE,"添加成功");
}else{
map.put(SystemConstant.SUCCESS,false);
map.put(SystemConstant.MESSAGE,"添加失败");
}
//map中存放的信息已json形式返回
return JSON.toJSONString(map);
}
//修改角色信息
@RequestMapping("/updateRole")
public String updateRole(Role role){
Map<String,Object> map = new HashMap<String, Object>();
int updateRole = roleService.updateRole(role);
if(updateRole>0){
map.put(SystemConstant.SUCCESS,true);
map.put(SystemConstant.MESSAGE,"修改成功");
}else{
map.put(SystemConstant.SUCCESS,false);
map.put(SystemConstant.MESSAGE,"修改失败");
}
//map中存放的信息已json形式返回
return JSON.toJSONString(map);
}
//删除角色信息
@RequestMapping("/deleteById")
public String deleteById(Integer id){
Map<String,Object> map = new HashMap<String, Object>();
int deleteById = roleService.deleteById(id);
if (deleteById>0){
map.put(SystemConstant.SUCCESS,true);//删除成功
map.put(SystemConstant.MESSAGE,"删除成功");
}else{
map.put(SystemConstant.SUCCESS,false);//删除失败
map.put(SystemConstant.MESSAGE,"删除失败");
}
return JSON.toJSONString(map);
}
//查看该角色编号下是否有员工
@RequestMapping("/checkRoleHasEmployee")
public String checkDeptHasEmployee(Integer id){
Map<String,Object> map = new HashMap<String, Object>();
int countById = employeeService.getEmployeeCountByRoleId(id);
if (countById>0){
//该角色是否有员工在用
map.put(SystemConstant.EXISI,true);//存在
map.put(SystemConstant.MESSAGE,"该角色有员工使用,不能删除");
}else{
map.put(SystemConstant.EXISI,false);//存在
}
return JSON.toJSONString(map);
}
/**
* 初始化菜单
* @return
*/
@RequestMapping("/initMenuTree")
public DataGridViewResult initMenuTree(Integer roleId){
//调用查询菜单列表的方法
List<Menu> menuList = menuService.findMenuList();
//根据角色ID查询该角色已经拥有的菜单ID的方法
List<Integer> currentRoleMenuIds = menuService.findMenuIdListByRoleId(roleId);
//定义集合,保存菜单信息
List<Menu> currentMenus = new ArrayList<Menu>();
//判断集合是否存在数据
if(currentRoleMenuIds!=null && currentRoleMenuIds.size()>0){
//根据菜单ID查询该菜单的信息
currentMenus = menuService.findMenuByMenuId(currentRoleMenuIds);
}
//创建集合保存树节点信息
List<TreeNode> treeNodes = new ArrayList<TreeNode>();
//循环遍历集合
for (Menu menu : menuList) {
//定义变量,标识是否选中
String checkArr = "0";//0表示复选框不选中,1表示选中复选框
//内层循环遍历当前角色拥有的权限菜单
//循环比较的原因:比较两个集合中的数据是否有相同的,有相同的表示当前角色拥有这个权限
for (Menu currentMenu : currentMenus) {
//如果ID相等,表示当前角色有这个菜单,有这个菜单则需要将复选框选中
if(menu.getId() == currentMenu.getId()){
checkArr ="1";//选中
break;
}
}
//定义变量,表示菜单是否展开
Boolean spread = (menu.getSpread()==null || menu.getSpread()==1) ? true : false;
treeNodes.add(new TreeNode(menu.getId(),menu.getPid(),menu.getTitle(),spread,checkArr));
}
//将数据返回到页面
return new DataGridViewResult(treeNodes);
}
/**
* 分配菜单
* @param ids
* @param roleId
* @return
*/
@RequestMapping("/saveRoleMenu")
public String saveRoleMenu(String ids,Integer roleId){
Map<String,Object> map = new HashMap<String,Object>();
//调用保存角色菜单关系的方法
if(roleService.saveRoleMenu(ids,roleId)>0){
map.put(SystemConstant.MESSAGE,"菜单分配成功");
}else{
map.put(SystemConstant.MESSAGE,"菜单分配失败");
}
return JSON.toJSONString(map);
}
/**
* 查询角色列表通过员工ID
* @param id
* @return
*/
@RequestMapping("/initRoleListByEmpId")
public DataGridViewResult initRoleListByEmpId(int id){
List<Map<String, Object>> roleList = roleService.findRoleListByMap();
//调用根据员工ID查询该员工拥有的角色列表的方法
List<Integer> roleIds = roleService.findEmployeeRoleByEmployeeId(id);
//循环比较两个集合中的角色ID值是否相等,相等则选中该角色
for (Map<String, Object> map : roleList) {
//定义变量,标识是否选中
boolean flag = false;//不选中
//获取每一个角色ID
Integer rid = (Integer) map.get("id");//id是主键,以主键作为map集合中key
//内层循环遍历该员工拥有的角色列表
for (Integer roleId : roleIds) {
//判断两个集合中是否存在角色ID相同
if(rid == roleId){
flag = true;//选中该角色
break;
}
}
//将状态保存在map集合中
map.put("LAY_CHECKED",flag);//key必须是LAY_CHECKED
}
return new DataGridViewResult(Long.valueOf(roleList.size()),roleList);
}
}
版权归原作者 OldWinePot 所有, 如有侵权,请联系我们删除。