侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

jsp登陆校验演示 servlet、login、success

Java  /  管理员 发布于 7年前   207

jsp的登录校验Demo

part_1:login.jsp:登录页面:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%  String path = request.getContextPath();  String basePath = request.getScheme() + "://"  + request.getServerName() + ":" + request.getServerPort()  + path + "/"; %>  <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html>  <head>  <base href="https:/article/<%=basePath%>">   <title>My JSP 'Login.jsp' starting page</title>   <meta http-equiv="pragma" content="no-cache">  <meta http-equiv="cache-control" content="no-cache">  <meta http-equiv="expires" content="0">  <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">  <meta http-equiv="description" content="This is my page">  <!--  <link rel="stylesheet" type="text/css" href="https:/article/styles.css">  -->   </head>   <%  String fdbkMsg = (String) request.getAttribute("fdbkMsg");  if (null == fdbkMsg) {  fdbkMsg = "";  }  %>   <%  Boolean logedIn = (Boolean) session.getAttribute("logedIn");  if (null == logedIn) {  logedIn = false;  } else if (logedIn) {  //如果在本次会话已经登陆,直接重定向到success-page-1  response   .sendRedirect("/ServletDemoProject/LOGIN-DEMO/success-page-1.jsp");  }  %>   <%  String username = "";  Cookie[] cookies = request.getCookies();  if ((null != cookies) && (cookies.length > 0)) {  for (Cookie c : cookies) {  if ("admin".equals(c.getValue())) {   username = "admin";   break;  }  }  }//end if-condition  %>   <body>  <br>  <div align="center">  请登录:  <br>  <form action="/ServletDemoProject/servlet/LoginVerificationServlet"  method="post">  用户名:  <input type="text" name="username" value="<%=username%>" />  <br>  密 码:  <input type="password" name="password" value="" />  <br>  <font color='red'><%=fdbkMsg%></font>  <br>  <input type="submit" value="提交" />  <br>  </form>  </div>  </body> </html> 

part_2:LoginVerificationServlet.java:校验登录信息,此处没有连接数据库,默认只有username:admin,password:888888才算登录成功;登陆失败时:重新转发到Login.jsp并提示用户登陆失败,重新登陆;

