基于javaweb+mysql的jsp+servlet校园宿舍管理系统(java+jsp+javaweb+mysql+ajax)

基于javaweb+mysql的jsp+servlet校园宿舍管理系统(java+jsp+javaweb+mysql+ajax)

运行环境

Java≥8、MySQL≥5.7、Tomcat≥8

开发工具

eclipse/idea/myeclipse/sts等均可配置运行

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb+mysql的JSP+Servlet校园宿舍管理系统(java+jsp+javaweb+mysql+ajax)

一、项目简述

功能:宿舍管理员,最高管理员,学生三个身份,包括学 生管理,宿舍管理员管理,考勤管理,宿舍楼管理,缺勤 记录管理,个人信息修改等等功能。

二、项目运行

环境配置: Jdk1.8 + Tomcat8.5 + mysql + Eclispe (IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。

项目技术: JSP + Entity+ Servlet + html+ css + JavaScript + JQuery + Ajax 等等。

			
			//查看用户是否有修改考勤记录的权限
			User user = userService.findStuCodeAndManager(record.getUser().getStuCode(),userCurr);
			System.out.println("修改权限user :"+user);
			if(user == null) {
				//无删除激活权限
				response.sendRedirect(getServletContext().getContextPath()+"/record.action?action=list");
			}else {
				//有删除激活权限
				recordService.update(record);
				//跳转到缺勤记录列表页
				response.sendRedirect(getServletContext().getContextPath()+"/record.action?action=list");
			}
		
		}
	}
		

}
package com.demo.servlet;

/**
 * Servlet implementation class DormBuildServlet
 */
@WebServlet("/dormBuild.action")
public class DormBuildServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public DormBuildServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

	/**
	 * @see HttpServlet#service(HttpServletRequest request, HttpServletResponse response)
	 */
/**
 * Servlet implementation class LoginServlet
 */
