SpringBoot集成security(1)|(security入门)


文章目录

  • SpringBoot集成security(1)|(security入门)
    • @[TOC]
  • 前言
  • 一、Spring Security是什么?
  • 二、security集成springboot
    • 1.依赖引入
    • 2.编写测试接口
    • 3.服务启动日志分析
    • 4.调用接口验证
    • 5.用户配置
  • 总结

章节
第一章链接: SpringBoot集成security(1)|(security入门)
第二章链接: SpringBoot集成security(2)|(security自定义配置)
第三章链接: SpringBoot集成security(3)|(security的前后端分离登录以及响应处理)
第四章链接: SpringBoot集成security(4)|(security基于JWT实现前后端分离自定义登录)

前言

最近项目上经常遇到需要对接第三方登录认证、授权第三方等问题,本着一劳永逸的心里,决定攻克一下springsecurity知识点,本系列文章将会介绍springsecurit从入门到深入了解,并能够在项目中实际运用。本系列文章大致分为几个阶段,第一阶段了解security,第二阶段实现在springboot中集成登录,第三阶段接入Oauth2、JWT,第四阶段实现第三方授权登录等。

一、Spring Security是什么?

Spring Security是一个提供身份验证,授权和保护以防止常见攻击的框架。凭借对命令式和响应式应用程序的一流支持,它是用于保护基于Spring的应用程序的事实上的标准。Spring Security 是针对Spring项目的安全框架,也是Spring Boot底层安全模块默认的技术选型,他可以实现强大的Web安全控制,对于安全控制,我们仅需要引入 spring-boot-starter-security 模块,进行少量的配置,即可实现强大的安全管理

二、security集成springboot

1.依赖引入

第一步需要引入springboot以及security相关依赖,其他依赖例如swagger、lombok等一些工具依赖没有放上来

 <!--springboot相关依赖--><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.5.7</version><relativePath/></parent><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--security引入--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId></dependency>

2.编写测试接口

提供一个测试接口用于验证security

@Api(tags = {"演示相关接口"})
@RestController
@RequestMapping("/demo")
public class DemoCtrl {@ApiOperation(value = "获取接口", notes = "获取接口")@GetMapping(value = "/get")public ResponseHandle success() {return ResponseHandle.SUCCESS("获取数据成功");}}

3.服务启动日志分析

1、springboot服务集成之后日志会打印一个Using generated security password: 7e2cf26c-1bff-4e27-9278-f5314c2f1f79,这个密码就是security的user用户默认的密码,每次启动都会改变

2、还会打印一个DefaultSecurityFilterChain信息,该信息表示引入security依赖后springboot会默认加载一个springsecurity的过滤器链,该默认的过滤器会阻止没有认证的访问请求

4.调用接口验证

在浏览器访问接口http://localhost:8080/demo/get,会跳转到http://localhost:8080/login页面,在登录页面输入user用户以及控制台打印的默认密码,会显示访问成功。

5.用户配置

实际使用的时候默认用户密码是变动的,这肯定不符合我们的要求,是否有其他方式来初始化用户呢?于是翻阅了文档,security提供了多种用户配置,下面我们来介绍当前简单模式下的简单配置,在yml配置文件中添加如下配置

spring:security:user:name: adminpassword: 123456roles: admin

结果:重启服务,日志没有打印默认密码,访问还是会跳到登录页,这个时候输入配置的用户密码即可访问

总结

到此springboot集成了security,并且security已经能够安全的保护我们的接口不被无认证请求访问。并且能够配置用户。

第一章链接: SpringBoot集成security(1)|(security入门)
第二章链接: SpringBoot集成security(2)|(security自定义配置)
第三章链接: SpringBoot集成security(3)|(security的前后端分离登录以及响应处理)
第四章链接: SpringBoot集成security(4)|(security基于JWT实现前后端分离自定义登录)

