【JavaEE】实现用户登陆【实现登录的交互+获取主页的交互】

导读:本篇文章讲解 【JavaEE】实现用户登陆【实现登录的交互+获取主页的交互】,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

实现用户登陆【实现登录的交互+获取主页的交互】

登录的交互:

请求:POST/login HTTP/1.1

获取主页的交互

在这里插入图片描述

步骤

1. 先编写一个简单的登录页面——使用from表单来构造post请求

在这里插入图片描述
注意
在这里插入图片描述

2. 编写一个Servlet来处理这个登录请求

在这里插入图片描述

3. 编写服务器端返回主页的逻辑

在这里插入图片描述
在这里插入图片描述

页面

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

源代码

login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>登录</title>
</head>
<style>
     
	body {
		background-color: #8ea4f8;

		background-repeat: no-repeat;
		background-size: cover; 
 
	}
	.login_box {
		width: 400px;
		height: 400px;
		background-color: #fff;
		margin: auto;
		margin-top: 150px;
		border-radius: 5px;
		overflow: hidden;
        
        overflow:hidden;
	}
	.title {
		text-align: center;
		font-size: 28px;
		color: #000;
		margin-top: 80px;
		margin-bottom: 10px;
		letter-spacing: 3px;
		font-family: sans-serif;
	}
	.input_box {
		width: 300px;
		height: 30px;
		width: 300px;
		height: 40px;
		padding-left: 10px;
		margin-top: 20px;
		margin-left: 50px;
	}
	.button_box {
		width: 300px;
		height: 35px;
		width: 300px;
		height: 40px;
		margin-top: 20px;
		margin-left: 50px;
		border-radius: 5px;
		background-color: #64a9d9;
		cursor: pointer;
		color: #fff;
	}
	.logo_box {
		position: absolute;
		background-color: #fff;
		width: 100px;
		height: 100px;
		border-radius: 100px;
		top: 100px;
		left: 46%;
		border: solid 5px #A68364;
		text-align: center;
	}
	.logo_img {
		margin-top: 20px;
	}
</style>
<body>
    <form action="login" method="post">
    <div class="logo_box"></div>
	<div class="login_box">
		<h1 class="title">欢迎登录</h1>
		<input class="input_box" type="text" name="username" placeholder="用户名">
		<input class="input_box" type="password" name="password"  placeholder="密码">
		<input class="button_box" type="submit"  value="登录">
	</div>
</form>
</body>
</html>

LoginServlet

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;
import java.io.IOException;

@WebServlet("/login")
public class LoginServlet extends HttpServlet {

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //处理用户请求
        String username =req.getParameter("username");
        String password =req.getParameter("password");
        //判断用户名、密码是否正确
        //数据库存储的用户名 密码 是判断的依据 此处为了简单将用户名密码写死
        if ("zmy".equals(username)&&"0704".equals(password)){
            //登陆成功
            //创建会话并并保存必要的身份信息
            HttpSession httpSession = req.getSession(true);
            //往会话中存储键值对,必要的身份信息
            httpSession.setAttribute("username",username);
            resp.sendRedirect("index");
        }else{
            //登录失败
            resp.getWriter().write("login failed!");
        }

    }
}

IndexServlet

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;
import java.io.IOException;

@WebServlet("/index")
public class IndexServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //返回一个主页(主页是一个简单的html页面)
        //此处需要得到用户名是啥,从HTTP session中就能拿到
        //此处getSession的参数必须是false ,前面登录的时候创建过会话了,此处直接获取到之前的会话

        HttpSession session = req.getSession(false);
        String username =(String) session.getAttribute("username");
                resp.setContentType("text/html;charset=utf8");
        resp.getWriter().write("<h3>欢迎回来!"+username+"</h3>");

    }
}

拓展:实现登录次数

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
不断刷新
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/119527.html

(0)
seven_的头像seven_bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!