Jsp&servlet中Dispatcher.forward和response.sendRedirect的区别

转发与重定向解析
本文对比了RequestDispatcher.forward()和response.sendRedirect()两种页面跳转方式的特点。forward()用于服务器内部跳转,能传递请求参数,但不能跳转至不同主机;sendRedirect()则在客户端实现跳转,支持跨域跳转并可携带参数。
RequestDispatcher.forward()是在服务器端起作用,当使用forward()时,Servlet engine传递HTTP请求从当前的Servlet or JSP到另外一个Servlet,JSP 或普通HTML文件,也即你的form提交至a.jsp,在a.jsp用到了forward()重定向至b.jsp,此时form提交的所有信息在b.jsp都可以获得,参数自动传递.
forward()无法重定向至有frame的jsp文件,可以重定向至有frame的html文件
同时forward()无法在后面带参数传递,比如servlet?name=frank,这样不行,可以程序内通过response.setAttribute("name",name)来传至下一个页面.
重定向后浏览器地址栏URL不变.
通常在servlet中使用,不在jsp中使用
response.sendRedirect()
是在用户的浏览器端工作,web服务器要求浏览器重新发送一个到被定向页面的请求
sendRedirect()可以带参数传递,比如servlet?name=frank传至下个页面,同时它可以重定向至不同的主机上
sendRedirect()可以重定向有frame.的jsp文件.
重定向后在浏览器地址栏上会出现重定向页面的URL
找出以下代码的错误并改正 package com.example.controller; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.annotation.*; import java.io.IOException; import java.sql.*; @WebServlet(name = "LoginServlet", value = "/login") public class LoginServlet extends HttpServlet{ // 数据库连接信息 private static final String JDBC_URL = "jdbc:mysql://localhost:3306/mywebapp?useSSL=false&serverTimezone=UTC"; private static final String JDBC_USER = "root"; private static final String JDBC_PASSWORD = "root"; // 替换成你的数据库密码 @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username = request.getParameter("username"); String password = request.getParameter("password"); boolean isValidUser = validateUser(username, password); if (isValidUser) { // 登录成功,将用户名存储在session中,并重定向到首页 HttpSession session = request.getSession(); session.setAttribute("username", username); response.sendRedirect("index.jsp"); } else { // 登录失败,设置错误信息并转发回登录页面 request.setAttribute("error", "用户名或密码错误!"); RequestDispatcher dispatcher = request.getRequestDispatcher("login.jsp"); dispatcher.forward(request, response); } } private boolean validateUser(String username, String password) { String sql = "SELECT * FROM user_table WHERE username = ? AND password = ?"; try (Connection conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD); PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setString(1, username); stmt.setString(2, password); try (ResultSet rs = stmt.executeQuery()) { return rs.next(); // 如果有记录返回true } } catch (SQLException e) { e.printStackTrace(); return false; } } }
06-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值