java jsp 跳转_JSP页面跳转方法大全

先来介绍一下在服务端JSP脚本中跳转页面的几种方法:

1. response.sendRedirct("跳转到页面");

该方法通过修改HTTP协议的HEADER部分,对浏览器下达重定向指令的,使浏览器显示重定向网页的内容. request无法传值过去.

执行完该页所有代码,然后再跳转到页面. 跳转地址栏改变.

可以跳转到其他服务器上的页面response.sendRedirct('https://www.jb51.net').

2.response.setHeader();

该方法和response.sendRedirect一样,通过修改HTTP协议的HEADER部分.

response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);

String newLocn="/index.html";

response.setHeader("Location",newLocn);

%>

3.

该方法是利用服务器端先将数据输出到缓冲区的机制,在把缓冲区的内容发送到客户端之前,原来的不发送,改为发送该页面的内容,如果在之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意.

request可以传值过去. 直接跳转到页面,后面的代码不执行. 跳转后地址栏不变. 无法跳转到其他服务器上的页面. 图片不是绝对路径无法显示.

4.request.getRequestDispatcher("跳转页面");

request可以传值过去. 执行完该页所有代码,然后再跳转到页面.

跳转地址栏不变. 不可以跳转到其他服务器上的页面

RequestDispatcher rd = request.getRequestDispatcher("jb51.jsp");

rd.forward(request,response);

%>

有以下3种方法可以做到输出重定向:

RESPONSE.SETREDERECT("URL")

该方法通过修改HTTP协议的HEADER部分,对浏览器下达重定向指令的,使浏览器显示重定向网页的内容.

response.sendRedirect("https://www.jb51.net/index.html");

2.下面的方法也能改变HTTP HEADER属性,它的原理和 1 是一样的.

response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);

String newLocn="/index.html";

response.setHeader("Location",newLocn);

% >

3.采用

该方法是利用服务器端先将数据输出到缓冲区的机制,在把缓冲区的内容发送到客户端之前,原来的不发送,改为发送该页面的内容,如果在之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意.

上面是在服务端利用JSP脚本的一些方法跳转,下面我们来看一下如何使用前端HTML,JS来做页面跳转

HTML语言的自动跳转

0是等待时间,如果设置为5表示等待5s后开始跳转

JavaScript跳转

第一种方法:

window.location.replace("https://www.jb51.net");

第二种方法:

window.location="https://www.jb51.net";

第三种方法:

document.location.href("https://www.jb51.net");

第四种方法:

history对象的back(),go()方法.go()方法需要一个整形入口参数

返回上一步

返回上一步

两者等价都是返回上一页

第五种方法:

document.formName.action="test.jsp";

document.formName.submit(); //使用JS提交的方式

此方法不推荐使用

第六种方法:

window.navigate("top.jsp");

其实利用JS跳转页面的方法还有很多,在这只列出了这几中,其它方法当你对JS有了基本了解后可以自由发挥你的想像了

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是回答: JavaWeb 登录检查及界面可分为以下几个步骤: 1. 创建登录页面:在 JSP 页面上布置输入用户名和密码的表单。 2. 创建 Servlet:用于接收登录表单提交的数据,并进行验证。 3. 校验用户名和密码:从表单提交的数据中获取用户名和密码,然后与数据库中的数据进行比对,如果验证通过,则将用户信息存入 Session 中。 4. 页面:如果用户信息验证通过,则至主页或其他需要登录才能访问的页面;如果验证不通过,则返回登录界面并给出错误提示。 以下是一个简单的示例: 1. 创建登录页面 login.jsp ``` <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Login</title> </head> <body> <form action="login" method="post"> <input type="text" name="username" placeholder="Username"><br> <input type="password" name="password" placeholder="Password"><br> <input type="submit" value="Login"> </form> </body> </html> ``` 2. 创建 Servlet LoginServlet ``` import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; @WebServlet("/login") public class LoginServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username = request.getParameter("username"); String password = request.getParameter("password"); if (username.equals("admin") && password.equals("123456")) { HttpSession session = request.getSession(); session.setAttribute("username", username); response.sendRedirect("index.jsp"); } else { response.sendRedirect("login.jsp?error=1"); } } } ``` 3. 在主页 index.jsp 中获取用户信息 ``` <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Index</title> </head> <body> <% HttpSession session = request.getSession(); String username = (String) session.getAttribute("username"); out.print("Welcome " + username); %> </body> </html> ``` 在上述示例中,我们通过 request.getParameter() 方法获取登录表单提交的数据,然后进行校验。如果校验通过,则将用户名存入 Session 中,并调用 response.sendRedirect() 方法至主页 index.jsp。如果校验不通过,则重定向至登录页面 login.jsp,并附带错误提示信息。 希望上述示例对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值