package cn.mike.servlet.test_1209_Login;  import java.io.IOException;  import javax.servlet.ServletException; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;  public class LoginVerificationServlet extends HttpServlet {   private static final long serialVersionUID = -6886327892796230543L;   public void doGet(HttpServletRequest request, HttpServletResponse response)  throws ServletException, IOException {  String username = request.getParameter("username");  String password = request.getParameter("password");  if (("admin".equals(username)) && ("888888".equals(password))) {// 登录成功  // 保存cookie到客户端  Cookie userCookie = new Cookie("username", username);  userCookie.setMaxAge(60 * 2);// expiry : 2 minutes  response.addCookie(userCookie);  // 重定向到一个新的页面,并提示XXX用户登录成功(使用session存取用户名);  request.getSession().setAttribute("username", username);  request.getSession().setAttribute("logedIn", true);  response   .sendRedirect("/ServletDemoProject/LOGIN-DEMO/success-page-1.jsp");  } else {// 登陆失败  // 转发到登录界面,并提示错误信息:  request.setAttribute("fdbkMsg", "用户名或密码错误!");  request.getRequestDispatcher("/LOGIN-DEMO/Login.jsp").forward(   request, response);  }  }   public void doPost(HttpServletRequest request, HttpServletResponse response)  throws ServletException, IOException {   // do same as GET-method :  doGet(request, response);  }  } 

part_3:success-page-1.jsp:校验登录成功后重定向到该页面,提示用户已经成功登陆;如果用户试图通过不正当途径,e.g:从地址栏访问,将会转发到登录界面,并作提示;

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%  String path = request.getContextPath();  String basePath = request.getScheme() + "://"  + request.getServerName() + ":" + request.getServerPort()  + path + "/"; %>  <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html>  <head>  <base href="https:/article/<%=basePath%>">   <title>My JSP 'success-page-1.jsp' starting page</title>   <meta http-equiv="pragma" content="no-cache">  <meta http-equiv="cache-control" content="no-cache">  <meta http-equiv="expires" content="0">  <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">  <meta http-equiv="description" content="This is my page">  <!--  <link rel="stylesheet" type="text/css" href="https:/article/styles.css">  -->   </head>   <%  String username = (String) session.getAttribute("username");  if (null == username) {  //如果username为空值,说明不是通过正常渠道来的,转发到Login页面;  request.setAttribute("fdbkMsg", "别想走后门进来,赶紧登录!");  request.getRequestDispatcher("/LOGIN-DEMO/Login.jsp").forward(   request, response);  }  %>   <body>  <br>  <%=username%>已经成功登陆。  <br>  <font>您可以选择浏览:</font>  <br>  <a href="https:ServletDemoProject/LOGIN-DEMO/success-page-2.jsp">点这儿有精彩.</a>  <br>  <a href="https:ServletDemoProject/LOGIN-DEMO/success-page-2.jsp">点这儿更精彩.</a>  <br />  <a href="https:ServletDemoProject/LOGIN-DEMO/success-page-2.jsp">你敢点这儿吗.</a>  <br />  </body> </html> 

part_4:success-page-2.jsp:登陆成功页面2,如果已经登陆成功将用户名保存到session,在访问该页面时将会校验一下,防止从地址栏暴力访问;

<%@ page language="java" import="java.util.Date" pageEncoding="UTF-8"%> <%@ page language="java" import="java.text.SimpleDateFormat"%> <%  String path = request.getContextPath();  String basePath = request.getScheme() + "://"  + request.getServerName() + ":" + request.getServerPort()  + path + "/"; %>  <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html>  <head>  <base href="https:/article/<%=basePath%>">   <title>My JSP 'success-page-2.jsp' starting page</title>   <meta http-equiv="pragma" content="no-cache">  <meta http-equiv="cache-control" content="no-cache">  <meta http-equiv="expires" content="0">  <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">  <meta http-equiv="description" content="This is my page">  <!--  <link rel="stylesheet" type="text/css" href="https:/article/styles.css">  -->   </head>   <%  String username = (String) session.getAttribute("username");  if (null == username) {  request.setAttribute("fdbkMsg", "呵呵嗒,这里是你来的地方吗?快登陆!");  //转发到登录界面:  request.getRequestDispatcher("/LOGIN-DEMO/Login.jsp").forward(   request, response);  }   SimpleDateFormat sDateFormat = new SimpleDateFormat("a");  Date today = new Date();  String am_pm_str = sDateFormat.format(today);  String am_pm_str_in_chinese = "";  if ("am".equalsIgnoreCase(am_pm_str)) {  am_pm_str_in_chinese = "上午";  } else  am_pm_str_in_chinese = "下午";   // set null;  sDateFormat = null;  today = null;  am_pm_str = null;  %>   <body>  <br />  <font><b><%=username%><%=am_pm_str_in_chinese%>好,能来到页面2真不简单.</b>  </font>  </body> </html> 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    JSP实现登录功能之添加验证码
    下一条:
    jsp网页登陆验证
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在java中实现的脱敏工具类代码示例分享(0个评论)
    • zookeeper安装流程步骤(0个评论)
    • 在java中你背的“八股文”可能已经过时了(2个评论)
    • 在php8.0+版本中使用属性来增加值代码示例(3个评论)
    • java 正则表达式基础,实例学习资料收集大全 原创(0个评论)
    • 近期文章
    • 在go语言中实现字符串可逆性压缩及解压缩功能(0个评论)
    • 使用go + gin + jwt + qrcode实现网站生成登录二维码在app中扫码登录功能(0个评论)
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-11
    • 2018-03
    • 2020-03
    • 2023-05
    • 2023-11
    • 2024-01
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客