1、JSP页面代码

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" type="text/css" href="./css/login/normalize.css" />
<link rel="stylesheet" type="text/css" href="./css/login/demo.css" /> <link rel="stylesheet" type="text/css" href="./css/login/component.css" />
<title>登录</title>
</head>
<body>
<body>
<div class="container demo-1">
<div class="content">
<div id="large-header" class="large-header">
<canvas id="demo-canvas"></canvas>
<div class="logo_box">
<h3>登录</h3>
<form action="${pageContext.request.contextPath }/login/loginyy" name="f" method="post">
<div class="input_outer">
<span class="u_user"></span>
<input id="username" name="username" value="" class="text" style="color: #FFFFFF !important" type="text" placeholder="请输入账户">
</div>
<div class="input_outer">
<span class="us_uer"></span>
<input id="password" name="password" value="" class="text" style="color: #FFFFFF !important; position:absolute; z-index:100;" type="password" placeholder="请输入密码">
</div>
<div class="mb2">
<!-- <a class="act-but submit" href="${pageContext.request.contextPath }/login/loginyy" style="color: #FFFFFF"> -->
<input class="text" type="submit" value="登录" style="color: #FFFFFF">
</a>
</div>
</form>
</div>
</div>
</div>
</div><!-- /container -->
<script src="./js/login/TweenLite.min.js"></script>
<script src="./js/login/EasePack.min.js"></script>
<script src="./js/login/rAF.js"></script>
<script src="./js/login/demo-1.js"></script>
<div style="text-align:center;">
</div>
</body>
</html>

2、创建登录用户User实体类

package com.chao.entity;

public class User {
private String username;
private String password; public String getUsername() {
return this.username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return this.password;
} public void setPassword(String password) {
this.password = password;
}
}

3、mysql数据库连接池

package com.chao.utils;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException; public class DBUtil {
private String dbUrl = "jdbc:mysql://数据库ip地址:3306/login";
private String dbUserName = "数据库用户名";
private String dbPassword = "数据库登录密码";
private String jdbcName = "com.mysql.cj.jdbc.Driver"; public Connection getCon() throws ClassNotFoundException, SQLException {
Class.forName(this.jdbcName);
Connection con = DriverManager.getConnection(this.dbUrl, this.dbUserName, this.dbPassword);
return con;
} public void closeCon(Connection con) throws SQLException {
if (con != null)
con.close();
}
}

4、登录代码实现

package com.chao.controller;

