是什么
用户通过浏览器发送一个请求,Tomcat服务器接收这个请求,会给浏览器发送一个状态码302,并设置一个重定向的路径,浏览器如果接收到了这个302的状态码以后,就会去自动加载服务器设置的路径
一个页面跳转到另外一个页面(应用场景)、登录页面跳转到主页面: login.jsp====>LoginServlet====>main.jsp
特征:
①重定向的过程是浏览器(客户端)的行为 ②实际上浏览器做了2次请求(当点击登录按钮的时候做了两次请求)(分别是请求login和main.jsp) ③注意上一次请求的request对象会丢失 ④重定向有一个非常明显的特征,即浏览器的url变化
实例
编辑login.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
<%--请求RedirectServlet--%>
RedirectServlet类
public class RedirectServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//设置request的编码格式
req.setCharacterEncoding("UTF-8");
//前端提交的所有参数都会保存到HttpServletRequest中,可以通过input标签的name属性获取参数
String username = req.getParameter("username");
String password = req.getParameter("password");
System.out.println("username:"+ username +" password:"+ password);
//往request中添加属性:request继承了map
req.setAttribute("username", username);
req.setAttribute("password", password);
/**
* 重定向
* 本质:302 main.jsp
* 特点:览器发送两次请求的行为,url会变,会创建新的request对象
*/
resp.sendRedirect("main.jsp");
//main.jsp页面中可以取username和password参数吗?取不到,因为main.jsp是浏览器发送的第二次请求,该请求并未携带任何参数
//main.jsp页面中可以取msg属性吗?取不到,,因为main.jsp是浏览器发送的第二次请求,该请求会创建新的request对象
web.xml
redirect
com.by.servlet.RedirectServlet
redirect
/redirect
main.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
这是main页面
<%--
<%=request.getAttribute("username")%>
<%=request.getAttribute("password")%>
--%>
${username}
${password}
测试结果:
重定向
* 本质:302 main.jsp
* 特点:览器发送两次请求的行为,url会变,会创建新的request对象
main.jsp页面中可以取username和password参数吗?取不到,因为main.jsp是浏览器发送的第二次请求,该请求并未携带任何参数
main.jsp页面中可以取msg属性吗?取不到,,因为main.jsp是浏览器发送的第二次请求,该请求会创建新的request对象
是什么
用户发送数据请求到服务器,服务器接收当前请求,会调用内部方式(转发)处理该请求,最终把响应给客户端
特征:
①转发是服务器的行为 ②浏览器在这个过程中只有一次行为 ③转发可以带有数据 request对象中 ④url不会发生任何的变化
实例
login.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
<%--请求ForwardServlet--%>
ForwardServlet
public class ForwardServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//设置request的编码格式
req.setCharacterEncoding("UTF-8");
//前端提交的所有参数都会保存到HttpServletRequest中,可以通过input标签的name属性获取参数
String username = req.getParameter("username");
String password = req.getParameter("password");
//往request对象中添加属性
req.setAttribute("username", username);
req.setAttribute("password", password);
//添加一个字符串
req.setAttribute("msg","getRequestDispatcher");
//转发:servlet内部行为(servlet1--->servlet2)
req.getRequestDispatcher("main.jsp").forward(req, resp);//request没有变
}
}
web.xml
forward
com.by.servlet.ForwardServlet
forward
/forward
main.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
这是main页面
${username}
${password}
测试
转发
本质:servlet内部的行为(servlet1---->servlet2)
特点:
浏览器url不变
还是原来的request对象,数据不丢失