只有在实战中练习才能真正获得能力的提升,本篇文章手把手带你用Java快速上手实现一个用户后台管理系统,大家可以在过程中查缺补漏,提升水平
主要功能
管理员登录功能、管理员列表操作、用户列表操作、订单管理
登录功能
设计思路:前端页面获取输入的数据,然后发送Ajax请求,在servlet中获取数据并调用service层中的方法进行处理,service层中调用dao层的实现方法,最终servlet返回一个结果集,判断登录是否成功。
login.html主要功能代码:
servlet中功能代码:
//登录 public void login(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //获取用户名和密码 String username = request.getParameter("username"); String password = request.getParameter("password"); //封装管理员对象 Administrator admin = new Administrator(); admin.setAname(username); admin.setPassword(password); //创建结果对象 ResultInfo resultInfo = new ResultInfo(); //调用service查询 Administrator administrator = service.login(admin); if (administrator == null) { resultInfo.setFlag(false); resultInfo.setErrorMsg("用户名或密码错误!"); } if (administrator != null && !administrator.getStatus().equals("Y")) { resultInfo.setFlag(false); resultInfo.setErrorMsg("该账户未激活!"); } if (administrator != null && administrator.getStatus().equals("Y")) { resultInfo.setFlag(true); //设置session request.getSession().setAttribute("username", administrator.getAname()); } //调用父类中定义的方法,转json数据后回传 writeValue(resultInfo, response); }
service层中代码实现:
@Override public Administrator login(Administrator administrator) { return dao.login(administrator); }
dao层中代码实现:
@Override public Administrator login(Administrator administrator) { Administrator admin = null; try { String sql = "SELECT * FROM administrator WHERE aname = ? AND PASSWORD = ?"; admin = template.queryForObject(sql, new BeanPropertyRowMapper<>(Administrator.class), administrator.getAname(), administrator.getPassword()); } catch (Exception e) { } return admin; }
实现效果:
管理员列表
设计思路:数据操作与登录功能大同小异,实现了管理员的增删改查,在此重点介绍分页、模糊查询。
admin_list.html主要功能代码:
servlet中功能代码:
//分页、模糊查询 public void pageQuery(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //接收参数 String currentPageStr = request.getParameter("currentPage"); //接收admin_name管理员名称 String admin_name = request.getParameter("admin_name"); //判断admin_name是否为null if (admin_name != null && !"null".equals(admin_name) && admin_name.length() > 0) { admin_name = new String(admin_name.getBytes("iso-8859-1"), "utf-8"); } else { admin_name = ""; } int currentPage = 0; //当前页码,不传递参数,默认为1 if (currentPageStr != null && currentPageStr.length() > 0) { currentPage = Integer.parseInt(currentPageStr); } else { currentPage = 1; } //每页显示条数,默认为5 int pageSize = 5; //调用service查询PageBean对象 PageBeanpb = service.pageQuery(currentPage, pageSize, admin_name); //将pageBean对象序列化为json,返回 writeValue(pb, response); }
service层中代码实现:
@Override public PageBeanpageQuery(int currentPage, int pageSize, String admin_name) { //封装PageBean PageBean pb = new PageBean<>(); //设置当前页码 pb.setCurrentPage(currentPage); //设置每页显示条数 pb.setPageSize(pageSize); //设置总记录数 int totalCount = dao.findTotalCount(admin_name); pb.setTotalCount(totalCount); //设置当前页显示的数据集合 int start = (currentPage - 1) * pageSize; //开始的记录数 List list = dao.findByPage(start, pageSize, admin_name); pb.setList(list); //设置总页数 = 总记录数/每页显示条数 int totalPage = totalCount % pageSize == 0 ? totalCount / pageSize : (totalCount / pageSize) + 1; pb.setTotalPage(totalPage); return pb; }
dao层中代码实现:
@Override public int findTotalCount(String admin_name) { //定义sql模板 String sql = "SELECT COUNT(*) FROM administrator WHERE 1=1 "; StringBuilder sb = new StringBuilder(sql); //条件 List
实现效果:
用户列表
设计思路:与管理员列表设计思路基本类似。
实现效果:
订单管理
设计思路:与管理员列表设计思路基本类似。
到此这篇关于详解Java快速上手用户后台管理系统的文章就介绍到这了,更多相关Java 后台管理系统内容请搜索0133技术站以前的文章或继续浏览下面的相关文章希望大家以后多多支持0133技术站!
以上就是详解Java快速上手用户后台管理系统的详细内容,更多请关注0133技术站其它相关文章!