import com.chao.entity.User;
import com.chao.utils.DBUtil;
import com.chao.utils.StringUtil;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping; @Controller
@RequestMapping({ "login" })
public class LoginController {
@RequestMapping
public String toLoginIndex(Model model) {
return "login";
} @RequestMapping({ "loginyy" })
public void toLogin(HttpServletRequest request, HttpServletResponse response) {
User user = new User();
String username = request.getParameter("username");
String password = request.getParameter("password"); user.setUsername(username);
user.setPassword(password);
System.out.println("----------------" + username + "--" + password + "---------------"); if ((StringUtil.isEmpty(password)) || (StringUtil.isEmpty(username))) {
HttpSession session = request.getSession();
session.setAttribute("error", "不能为空");
try {
response.sendRedirect(request.getContextPath() + "/login");
} catch (IOException e) {
e.printStackTrace();
}
System.out.println("---------kong----------");
return;
} DBUtil db = new DBUtil();
String sql = "select username from users where username='" + user.getUsername() + "'";
String sql1 = "select password from users where password='" + user.getPassword() + "'";
try {
Statement stmt = db.getCon().createStatement();
Statement stmt1 = db.getCon().createStatement();
ResultSet rs = stmt.executeQuery(sql);
ResultSet rs1 = stmt1.executeQuery(sql1); if ((rs.next()) && (rs1.next())) {
HttpSession session = request.getSession();
session.setAttribute("currentUser", "登陆成功");
response.sendRedirect("/file");
} else {
System.out.println("-------用户名或密码错误-----"); HttpSession session = request.getSession();
session.setAttribute("error", "错误");
session.setAttribute("username", username);
session.setAttribute("password", password); response.setCharacterEncoding("GB2312");
PrintWriter out = response.getWriter();
out.print("<script>alert('用户名或密码错误,请重新输入!'); window.location='/login' </script>");
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}

5、JSP页面直接跳转拦截验证

<%
if(null==session.getAttribute("currentUser")){
System.out.print("ddd");
response.sendRedirect("/login");
return;
}else{
System.out.print("yyy");
}
%>

6、退出界面代码实现

package com.chao.controller;
import javax.servlet.http.HttpSession;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping; @Controller
@RequestMapping({ "quit" })
public class QuitController {
@RequestMapping
public String outLogin(HttpSession session) {
// 通过session.invalidata()方法来注销当前的session
session.invalidate();
return "login";
}
}

前端JSP页面代码

<form action="${pageContext.request.contextPath}/quit" method="post">
<table align="right">
<tr><td>
<input type="submit" value="退出登录">
</td></tr>
</table>
</form>

Java-JSP页面实现简单登录退出(菜鸟一枚、仅供参考)的更多相关文章

  1. JAVA语言程序设计课后习题----第五单元解析(仅供参考)

    1 本题是水题,题目要求你求最大值.最小值,建议你用Arrays.sort函数进行排序,最大值.最小值就可以确定了 import java.util.Arrays; import java.util. ...

  2. JAVA语言程序设计课后习题----第三单元解析(仅供参考)

    1 本题水题,记住要知道输入格式即可 import java.util.Scanner; public class test { public static void main(String[] ar ...

  3. JAVA语言程序设计课后习题----第八单元解析(仅供参考)

    1 本题主要考的是方法的克隆,与c++里面的拷贝有点相似,具体看书本p147 import java.util.Objects; public class Square implements Clon ...

  4. JAVA语言程序设计课后习题----第七单元解析(仅供参考)

    1 本题水题,就是想让你理解继承的含义 public class Animaal { public double weight; public void eat(){ } } public class ...

  5. JAVA语言程序设计课后习题----第六单元解析(仅供参考)

    1 本题就是基本函数的用法 import java.util.Scanner; public class Poone { public static void main(String[] args) ...

  6. JAVA语言程序设计课后习题----第四单元解析(仅供参考)

    1 本题水题,主要理解题目的意思即可,访问方法和修改方法可以通过快捷方式alt+insert选中你需要的成员变量即可 public class Person { public String name; ...

  7. PHP简单登录退出代码

    PHP简单登录退出代码 登录页面login.html 负责收集用户填写的登录信息.  <html> <head> <title></title> < ...

  8. VSS的运用小内容(针对于vs2008版本)(小的问题都是,仅供参考--只针对于菜鸟级的)

    自己开始接触vss 的时候有些小的习惯没有很好的养成,下面的有关VSS内容都是简单的迁入迁出的问题,(仅供参考) 1.文件的迁入迁出:(.txt..xlsx..doc) a:文件的覆盖问题: 对于文件 ...

  9. JSP页面以及简单的指令

    —JSP(Java Server Pages)是指: —在HTML中嵌入Java脚本语言 —由应用服务器中的JSP引擎来编译和执行嵌入的Java脚本语言命令 —然后将生成的整个页面信息返回给客户端 页 ...

  10. Java jsp页面中jstl标签详解

    JSLT标签库,是日常开发经常使用的,也是众多标签中性能最好的.把常用的内容,放在这里备份一份,随用随查.尽量做到不用查,就可以随手就可以写出来.这算是Java程序员的基本功吧,一定要扎实. JSTL ...

随机推荐

  1. boost asio 网络编程案例简单改写

    boost教程:http://zh.highscore.de/cpp/boost/ 改写7.4网络编程案例,服务器支持连接多个客户端 服务端: #include <iostream> #i ...

  2. Spring Boot 开启后缀匹配模式

    项目原有 Java 配置为继承 WebMvcConfigurationSupport, 而WebMvcConfigurationSupport#requestMappingHandlerMapping ...

  3. 正整数n型方阵

    正整数n型方阵(不用数组完成) 一般呢这种n型方阵很多人都是用数组完成,今天呢小编就用简单的循环控制结构来完成,不需用到数组.题目:从键盘输入一个正整数n,根据n形成一个方阵.方阵最外层是第一层,每层 ...

  4. 日志参数 %n 引起的coredump

    今天测试发现一段代码 coredump,居然是一行日志输出.看参数都乱了,以为是内存溢出造成的.查了半天,也没发现问题 最后把前边的函数调用都注释掉,只运行这一段日志输出,依然挂掉 仔细一看: TRA ...

  5. 关于右值 std::move

    今天发现一个情况,对容器map 进行 std::move 之后,原map被清空了.     map<int, int> tmp;     tmp[1] = 1;     tmp[2] = ...

  6. AWS RedShift实战应用SQL大全及经验分享[持续更新]

    文章目录 前言 - 关于RedShift 一.数据维护篇 1.1 表结构操作 1.2 数据添加与查询 1.3 数据修改与删除 1.4 事物操作 二.SQL结构篇 2.1 使用with封装代码 2.2 ...

  7. 路由器、集线器、交换机分别工作在OSI七层协议模型的哪一层

    路由器三层(网络层): 集线器一层(物理层): 普通交换机二层(数据链路层). 现在也有工作在第三层的交换机. OSI七层网络模型由下至上为1至7层,分别为物理层(Physical layer),数据 ...

  8. RepVGG:一个结构重参数化网络

    ​  本文来自公众号"AI大道理" ResNet.DenseNet 等复杂的多分支网络可以增强模型的表征能力,使得训练效果更好.但是多分支的结构在推理的时候效率严重不足. 看起来二 ...

  9. C++ 函数类型和函数指针类型的自动推导、声明和赋值

    1.函数类型推导 #include <iostream> bool MyComp(int val1, int val2) { return val1 > val2; } int ma ...

  10. serializers序列化函数简单入门

    1. 创建Django项目和应用程序 首先,我们需要创建一个Django项目和一个Django应用程序.如果你已经有了Django项目和应用程序,请跳过这一步. $ django-admin star ...