@WebServlet("/login")
public class LoginServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public LoginServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#service(HttpServletRequest request, HttpServletResponse response)
     */
    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        System.out.println("========登录=============");
        //Tomcat8.0 处理post请求乱码问题
        request.setCharacterEncoding("utf-8");
        //根据输入框标签的name属性值去获登录名和密码
        String stuCode = request.getParameter("stuCode");
        String password = request.getParameter("password");
        String remember = request.getParameter("remember");
        System.out.println("stuCode:" + stuCode + "  password:" + password + "   remember:" + remember);

        UserService userService = new UserServiceImpl();
        //去查询用户输入的登录名和密码是否正确
        User user = userService.findByStuCodeAndPass(stuCode, password);
        System.out.println("user:" + user);

        if (user == null) {
            //用户输入的学号或密码错误,跳转到登录页面,并给予提示信息
            request.setAttribute("error", "您输入的学号或密码错误!");
            //请求链未断开的跳转,可以在下一个servlet或jsp中,获取保存在request中的数据
            request.getRequestDispatcher("index.jsp").forward(request, response);
        } else {
            //用户输入学号和密码正确,登录成功,跳转到主页面
            //保存在session中的数据,默认是30分钟内有效。保存在session中的数据,在整个项目中都可以获取得到
		
		if(action != null & action.equals("list")) {
			//查询缺勤记录并展示
			Integer roleId = userCurr.getRoleId();
			List<DormBuild>  builds = new ArrayList<DormBuild>();
			if(roleId.equals(0)) {
				//如当前用户是超级管理员,他能将学生添加到所有的宿舍楼,查询所有宿舍楼
				builds = buildService.findAll();
			}else if(roleId.equals(1)) {
				//如当前用户 为宿舍管理员,他只能添加学生到其管理的宿舍楼
				builds =  buildService.findByUserId(userCurr.getId());
			}
			System.out.println("builds:"+builds);
			request.setAttribute("builds", builds);
			
			String startDate = request.getParameter("startDate");
			String endDate = request.getParameter("endDate");
			String dormBuildId = request.getParameter("dormBuildId");
			String searchType = request.getParameter("searchType");
			String keyword = request.getParameter("keyword");
			String pageIndex = request.getParameter("pageIndex");
			System.out.println("startDate:"+startDate+" endDate:"+endDate+" dormBuildId:"+dormBuildId+
					" searchType:"+searchType+" keyword:"+keyword+"  pageIndex:"+pageIndex);
			
			//默认查询第一页,需两个参数,当前页码pageIndex,每页展示的条数  
			PageModel pageModel = new PageModel();
			if(pageIndex != null && !pageIndex.equals("")) {
				pageModel.setPageIndex(Integer.parseInt(pageIndex));
			}
			
			//分页查询考勤记录
			List<Record> records = recordService.findRecords(startDate,endDate,dormBuildId,
					searchType,keyword,userCurr,pageModel);
			System.out.println("records:"+records);
			
			//获取查询结果总数
			Integer totalNum = recordService.getToTalNum(startDate,endDate,dormBuildId,
					searchType,keyword,userCurr);
			System.out.println("totalNum:"+totalNum);
			
			request.setAttribute("totalNum", totalNum);
			request.setAttribute("startDate", startDate);
}
package com.demo.servlet;

/**
 * Servlet implementation class LoginServlet
 */
@WebServlet("/login")
public class LoginServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public LoginServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#service(HttpServletRequest request, HttpServletResponse response)
     */
    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        System.out.println("========登录=============");
        //Tomcat8.0 处理post请求乱码问题
        request.setCharacterEncoding("utf-8");
        //根据输入框标签的name属性值去获登录名和密码
        String stuCode = request.getParameter("stuCode");
        String password = request.getParameter("password");
        String remember = request.getParameter("remember");
        System.out.println("stuCode:" + stuCode + "  password:" + password + "   remember:" + remember);

        UserService userService = new UserServiceImpl();
        //去查询用户输入的登录名和密码是否正确
        User user = userService.findByStuCodeAndPass(stuCode, password);
			String keyword = request.getParameter("keyword");
			String pageIndex = request.getParameter("pageIndex");
			System.out.println("startDate:"+startDate+" endDate:"+endDate+" dormBuildId:"+dormBuildId+
					" searchType:"+searchType+" keyword:"+keyword+"  pageIndex:"+pageIndex);
			
			//默认查询第一页,需两个参数,当前页码pageIndex,每页展示的条数  
			PageModel pageModel = new PageModel();
			if(pageIndex != null && !pageIndex.equals("")) {
				pageModel.setPageIndex(Integer.parseInt(pageIndex));
			}
			
			//分页查询考勤记录
			List<Record> records = recordService.findRecords(startDate,endDate,dormBuildId,
					searchType,keyword,userCurr,pageModel);
			System.out.println("records:"+records);
			
			//获取查询结果总数
			Integer totalNum = recordService.getToTalNum(startDate,endDate,dormBuildId,
					searchType,keyword,userCurr);
			System.out.println("totalNum:"+totalNum);
			
			request.setAttribute("totalNum", totalNum);
			request.setAttribute("startDate", startDate);
			request.setAttribute("endDate", endDate);
			request.setAttribute("dormBuildId", dormBuildId);
			request.setAttribute("searchType", searchType);
			request.setAttribute("keyword", keyword);
			request.setAttribute("pageIndex", pageModel.getPageIndex());
			request.setAttribute("records", records);
			request.setAttribute("mainRight", "/WEB-INF/jsp/recordList.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
			
		}else if(action != null && action.equals("preAdd")) {
			//跳转到添加页面
			request.setAttribute("mainRight", "/WEB-INF/jsp/recordAddOrUpdate.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
			
		}else if(action != null && action.equals("save")) {
			//保存
			String stuCode = request.getParameter("stuCode");
			String date = request.getParameter("date");

/**
 * Servlet implementation class LoginOutServlet
 */
@WebServlet("/loginOut.action")
public class LoginOutServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public LoginOutServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

	/**
	 * @see HttpServlet#service(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		System.out.println("========退出==========");
		//清除保存在session中的用户信息
		request.getSession().removeAttribute("session_user");
		
		//清除保存在cookie中的用户信息
		//根据名字查找保存当前项目的学号和密码
		Cookie  cookie = CookieUtil.getCookieByName(request,"cookie_name_pass");
		if(cookie != null) {
			//设计cookie有效时间0 ,马上失效
			cookie.setMaxAge(0);
			//设置cookie作用范围
			cookie.setPath(request.getContextPath());
			System.out.println("request.getContextPath():"+request.getContextPath());
			//将cookie响应出去
			response.addCookie(cookie);
		}
		response.sendRedirect("index.jsp");
	}

}
package com.demo.util;

public class CookieUtil {

	public static void addCookie(String cookieName, int time, 
			HttpServletRequest request,HttpServletResponse response, 
			request.setAttribute("dormBuildId", dormBuildId);
			request.setAttribute("searchType", searchType);
			request.setAttribute("keyword", keyword);
			request.setAttribute("students", students);
			request.setAttribute("mainRight", "/WEB-INF/jsp/studentList.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
			
		}else if(action != null & action.equals("preAdd")) {
			//根据用户角色查询宿舍楼进行添加学生,
			//如当前用户 为宿舍管理员,他只能添加学生到其管理的宿舍楼
			
			//跳转到学生的添加页面
			request.setAttribute("mainRight", "/WEB-INF/jsp/studentAddOrUpdate.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
			
		}else if(action != null & action.equals("save")) {
			//保存学生
			String stuCode = request.getParameter("stuCode");
			String name = request.getParameter("name");
			String sex = request.getParameter("sex");
			String tel = request.getParameter("tel");
			String passWord = request.getParameter("passWord");
			String  dormBuildId= request.getParameter("dormBuildId");
			String dormCode = request.getParameter("dormCode");
			System.out.println("stuCode:"+stuCode+"  name:"+name+"   sex:"+sex+
					"  tel:"+tel+" passWord:"+passWord+" dormBuildId:"+dormBuildId+
					"  dormCode:"+dormCode);
			
			//未存在,则保存
			User student = userService.findByStuCode(stuCode);
			if(id != null && !id.equals("")) {
				//更新之前,查询数据库是否已经存在当前学号的学生,如已存在,则跳转到添加页面
				if(student != null  && !student.getId().equals(Integer.parseInt(id))) {
					System.out.println("根据学生学号查询student:"+student);
					//当前学号的学生已存在,请重新修改,跳转到该学生的修改页面
					request.getRequestDispatcher("/student.action?action=preUpdate&id="+id).forward(request, response);;
				}else {
					//更新
					User studentUpdate = userService.findById(Integer.parseInt(id));
					studentUpdate.setStuCode(stuCode);
					studentUpdate.setSex(sex);
					studentUpdate.setTel(tel);
					studentUpdate.setName(name);
					studentUpdate.setPassWord(passWord);
					studentUpdate.setDormBuildId(Integer.parseInt(dormBuildId));
					studentUpdate.setDormCode(dormCode);

/**
 * Servlet implementation class StudentServlet
 */
@WebServlet("/student.action")
public class StudentServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public StudentServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

	/**
	 * @see HttpServlet#service(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		System.out.println("=========student.action=============");
		
		//解决传递过来的中文乱码问题
		request.setCharacterEncoding("utf-8");
		String action = request.getParameter("action");
		//获取学生id
		String id = request.getParameter("id");
		String disabled = request.getParameter("disabled");
		
		//获取当前登录的用户
		User user = (User) request.getSession().getAttribute("session_user");
		Integer roleId = user.getRoleId();
		
		DormBuildService buildService = new DormBuildServiceImpl();
		}
	}

	private void roleJudgment(User user, HttpServletRequest httpServletRequest, ServletResponse response,
			FilterChain chain) throws IOException, ServletException {
		//获取用户角色id
		Integer  roleId = user.getRoleId();
		//获取请求地址  /DormTest/dormBuild.action

		String  requestUrI = httpServletRequest.getRequestURI();
		System.out.println("requestUrI:"+requestUrI);
		
		//动态获取项目名/DormTest
		String path = httpServletRequest.getContextPath();
		System.out.println("path:"+path);
		if( (requestUrI.startsWith(path+"/dormBuild.action") || requestUrI.startsWith(path+"/dormManager.action"))
				&& roleId.equals(0)) {
			//当用户发送的是宿舍楼管理模块或者宿舍管理员管理模块的请求时,只有在当前用户角色为超级管理员时才放行
			httpServletRequest.getSession().setAttribute("session_user", user);
			chain.doFilter(httpServletRequest, response);
			
		}else if(requestUrI.startsWith(path+"/student.action") && !roleId.equals(2)) {
			//当用户发送的请求是学生模块的请求时,只有当前用户角色不是学生就放行
			httpServletRequest.getSession().setAttribute("session_user", user);
			chain.doFilter(httpServletRequest, response);
			
		}else if(requestUrI.startsWith(path+"/record.action") ||
				requestUrI.startsWith(path+"/password.action")||
				requestUrI.startsWith(path+"/loginOut.action")||
				requestUrI.startsWith(path+"/index.action")) {
			//当用户发送的请求是考勤、修改密码、退出模块的请求时,不管用户的角色是什么,都放行
			httpServletRequest.getSession().setAttribute("session_user", user);
			chain.doFilter(httpServletRequest, response);
		}else {
			httpServletRequest.getRequestDispatcher("/index.jsp").forward(httpServletRequest, response);
		}
	}

	/**
	 * @see Filter#init(FilterConfig)
	 */
	public void init(FilterConfig fConfig) throws ServletException {
		// TODO Auto-generated method stub
	}

}
package com.demo.servlet;

					request.setAttribute("builds", builds);
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildList.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
					
				}
			}else {
				//保存
				if(dormBuild != null) {
					//当前用户输入的宿舍楼名已存在
					//表示跳转到宿舍楼添加页面
					request.setAttribute("error", "当前宿舍楼名已存在,请重新输入!");
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildAddOrUpdate.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
				}else {
					//当前用户输入的宿舍楼名不存在,则保存用户输入的信息到数据库
					DormBuild build = new DormBuild();
					build.setName(name);
					build.setRemark(remark);
					build.setDisabled(0);
					dormBuildService.save(build);
					//保存完成,跑到宿舍楼管理列表页,查询所有宿舍楼
					List<DormBuild>  builds  = dormBuildService.find();
					//查询所有的宿舍楼,在select中遍历
					List<DormBuild>  buildSelects = dormBuildService.find();
					request.setAttribute("buildSelects", buildSelects);
					request.setAttribute("builds", builds);
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildList.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
				}
			}
			
		}else if(action != null & action.equals("preUpdate")) {
			//根据宿舍楼id,查询宿舍楼
			DormBuild build = dormBuildService.findById(Integer.parseInt(id));
			//保存宿舍楼信息,到前端页面展示
			request.setAttribute("build", build);
			//跳转到宿舍楼修改页面
			request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildAddOrUpdate.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
		}else if(action != null & action.equals("deleteOrAcive")) {
			//删除或激活
			String disabled = request.getParameter("disabled");
			
			DormBuild  dormBuild = dormBuildService.findById(Integer.parseInt(id));
			System.out.println("更新前dormBuild:"+dormBuild);
			dormBuild.setDisabled(Integer.parseInt(disabled));
			System.out.println("更新后dormBuild:"+dormBuild);
		System.out.println("=========student.action=============");
		
		//解决传递过来的中文乱码问题
		request.setCharacterEncoding("utf-8");
		String action = request.getParameter("action");
		//获取学生id
		String id = request.getParameter("id");
		String disabled = request.getParameter("disabled");
		
		//获取当前登录的用户
		User user = (User) request.getSession().getAttribute("session_user");
		Integer roleId = user.getRoleId();
		
		DormBuildService buildService = new DormBuildServiceImpl();
		UserService userService = new UserServiceImpl();
		
		List<DormBuild>  builds = new ArrayList<DormBuild>();
		if(roleId.equals(0)) {
			//如当前用户是超级管理员,他能将学生添加到所有的宿舍楼,查询所有宿舍楼
			builds = buildService.findAll();
		}else if(roleId.equals(1)) {
			//如当前用户 为宿舍管理员,他只能添加学生到其管理的宿舍楼
			builds =  buildService.findByUserId(user.getId());
		}
		System.out.println("builds:"+builds);
		request.setAttribute("builds", builds);
		
		
		if(action != null & action.equals("list")) {
			//查询学生在右侧展示
			String dormBuildId = request.getParameter("dormBuildId");
			String searchType = request.getParameter("searchType");
			String keyword = request.getParameter("keyword");
			//当前要查询的页面
			String pageIndex = request.getParameter("pageIndex");
			System.out.println("dormBuildId:"+dormBuildId+"  searchType:"+searchType+"  keyword:"+keyword);
			
			//默认查询第一页,需两个参数,当前页码pageIndex,每页展示的条数  
			PageModel pageModel = new PageModel();
			if(pageIndex != null && !pageIndex.equals("")) {
				pageModel.setPageIndex(Integer.parseInt(pageIndex));
			}
			List<User> students = userService.findStudent(dormBuildId,searchType,keyword,user,pageModel);
			//获取查询处理的总数量
			Integer  totalNum = userService.findTotalNum(dormBuildId,searchType,keyword,user);
			System.out.println("totalNum:"+totalNum);
			System.out.println("students:"+students);
			
			request.setAttribute("totalNum", totalNum);
			request.setAttribute("pageIndex", pageModel.getPageIndex());
			request.setAttribute("dormBuildId", dormBuildId);
			request.setAttribute("searchType", searchType);
					request.setAttribute("error", "当前宿舍楼名已存在,请重新输入!");
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildAddOrUpdate.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
				}else {
					//当前用户输入的宿舍楼名不存在,则保存用户输入的信息到数据库
					DormBuild build = new DormBuild();
					build.setName(name);
					build.setRemark(remark);
					build.setDisabled(0);
					dormBuildService.save(build);
					//保存完成,跑到宿舍楼管理列表页,查询所有宿舍楼
					List<DormBuild>  builds  = dormBuildService.find();
					//查询所有的宿舍楼,在select中遍历
					List<DormBuild>  buildSelects = dormBuildService.find();
					request.setAttribute("buildSelects", buildSelects);
					request.setAttribute("builds", builds);
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildList.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
				}
			}
			
		}else if(action != null & action.equals("preUpdate")) {
			//根据宿舍楼id,查询宿舍楼
			DormBuild build = dormBuildService.findById(Integer.parseInt(id));
			//保存宿舍楼信息,到前端页面展示
			request.setAttribute("build", build);
			//跳转到宿舍楼修改页面
			request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildAddOrUpdate.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
		}else if(action != null & action.equals("deleteOrAcive")) {
			//删除或激活
			String disabled = request.getParameter("disabled");
			
			DormBuild  dormBuild = dormBuildService.findById(Integer.parseInt(id));
			System.out.println("更新前dormBuild:"+dormBuild);
			dormBuild.setDisabled(Integer.parseInt(disabled));
			System.out.println("更新后dormBuild:"+dormBuild);
			
			//执行更新
			dormBuildService.update(dormBuild);
			//更新完成,跑到宿舍楼管理列表页,查询所有宿舍楼
			List<DormBuild>  builds  = dormBuildService.find();
			//查询所有的宿舍楼,在select中遍历
			List<DormBuild>  buildSelects = dormBuildService.find();
			request.setAttribute("buildSelects", buildSelects);
			request.setAttribute("builds", builds);
			request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildList.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
		}
		
		
		if(action != null & action.equals("list")) {
			List<DormBuild>  builds = new ArrayList<DormBuild>();
			if(id == null || id.equals("")) {
				//点击左侧宿舍楼管理,查询所有宿舍楼信息,跳转到宿舍楼列表页
				builds = dormBuildService.find();
			}else if(id != null && !id.equals("")) {
				//点击搜索按钮搜索宿舍楼,根据宿舍楼id查询宿舍楼信息
				DormBuild  build = dormBuildService.findById(Integer.parseInt(id));
				builds.add(build);
			}
			
			//查询所有的宿舍楼,在select中遍历
			List<DormBuild>  buildSelects = dormBuildService.find();
			request.setAttribute("buildSelects", buildSelects);
			request.setAttribute("id", id);
			System.out.println("builds:"+builds);
			request.setAttribute("builds", builds);
			request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildList.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
			
		}else if(action != null & action.equals("preAdd")) {
			//表示跳转到宿舍楼添加页面
			request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildAddOrUpdate.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
			
		}else if(action != null & action.equals("save")) {
			//保存数据
			String name = request.getParameter("name");
			String remark = request.getParameter("remark");
			System.out.println("name:"+name+"  remark:"+remark);
			
			
			//宿舍楼名字不能重复,从数据库查询,当前用户输入的宿舍楼名字是否已经存在
			DormBuild  dormBuild = dormBuildService.findByName(name);
			System.out.println("dormBuild:"+dormBuild);
			
			if(id != null && !id.equals("")) {
				//更新
				if(dormBuild != null && !dormBuild.getId().equals(Integer.parseInt(id))) {
					//表示跳转到宿舍楼添加页面
					request.setAttribute("error", "当前宿舍楼名已存在,请重新输入!");
					
					//根据宿舍楼id,查询宿舍楼
					DormBuild build = dormBuildService.findById(Integer.parseInt(id));
					//保存宿舍楼信息,到前端页面展示
					request.setAttribute("build", build);
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildAddOrUpdate.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
				}else {
					dormBuild = dormBuildService.findById(Integer.parseInt(id));

/**
 * Servlet implementation class RecordServlet
 */
@WebServlet("/record.action")
public class RecordServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public RecordServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

	/**
	 * @see HttpServlet#service(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		System.out.println("====record.action========");
		
		//在tomcat8.0中,如果是post请求,传递过来的中文可能会出现乱码问题 
		request.setCharacterEncoding("utf-8");
		String action = request.getParameter("action");
		String id = request.getParameter("id");
		System.out.println("action:"+action+" recordId:"+id);
		
		//获取当前登录的用户
		User userCurr = (User) request.getSession().getAttribute("session_user");
				
			}else {
				//表示无修改权限,跳转到学生管理的列表页
				response.sendRedirect(getServletContext().getContextPath()+"/student.action?action=list");
			}
			
		}
			
	}
}

package com.demo.servlet;

/**
 * Servlet implementation class RecordServlet
 */
@WebServlet("/record.action")
public class RecordServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public RecordServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

	/**
	 * @see HttpServlet#service(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		System.out.println("===========dormManager.action==========");
		//在Tomcat8.0中解决post请求乱码问题
		request.setCharacterEncoding("utf-8");
		String action = request.getParameter("action");
		//宿舍管理员ID
		String id = request.getParameter("id");
		
		UserService userService = new UserServiceImpl();
		DormBuildService buildService = new DormBuildServiceImpl();
		
		//查询所有的宿舍楼并保存,以便在添加和修改宿舍管理员时在前端展示
		List<DormBuild>  builds = buildService.find();
		request.setAttribute("builds", builds);
		if(action != null & action.equals("list")) {
			//宿舍管理员查询
			String searchType = request.getParameter("searchType");
			String keyword = request.getParameter("keyword");
			System.out.println("searchType:"+searchType+"  keyword:"+keyword);
			
			//查询宿舍管理员
			List<User>  users = userService.findManager(searchType,keyword);
			
			request.setAttribute("searchType", searchType);
			request.setAttribute("keyword", keyword);
			request.setAttribute("users", users);
			request.setAttribute("mainRight", "dormManagerList.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
		}else if(action != null & action.equals("preAdd")) {
			//跳转到宿舍管理员添加页面
			request.setAttribute("mainRight", "dormManagerAddOrUpdate.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
			
		}else if(action != null & action.equals("save")) {
			System.out.println("======保存宿舍管理员=========");
			String name = request.getParameter("name");
			System.out.println("dormBuild:"+dormBuild);
			
			if(id != null && !id.equals("")) {
				//更新
				if(dormBuild != null && !dormBuild.getId().equals(Integer.parseInt(id))) {
					//表示跳转到宿舍楼添加页面
					request.setAttribute("error", "当前宿舍楼名已存在,请重新输入!");
					
					//根据宿舍楼id,查询宿舍楼
					DormBuild build = dormBuildService.findById(Integer.parseInt(id));
					//保存宿舍楼信息,到前端页面展示
					request.setAttribute("build", build);
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildAddOrUpdate.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
				}else {
					dormBuild = dormBuildService.findById(Integer.parseInt(id));
					dormBuild.setName(name);
					dormBuild.setRemark(remark);
					
					//执行更新
					dormBuildService.update(dormBuild);
					//更新完成,跑到宿舍楼管理列表页,查询所有宿舍楼
					List<DormBuild>  builds  = dormBuildService.find();
					//查询所有的宿舍楼,在select中遍历
					List<DormBuild>  buildSelects = dormBuildService.find();
					request.setAttribute("buildSelects", buildSelects);
					request.setAttribute("builds", builds);
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildList.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
					
				}
			}else {
				//保存
				if(dormBuild != null) {
					//当前用户输入的宿舍楼名已存在
					//表示跳转到宿舍楼添加页面
					request.setAttribute("error", "当前宿舍楼名已存在,请重新输入!");
					request.setAttribute("mainRight", "/WEB-INF/jsp/dormBuildAddOrUpdate.jsp");
					request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
				}else {
					//当前用户输入的宿舍楼名不存在,则保存用户输入的信息到数据库
			
			request.setAttribute("searchType", searchType);
			request.setAttribute("keyword", keyword);
			request.setAttribute("users", users);
			request.setAttribute("mainRight", "dormManagerList.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
		}else if(action != null & action.equals("preAdd")) {
			//跳转到宿舍管理员添加页面
			request.setAttribute("mainRight", "dormManagerAddOrUpdate.jsp");
			request.getRequestDispatcher("/WEB-INF/jsp/main.jsp").forward(request, response);
			
		}else if(action != null & action.equals("save")) {
			System.out.println("======保存宿舍管理员=========");
			String name = request.getParameter("name");
			String passWord = request.getParameter("passWord");
			String sex = request.getParameter("sex");
			String tel = request.getParameter("tel");
			//获取复选框中用户选中的宿舍楼
			String[] dormBuildIds = request.getParameterValues("dormBuildId");
			System.out.println("name:"+name+"  pass:"+passWord+"  sex:"+sex+"  tel:"+tel+"  dormBuildIds:"+Arrays.toString(dormBuildIds));
			
			if(id == null || id.equals("")) {
				//保存
				User user = new User(name, passWord, sex, tel, null, 1);
				user.setDisabled(0);
				
				//当前登录的用户
				User user2 = (User) request.getSession().getAttribute("session_user");
				user.setCreateUserId(user2.getId());
				
				userService.saveManager(user,dormBuildIds);
				System.out.println("getServletContext().getContextPath():"+getServletContext().getContextPath());
				
			}else {
				//修改
				//通过宿舍管理员ID获取宿舍管理员
				User user = userService.findById(Integer.parseInt(id));
				user.setName(name);
				user.setPassWord(passWord);
				user.setSex(sex);
				user.setTel(tel);
				userService.updateManager(user);
				
				//修改还需修改宿舍管理员与宿舍楼的中间表
				//① 删除当前宿舍管理员管理的所有宿舍楼
				buildService.deleteByUserId(user.getId());
				
				//② 新增当前宿舍管理员管理的所有宿舍楼  
				buildService.saveManagerAndBuild(user.getId(),dormBuildIds);
			}
			//跳转到宿舍管理员列表页,查看所有的宿舍管理员
			//重定向,请求链断开,不能在下一个servlet或jsp中获取保存在request中的参数
			response.sendRedirect(getServletContext().getContextPath()+"/dormManager.action?action=list");

请添加图片描述

请添加图片描述
请添加图片描述
请添加图片描述

基于JavaWeb的网上商城系统是一个通过Java编写的,使用JSPServletMySQLAjax等技术来构建的在线购物平台。该系统通过网络连接用户和商家,帮助用户浏览、选择和购买商品,同时也为商家提供了一个方便的销售平台。 该系统的主要功能包括商品展示、用户注册与登录、购物车管理、订单管理、支付和物流跟踪等。用户可以在系统中浏览各类商品,通过搜索或分类查找自己想要的产品,并将其加入购物车。用户还可以注册账号并登录系统,以便享受个性化的购物服务和更好的体验。 购物车管理模块允许用户对已选商品进行编辑、删除和结算操作,在结算时系统会自动计算商品的总价,并生成相应的订单。订单管理模块为用户提供查看订单、取消订单和评价订单等功能,同时商家也可以在系统中查看订单并进行发货操作。 为了保证交易的安全性,系统使用了支付和物流跟踪两个关键技术。支付模块允许用户选择不同的支付方式,并提供了安全的支付接口来完成交易。物流跟踪模块则通过整合物流公司的接口,让用户和商家可以实时追踪订单的配送状态。 总的来说,基于JavaWeb的网上商城系统提供了一套完整的购物解决方案,通过结合各种技术和模块,实现了商品展示、购物车管理、订单管理、支付和物流跟踪等功能,为用户和商家提供了一个便捷、安全的在线购物平台。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值