码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Session实现登录(springboot项目)


    Session实现登录(springboot项目)

    • 代码实现
      • 自定义一个拦截器
      • 注册拦截器
      • 登录接口
      • 业务接口,只有成功登录的用户才能访问
    • 测试
      • 直接访问业务接口。由于未登录,请求地址会被拦截,所以预期是不会返回“bussiness logic...”的
      • 登录
        • 登录失败
        • 登录成功
    • 注:以上只是利用了拦截器和session实现了最简单、最基本的功能,具体的业务根据实际情况进行添加、修改
    • 附:
      • 关于session

    代码实现

    自定义一个拦截器

    package com.xl.sessionlogin.interceptor;
    
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    import org.springframework.web.servlet.HandlerInterceptor;
    
    public class LoginInterceptor implements HandlerInterceptor {
    
    	@Override
    	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
    			throws Exception {
    		boolean result = false;
    		try {
    			result = (boolean)request.getSession().getAttribute("pass");
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    		if (result) {
    			return true; // 放行
    		}
    		return false; // 拦截
    	}
    	
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    注册拦截器

    package com.xl.sessionlogin.config;
    
    import org.springframework.context.annotation.Configuration;
    import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
    
    import com.xl.sessionlogin.interceptor.LoginInterceptor;
    
    /**
     * 	注册拦截器并添加配置
     * @author Administrator
     *
     */
    @Configuration
    public class MyConfig implements WebMvcConfigurer {
    
    	@Override
    	public void addInterceptors(InterceptorRegistry registry) {
    		registry.addInterceptor(new LoginInterceptor())
    				.addPathPatterns("/**") // 拦截所有
    				.excludePathPatterns("/login"); //排除该登录地址或添加其他
    		
    	}
    	
    	
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    登录接口

    package com.xl.sessionlogin.controller;
    
    import javax.servlet.http.HttpServletRequest;
    
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    @RequestMapping("/login")
    public class LoginController {
    	
    	@RequestMapping("")
    	public String login(HttpServletRequest request,String username, String password) {
    		String re = "login success.......";
    		
    		if (validateAccount(username,password)) { //验证通过
    			request.getSession().setAttribute("pass", true);
    		} else {
    			request.getSession().invalidate(); // 作废当前session
    			re = "login failed......";
    		}
    		return re;
    	}
    	
    	/**
    	 *  	验证账号
    	 * @param username
    	 * @param password
    	 * @return true:通过, false:不通过
    	 */
    	private boolean validateAccount(String username, String password) {
    		if (username.length() == password.length())
    			return true;
    		return false;
    	}
    	
    	
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39

    业务接口,只有成功登录的用户才能访问

    package com.xl.sessionlogin.controller;
    
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    @RequestMapping("/homepage")
    public class HomepageController {
    	
    	@RequestMapping("/logic")
    	public String busiLogic() {
    		
    		return "bussiness logic...";
    	}
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    测试

    启动项目,

    直接访问业务接口。由于未登录,请求地址会被拦截,所以预期是不会返回“bussiness logic…”的

    在这里插入图片描述

    登录

    登录失败

    在这里插入图片描述
    访问业务接口,因为登录失败,肯定是无法访问的

    在这里插入图片描述

    登录成功

    在这里插入图片描述
    访问业务接口,预期会返回字符串“bussiness logic…”
    在这里插入图片描述

    注:以上只是利用了拦截器和session实现了最简单、最基本的功能,具体的业务根据实际情况进行添加、修改

    附:

    关于session

    服务器可以为每个用户浏览器创建一个会话对象(session对象),一个浏览器只能产生一个session,当新建一个窗口访问服务器时,还是原来的那个session。session中默认保存的是当前用户的信息。因此,在需要保存其他用户数据时,我们可以自己给session添加属性。session(会话)可以看为是一种标识,通过带session的请求,可以让服务器知道是谁在请求数据。

    参考:https://blog.csdn.net/qq_29025955/article/details/126452582

  • 相关阅读:
    JavaScript数组有map方法,你知道shell怎么实现吗?
    货物从内地到香港的选择
    amber教程5.3:带非标准残基的绿色荧光蛋白的MD
    ios面试准备 - objective-c篇
    【docker】查看容器日志
    最新ACM Fellow名单发布,唐杰等4名中国大陆学者当选,中国机构入选人数排名第二
    Java 流处理之收集器
    Qt中定时器的所有使用方式
    使用DevExpress WPF主题设计器轻松创建Office 2019绿色主题(一)
    C++动态内存管理
  • 原文地址:https://blog.csdn.net/qq_29025955/article/details/126749029
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号