通过Servlet跳转页面以及发送数据
2023.2.22
- 通过
HttpServletRequest
接口中getRequestDispatcher()
方法,传入一个字符串,返回一个RequestDispatcher
对象,该字符串是页面的路径;然后再调用forward()
方法,传入HttpServletRequest
和HttpServletResponse
对象进行跳转,需要传递的参数放在HttpServletRequest
对象中,前端jsp页面使用${}
进行接收:
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws
ServletException, IOException {
String username = new String();
String password = new String();
if (req.getParameter("username") != null && req.getParameter("password") != null) {
username = req.getParameter("username");
password = req.getParameter("password");
}
// 将参数传入req中
req.setAttribute("username", username);
req.setAttribute("password", password);
// 转发(转发时要将service的req和resp发送到新页面,仅仅在转发时可以拿到数据)
req.getRequestDispatcher("home.jsp").forward(req,resp);//链式编程
}
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>home</title>
</head>
<body>
接收到参数:<br>
${username}<br>
${password}
</body>
</html>
结果:
该方式适用于页面跳转,参数不会保存,直接输入目标地址不会带入参数
- 通过
HttpServletResponse
接口中sendRedirect()
方法,传入一个字符串,字符串可以是页面的路径,也可以是servlet的路径。使用该方法跳转时,需要传递的数据需要放在session
中,前端jsp中依旧使用${}
接收:
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 将参数传入session中
String username = new String();
String password = new String();
HttpSession session = req.getSession();
if (req.getParameter("username") != null && req.getParameter("password") != null) {
username = req.getParameter("username");
password = req.getParameter("password");
session.setAttribute("username", username);
session.setAttribute("password", password);
}
// 通过session去将数据转发到新页面,只能在同一个浏览器才能拿到数据,且数据保存时长为30分钟)
resp.sendRedirect("home.jsp");
}
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>home</title>
</head>
<body>
接收到参数:<br>
${username}<br>
${password}
</body>
</html>
结果:
该方式传递的参数即使直接输入地址也会保留,保留时间默认为30分钟