返回顶部
首页 > 资讯 > 后端开发 > JAVA >SpringBoot + layui 框架实现一周免登陆功能
  • 315
分享到

SpringBoot + layui 框架实现一周免登陆功能

springbootlayui一周免登陆 2023-09-04 14:09:36 315人浏览 八月长安
摘要

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识

在这里插入图片描述

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。
🍎个人主页:Java Fans的博客
🍊个人信条:不迁怒,不贰过。小知识,大智慧。
💞当前专栏:SpringBoot 框架从入门到精通
✨特色专栏:国学周更-心性养成之路
🥭本文内容:SpringBoot + layui 框架实现一周免登陆功能

在这里插入图片描述
要实现一周免登录功能,您可以使用Spring Boot和Layui框架配合完成。以下是一种可能的实现方式:

创建一个名为User的实体类,用于表示用户信息,其中包含用户的用户名和密码等字段,以及用于标记用户是否选择一周免登陆的rememberMe字段。

@Entity@Table(name = "users")public class User implements Serializable {    @Id    @GeneratedValue(strategy = GenerationType.IDENTITY)    private Long id;    @Column(unique = true, nullable = false)    private String username;    @Column(nullable = false)    private String passWord;    private boolean rememberMe;    // Getters and Setters    // ...}

创建一个名为UserRepository的接口,用于对User实体进行数据库操作。

@Repositorypublic interface UserRepository extends JpaRepository<User, Long> {    User findByUsername(String username);}

创建一个名为UserService的服务类,用于处理用户相关的业务逻辑。在这个类中,添加一个方法用于验证用户的登录,并根据用户是否选择一周免登陆来设置相关的Cookie。

@Servicepublic class UserService {    private UserRepository userRepository;    @Autowired    public void setUserRepository(UserRepository userRepository) {        this.userRepository = userRepository;    }    public boolean login(String username, String password, boolean rememberMe, httpservletResponse response) {        User user = userRepository.findByUsername(username);        if (user != null && user.getPassword().equals(password)) {            if (rememberMe) {                // 设置一周免登陆的Cookie,有效期为7天                Cookie cookie = new Cookie("rememberMe", "true");                cookie.setMaxAge(7 * 24 * 60 * 60);  // 7天的秒数                cookie.setPath("/");                response.addCookie(cookie);                user.setRememberMe(true);                userRepository.save(user);            }            return true;        }        return false;    }}

创建一个名为LoginController的控制器类,用于处理用户登录的请求。

@Controllerpublic class LoginController {    private UserService userService;    @Autowired    public void setUserService(UserService userService) {        this.userService = userService;    }    @RequestMapping("/login")    public String login(String username, String password, boolean rememberMe, HttpServletResponse response) {        if (userService.login(username, password, rememberMe, response)) {            return "redirect:/home";  // 登录成功后跳转到主页        }        return "redirect:/login?error";  // 登录失败跳转回登录页面,并带上错误参数    }}

在对应的登录页面中使用Layui框架的表单组件,将用户名、密码和记住我选项组织成一个表单,并向LoginController的登录请求发送POST请求。

DOCTYPE html><html><head>    <title>登录title>        <link rel="stylesheet" href="https://cdn.staticfile.org/layui/2.5.4/CSS/layui.min.css">    <script src="https://cdn.staticfile.org/layui/2.5.4/layui.min.js">script>head><body>    <div class="layui-container">        <fORM class="layui-form" action="/login" method="post">            <div class="layui-form-item">                <label class="layui-form-label">用户名label>                <div class="layui-input-block">                    <input type="text" name="username" lay-verify="required" autocomplete="off" placeholder="请输入用户名" class="layui-input">                div>            div>            <div class="layui-form-item">                <label class="layui-form-label">密码label>                <div class="layui-input-block">                    <input type="password" name="password" lay-verify="required" autocomplete="off" placeholder="请输入密码" class="layui-input">                div>            div>            <div class="layui-form-item">                <div class="layui-input-block">                    <input type="checkbox" name="rememberMe" title="记住我" lay-skin="primary">                    <button class="layui-btn" lay-submit lay-filter="formDemo">登录button>                div>            div>        form>    div>    <script>        layui.use(['form'], function() {            var form = layui.form;            // 表单验证            form.verify({                required: function(value, item) {                    if(value.length < 1) {                        return '该项不能为空';                    }                }            });            // 监听表单提交            form.on('submit(formDemo)', function(data) {                // 获取表单数据并提交                var username = data.field.username;                var password = data.field.password;                var rememberMe = data.field.rememberMe === 'on';                // 发送ajax请求提交登录表单                $.ajax({                    url: '/login',                    type: 'POST',                    data: {                        username: username,                        password: password,                        rememberMe: rememberMe                    },                    success: function(res) {                        // 登录成功后的逻辑处理                        if (res.success) {window.location.href = '/home';                        } else {layer.msg(res.message, {icon: 2});                        }                    },                    error: function() {                        layer.msg('服务器错误', {icon: 2});                    }                });                return false; // 阻止表单提交            });        });    script>body>html>

在上述代码中,我们使用了Layui的form模块进行表单的验证和提交。form.verify()函数用于定义表单字段的验证规则,这里只提供了一个required规则作为示例。

form.on(‘submit(formDemo)’, function(data) {})函数用于监听表单提交事件,并在提交时使用AJAX发送登录请求。提交成功后,根据服务器的响应进行相应的处理。


  码文不易,本篇文章就介绍到这里,如果想要学习更多Java系列知识点击关注博主,博主带你零基础学习Java知识。与此同时,对于日常生活有困扰的朋友,欢迎阅读我的第四栏目《国学周更—心性养成之路》,学习技术的同时,我们也注重了心性的养成。

在这里插入图片描述

来源地址:https://blog.csdn.net/hh867308122/article/details/132225310

--结束END--

本文标题: SpringBoot + layui 框架实现一周免登陆功能

本文链接: https://lsjlt.com/news/393673.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • SpringBoot + layui 框架实现一周免登陆功能
    ✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识...
    99+
    2023-09-04
    springboot layui 一周免登陆
  • vue实现登陆功能
    本文实例为大家分享了vue实现登陆功能的具体代码,供大家参考,具体内容如下 最近在学习vue,发现了vue的好多坑,比如怎么更好的获取input框输入的值而减少获取dom节点的消耗 ...
    99+
    2024-04-02
  • flask框架实现修改密码和免密登录功能
    目录修改密码功能免密登录修改密码功能 数据库部分: #重置密码 def reset_pass(phone,password): conn,cursor=get_conn(...
    99+
    2024-04-02
  • VueelementUI实现免密登陆与号码绑定功能
    目录前言登录功能绑定/解绑功能获取用户信息功能获取用户信息功能最终效果项目地址前言 前端代码的框架采用vue.js + elementUI 这套较为简单的方式实现,以及typescr...
    99+
    2022-11-13
    Vue elementUI免密登陆 Vue elementUI号码绑定
  • flask框架如何实现修改密码和免密登录功能
    这篇文章将为大家详细讲解有关flask框架如何实现修改密码和免密登录功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。修改密码功能数据库部分:#重置密码def reset_pass(phone,...
    99+
    2023-06-15
  • nodejs实现登陆验证功能
    本文实例为大家分享了nodejs实现登陆验证的具体代码,供大家参考,具体内容如下 登陆验证需要提交数据,一种使用form表单提交数据,另一种使用原生js提交数据 form表单提交 搭...
    99+
    2024-04-02
  • Node.js实现登陆注册功能
    本文实例为大家分享了Node.js实现登陆注册的具体代码,供大家参考,具体内容如下 1.服务器端 在项目里创建一个json文件用来存储数据,通过express创建服务器对象,fs模块...
    99+
    2024-04-02
  • JS实现layui table筛选框记忆功能
    碰到表中列很多如下表 使用layui table的筛选功能.选完之后呢,关掉浏览器再打开或者换个页面再打开的时候,选择就白选了.这种情况下,客户就要求加个记忆功能.让她下次再打开...
    99+
    2024-04-02
  • 怎么使用thinkphp框架实现登录功能
    这篇文章主要介绍“怎么使用thinkphp框架实现登录功能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用thinkphp框架实现登录功能”文章能帮助大家解决问题。第一步:创建登录页面首先,需...
    99+
    2023-07-05
  • springboot+vue实现登录功能
    本文实例为大家分享了springboot+vue实现登录功能的具体代码,供大家参考,具体内容如下 目录结构 前端端口:8080 后端端口:8900 login.vue <...
    99+
    2024-04-02
  • vue+springboot实现登录功能
    本文实例为大家分享了vue+springboot实现登录功能的具体代码,供大家参考,具体内容如下 1. 登录功能的实现 实现提交表单的代码如下: async submitForm...
    99+
    2024-04-02
  • Java Web实现自动登陆功能
    Java对自动登陆功能的简单实现,仅用到了servlet和一个filter。第一次写博文,如有不足的地方,敬请指正,谢谢。 登陆界面 <%@ page language="...
    99+
    2024-04-02
  • js实现登陆与注册功能
    本文实例为大家分享了js实现登陆与注册功能的具体代码,供大家参考,具体内容如下 1、首先在phpstudy文件中寻找到一个文件名叫 “www” 的文件  在里面创建html...
    99+
    2024-04-02
  • Android AndBase框架实现多功能标题栏(一)
    本文是针对AndBase框架学习整理的第一篇笔记,想要了解AndBase框架的朋友可以阅读本文,大家共同学习。 1.使用AndBase实现多功能标题栏 AndBase框架内部提...
    99+
    2022-06-06
    标题栏 Android
  • PHP用Session实现用户登陆功能
    目录一、启动 Session 会话,并创建一个 $admin 变量:二、验证提交数据三、判断是否登陆:四、如果要登出系统怎么办?销毁 Session 即可。五、设置生存周期对比起Co...
    99+
    2022-12-22
    php登录 session用户登陆
  • PHP怎么实现用户登陆功能
    本篇内容主要讲解“PHP怎么实现用户登陆功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP怎么实现用户登陆功能”吧!一.简介由于 Session 是以文本文件形式存储在服务器端的,所以不怕...
    99+
    2023-06-03
  • nodejs怎么实现登陆验证功能
    这篇文章主要介绍“nodejs怎么实现登陆验证功能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“nodejs怎么实现登陆验证功能”文章能帮助大家解决问题。登陆验证需要提交数据,一种使用form表单提...
    99+
    2023-06-30
  • SpringBoot实现滑块验证码验证登陆校验功能详解
    目录前言一、实现效果二、实现思路三、实现步骤1. 后端 java 代码1.1 新建一个拼图验证码类1.2 新建一个拼图验证码工具类1.3 新建一个 service 类1.4 新建一个...
    99+
    2024-04-02
  • java实现文件夹上传功能实例代码(SpringBoot框架)
    目录前言一、前端如何设置上传组件并将资源上传到后台服务1)首先我们需要新建一个用来提交文件夹的form表单2)然后我们添加自己框架内的一些按钮来触发该隐藏的表单二、后台如何接收处理文...
    99+
    2023-05-14
    springboot文件夹上传 springboot 文件上传 上传文件 springboot
  • Jetpack Compose 实现一个图片选择框架功能
    目录获取图片拍照策略NothingCaptureStrategyFileProviderCaptureStrategyMediaStoreCaptureStrategy总结拍照权限取...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作