java.lang.IllegalStateException: Cannot forward after response has been committed异常

本文探讨了Java Web应用中登录阶段出现的IllegalStateException异常,该异常源于响应已提交后的页面转发操作。通过逐步分析代码并加入return语句解决了此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java.lang.IllegalStateException: Cannot forward after response has been committed

这个异常在我 登入的时候就有  而且页面还没有报错  这个 我真不懂 

protected void doPost(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException
			{	
		boolean isError=false;
		String username=req.getParameter(WebAttribute.ParameterOfUsername);
		String password=req.getParameter(WebAttribute.ParameterOfPssword);
		UserService service=new  SimpleUserService();
		try{
			User user=service.login(username, password);
			HttpSession session = req.getSession(false);
			if(session == null){
				req.getSession(true).setAttribute(WebAttribute.CURRENT_USER_SESSION_ATTRIBUTE, user);
			}else{
				session.setAttribute(WebAttribute.CURRENT_USER_SESSION_ATTRIBUTE, user);
			}	
			req.getRequestDispatcher("/WEB-INF/views/user/home.jsp").forward(req, resp);
			return;
		}catch(UsernameOrPasswordIsNullException e)
		{
			req.setAttribute(WebAttribute.VIEW_EXCEPTION_ATTRIBUTE,"账号或者密码不能为空");
			isError=true;
		}catch(UsernameNotFoundException e)
		{
			req.setAttribute(WebAttribute.VIEW_EXCEPTION_ATTRIBUTE,"密码错误");
			isError=true;
		}catch(UsernameMismatchPasswordException e)
		{
			req.setAttribute(WebAttribute.VIEW_EXCEPTION_ATTRIBUTE, "密码错误");
			isError=true;
		}
		catch(UserServiceException e)
		{
			req.setAttribute(WebAttribute.VIEW_EXCEPTION_ATTRIBUTE, "系统错误");
			isError=true;
		}finally
		{
			if(isError==true)
			{
				req.getRequestDispatcher("/index.jsp").forward(req, resp);
				return;
			}
		}




后来debug 后才知道  转发 是页面上执行的  所以后面的代码 加上return 就好了   因为 转发页面还在这,所以后面代码也会执行,系统就会报错。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值