SpringBoot集成security(1)|(security入门)相关推荐

  1. SpringBoot集成beetl模板快速入门

    SpringBoot集成beetl模板快速入门 本文引导 SpringBoot集成beetl模板快速入门 创建SpringBoot工程(idea) 新建工程 修改maven本地仓库位置 配置Sprin ...

  2. Springboot 集成Springcloud gateway的入门

    最近做项目使用到了springcloude gateway作为网关,因此在此记录下springcloud gateway的入门操作,后续再将源码解读写出来,先立个flag. 回归正题,Springcl ...

  3. springboot集成flowable简单实例入门

    此案例是demo.功能有创建流程.完成审批.生成流程图.适合有java基础的人员看. 第一步.画流程图 resources资源包下,新建processes包,新建一个文件,我命名他apply-rest ...

  4. SpringBoot集成Spring Security —— 第二章自动登录

    文章目录 一.修改login.html 二.两种实现方式 2.1 Cookie 存储 2.2 数据库存储 2.2.1 基本原理 2.2.2 代码实现 三.运行程序 在上一章:SpringBoot集成S ...

  5. SpringBoot集成Spring Security(2)——自动登录

    在上一章:SpringBoot集成Spring Security(1)--入门程序中,我们实现了入门程序,本篇为该程序加上自动登录的功能. 文章目录 一.修改login.html 二.两种实现方式 2 ...

  6. SpringBoot集成Spring Security(二)注册 、密码加密、修改密码

    SpringBoot集成Spring Security(一)登录注销 写在前面 上一节创建了项目并且利用Spring Security完成了登录注销功能,这里继续说一下注册.密码加密和找回密码,代码注 ...

  7. SpringBoot集成Spring Security(一)登录注销

    同个人网站 https://www.serendipper-x.cn/,欢迎访问 ! SpringBoot集成Spring Security(二)注册 .密码加密.修改密码 写在前面 Spring S ...

  8. springboot集成Spring Security oauth2(八)

    由于公司项目需要,进行SpringBoot集成Spring Security oauth2,几乎搜寻网上所有大神的案例,苦苦不能理解,不能完全OK. 以下是借鉴各大神的代码,终于demo完工,请欣赏 ...

  9. springboot集成security

    接着上一篇( springboot 集成mybatis)继续搞,接下来集成security 首先还是添加pom依赖 <dependency><groupId>org.sprin ...

最新文章

  1. rsync+innotify实现实时同步
  2. Centos 安装Docker
  3. 隐马尔可夫(HMM)、前/后向算法、Viterbi算法
  4. android SQLite数据库的使用
  5. list取数据_Day.5利用Pandas做数据处理(二)
  6. 六种方式实现生产者消费者(未完)
  7. drools规则引擎技术指南_物联网规则引擎技术
  8. 作者:曹玉社(1990-),男,国防科学技术大学并行与分布处理重点实验室硕士生...
  9. Java案例:使用clone()方法克隆对象
  10. 前端会有什么新的变化
  11. 云架构化-设计理念参考
  12. Linux 2.6.19.x 内核编译配置选项简介
  13. 计算机软件实习每日学习打卡(1)20201130
  14. [教程] ESP32+TFT+分光棱镜实现透明小电视
  15. 直接添加集合对象Arrays.asList()
  16. c语言原子操作实例,多CPU上的原子操作
  17. [4G5G专题-89]:流程 - 4G LTE终端在网络侧不同设备中的状态
  18. 优雅的点(2017网易校园招聘)---最详细的解答
  19. trs 同步模版 栏目修改(高级)
  20. mybatis 多表连接查询,万能map

热门文章

  1. 蓝桥杯13-20届真题答案和解析(Java 大学 B 组)2013年省赛真题3_振兴中华
  2. 计算机计划300字作文,计划作文300字4篇
  3. Java常用的Linux命令
  4. 服务器在bios下也自动关机,十大常见的内存BIOS故障现象及解决方案
  5. 智慧楼宇中的“黑科技”
  6. 调查电视节目受欢迎程度 (15分)
  7. FOC之PLL锁相环
  8. 再看穆里尼奥与C罗的交恶史
  9. 学python最好的方式是什么意思_通过5个步骤以正确的方式学习Python
  10. Yocto--书籍、网站、较好博文