• 慕课网首页
  • 免费课
  • 实战课
  • 体系课
  • 慕课教程
  • 专栏
  • 手记
  • 企业服务
  • 猿问

我的购物车

已加入门课程

购物车里空空如也

快去这里选购你中意的课程

实战课

体系课

我的订单中心
去购物车
  • 登录 / 注册
抱歉,未找到你想要查询的结果
全部开发者教程

Spring Security

Spring Security 基础
Spring Security 简介 Spring Security 起步 Servlet 安全架构 Spring Security 安全过滤器 Spring Security 异常回收
Spring Security 认证
Spring Security 基本认证组件 Spring Security 用户名密码认证 OAuth2 集成社交网站认证 OAuth2 集成构造认证授权服务器 OAuth2 集成资源服务器 SAML2 认证集成 CAS 统一认证集成 集成JAAS认证 集成OPENID认证 实现记住我功能 实现预认证 集成X.509认证
Spring Security 鉴权
Spring Security 鉴权原理 Servlet 实现鉴权 访问控制表达式 安全对象实现 域对象安全
Spring Security 扩展
CSRF 保护 安全响应头 HTTP 协议安全 HTTP 访问限制 加密模块 单元测试
  • 前端开发

    JavaScript

    JavaScript 入门教程

    本教程带你从初级到高级全面掌握 Javascript 的使用方法

    TypeScript 入门教程

    这是一个很好的简单课程,只需2小时你就可以学习TypeScript基础知识。

    Vue 入门教程

    本教程带您从零开始学习 Vue 框架的使用,让您轻松应对 Vue 项目的开发。

    Ajax 入门教程

    本教程涵盖Ajax的实现原理,及Ajax封装,最后是框架实现方法。

    ES6-10 入门教程

    对比 ES5 进行学习 ES6+,理解 ES6+ 语法背后的思想

    Yarn 入门教程

    Yarn得相关基础知识和高级进阶

    ECharts 入门教程

    从零开始学习 ECharts ,掌握 ECharts 核心内容

    HTML & CSS

    CSS3 入门教程

    本课程从盒模型、文字、颜色、过渡、动画、布局、伪类等方面介绍 CSS3 的使用。

    雪碧图入门教程

    本文详细介绍了雪碧图的由来历史以及各种使用方式

    移动端布局教程

    由于移动互联网的兴起,移动端项目占据了很大一部分比重,本章将详细讲解几种常见布局

    Html5 入门教程

    最新一代的HTML标准,增加了许多实用的特性

    Sass 入门教程

    前端项目中 Sass 的快速入门教程

    HTML 入门教程

    从零讲解 HTML,掌握基础 HTML 知识内容

    canvas 入门教程

    本教程带你从初级到高级全面掌握canvas的使用方法

    uni-app 入门教程

    从零开始学习 uni-app 框架,轻松上手应用开发

  • 服务端相关

    服务器

    Nginx 入门教程

    本教程使您掌握 Nginx 安装、配置、核心模块的详解、实际使用的能力。

    HTTP 入门教程

    从协议原理开始到 Web 服务器以及 Web 安全一网打尽

    Docker 入门教程

    从 Docker 的基础概念开始,从实际问题入手带你学习 Docker

    Shell 入门教程

    本教程由浅入深,系统性的讲解Linux Shell脚本编程。

    Linux 入门教程

    本教程从安装 Linux 开始,囊括 Linux 基础命令操作以及进阶系统管理

    开发工具

    Gradle 入门教程

    本教程使您掌握实际使用gradle进行项目构建、测试、打包、发布的能力。

    Vim 编辑器教程

    课程主要讲解Vim的安装配置,四种模式、基本操作,以及包管理工具和寄存器等内容。

    RESTful 规范教程

    本教程从什么是 REST 开始带你领略 Web 开发中无处不在的规范

    Dreamweaver 教程

    DW 是一款同时具有网页制作和网页管理功能的网站开发工具,可以快速进行网站建设

    Markdown 入门教程

    本课程涵盖 Markdown 的基本及扩展语法。

    Maven 入门教程

    从最基础的安装 Maven 开始到 Maven 在开发中的实际应用

    Eclipse 编辑器教程

    本教程从Eclipse安装开始带你轻松掌握Eclipse常用开发技巧

    GitHub 入门教程

    本教程带你轻松掌握最实用的 GitHub 知识

    Android Studio 编辑器教程

    Android Studio 编程技巧一网打尽

    PyCharm 编辑器教程

    工作经常用到的 PyCharm 编辑器使用技巧一网打尽

    Sublime Text 使用教程

    花里胡哨展示sublime编辑器的各种功能

    Postman 教程

    Postman 由Google 开发用来做接口请求测试,前后端开发人员都可以使用

    Git入门教程

    从入门到精通。

    热门服务端语言

    C 语言入门教程

    本教程从语法基础、进阶知识等各方面详解 C 语言。

    Go 入门教程

    本教程从 Go 语言的基本语法掌握到进阶编程实践

    Kotlin 教程

    从 Kotlin 的基础语法到高级特性一网打尽

    Ruby 入门教程

    本教程从 Ruby 的各种对象开始学习到 Ruby 的实际使用

    ThinkPHP 入门教程

    本教程主要讲解 ThinkPHP 框架如何上手开发应用

  • Java

    基础应用

    Java 入门教程

    深入浅出讲解 Java 语言基础知识,带你入门 Java 语言

    Android 入门教程

    为你解析最实用的 Android 技术,让你平滑上手,顺利进阶,为开发保驾护航

    算法入门教程

    分析讲解常见算法的思想及使用

    数据结构入门教程

    通俗易懂的带你了解 Java 数据结构

    Lambda 表达式教程

    本教程展现了Lambda表达式的基础语法以及在程序中的应用

    Java 并发原理入门教程

    本教程为Java并发原理入门教程,在Java程序开发中占据着举足轻重的地位

    设计模式入门教程

    带你分析最常见的九个设计模式

    Java并发工具

    本课程简洁明了展示最基本的并发工具类相关概念及应用方法。

    JVM 入门教程

    JVM 入门教程,对JVM结构进行分模块讲解,简单易懂。

    RabbitMQ 入门教程

    超系统的RabbitMQ基础知识课程,你还在等什么?

    网络编程入门教程

    Java 网络编程核心要点详解

    后端通用面试教程

    带你系统梳理后端高频面试题,轻松丰富你的校招&社招阶段

    框架应用

    Spring Boot 入门教程

    循序渐进讲解 Spring Boot 企业级应用开发

    Spring 入门教程

    通俗易懂 渐进式讲解 Spring 企业级开发应用

    Hibernate 入门教程

    由浅入深讲解 Hibernate 企业级 JDBC 应用框架

    MyBatis 入门教程

    本教程整理出“百分之二十”的知识,帮你办到“百分之八十”事情

    Spring MVC 入门教程

    通俗易懂讲解 Spring MVC 框架应用

    Swagger 入门教程

    本课程以图文并茂的方式带你学习 Swagger 核心知识和应用剖析

    Zookeeper 入门教程

    由浅入深的 学习 ZooKeeper 的基本使用以及高级使用

    Netty 教程

    由浅入深的讲解 Netty 的核心知识体系,快速上手使用和理解 Netty

    Spring Security

    本课程涵盖了 Spring Security 框架的基本原理和集成方法

    微服务

    Spring Cloud Hystrix

    系统介绍 Hystrix 支持特性与实际应用场景实战

  • Python

    基础应用

    Python 入门语法教程

    本教程带你从 Python 的基础语法开始学习 Python。

    Python 原生爬虫教程

    本教程从爬虫基础知识到进阶技巧到实际应用。

    Python 进阶应用教程

    本教程涵盖 Python 的面向对象、标准库解析、异常处理直至最后的领域应用

    Python 算法入门教程

    用 Python 代码实现常用算法并汲取算法核心思想。

    进阶方向应用

    Django 入门教程

    从 Web 基础到 Django 框架的实际开发应用

    Flask 框架教程

    Flask 框架快速入门实现一个 TodoList 功能

    NumPy 入门教程

    本教程从基础的数据类型开始到 NumPy 的高级应用一网打尽

    Scrapy 入门教程

    从爬虫基础开始到使用 Scrapy 框架抓取各大网站数据

    TensorFlow 入门教程

    通过本教程对 TensorFlow 框架快速入门

    Python 办公自动化教程

    本教程带你使用Python快速操作Excel、Word、PPT,处理各种文件

    Pandas 入门教程

    本教程从基础的数据类型开始到 Pandas 的高级应用一-网打尽

  • 数据库

    MySQL

    MySQL 入门教程

    本教程主要讲解 MySQL 增删改查等基础操作

    SQL 入门教程

    本教程讲解使用 SQL 访问和处理数据系统中的数据的方法。

    MySQL 进阶教程

    那些你还不理解的 MySQL 高阶特性一网打尽

首页 慕课教程 Spring Security Spring Security Spring Security 简介
童雷 · 更新于 2020-11-24

Spring Security 起步

下一节

Spring Security 简介

1. 前言

不难证明,外卖和我们的生活越来越紧密,我们也许天天都点外卖,那有没有想过,为什么我们敢把自己的姓名、身份证、手机、银行卡、家庭住址等等一系列敏感信息都放心地告诉给第三方平台?这离不开一个词「信任」。当我点了一单外卖,为什么饭店看得到我的订单?为什么配送员可以找得到我家?为什么客服中心可以处理投诉?为什么财务人员可以划拨?这里又出现了另一个词「职责」。

所谓「信任」,就是我知道你是谁,我也相信你做的事;所谓「职责」,就是我们相互独立又共同协作。在 IT 系统中,「信任」是通过「认证」来完成的,「职责」是通过「权限」来实现的,它们又被统称为「应用安全」。可见,「安全」是 IT 系统正常运营的必要条件之一。既然「安全」如此重要,那有没有一套框架可以帮助 Spring Boot 开发者快速地、规范地、有效地构建自己 IT 系统的安全环境呢?当然有,那就是本次课程的主题:「Spring Security」安全框架。

2. Spring Security 简介

2.1 Spring Security 的诞生

Spring Security 是 Spring 家族的中,提供认证、授权和攻击防护功能的一套安全框架。Spring Security 支持命令式和响应式两种开发模式,它也是 Spring 应用在安全框架方面的公认标准。

Spring Security 的前身是 Acegi security。Acegi security 在 1.0.7 版本之后便不再跟新,转而以 Spring Security 2.0 的身份出现在 Spring 大家庭中。截止今日(2020 年 5 月 17 日),Spring Security 正式版本已经发展至 5.3,并且已经公布 5.4 的预览版本。

2.2 Spring Security 和同类型框架的比较

Java 环境下有两大安全框架:Spring Security 和 Shiro。

和 Spring Security 一样,Shiro 同样隶属于一个强大的软件社区: Apache。二者的功能类似,都完成了认证和鉴权功能,都有超过十年的发展历史。Shiro 是一个独立的安全框架,Spring Security 则与 Spring 关联紧密,所以在二者的选择上,可以简单的用如下原则区分:

如果我们开发 Spring Boot 项目,那优先建议使用 Spring Security 安全框架。如果我们开发其他类型的项目,那请使用 Shiro 作为安全框架。

Spring Security 安全框架适合为 Spring Boot 项目提供安全保护,所以如果您是个 Spring Boot 项目的开发人员,且正在寻找一种可以和 Spring Boot 轻松集成的,用于认证和鉴权的框架时,可以优先考虑 Spring Security。

2.3 Spring Security 相关资源:

官方网站:https://spring.io/projects/spring-security

官方实例:https://github.com/spring-projects/spring-security/tree/5.3.2.RELEASE

推荐社区:https://stackoverflow.com/questions/tagged/spring-security

问题跟进:https://github.com/spring-projects/spring-security/issues

3. Spring Security 的特性

Spring Security 的核心特性包括:认证和授权、常规攻击防范、与 Servlet 接口集成、与 Spring MVC 集成等。

认证和授权的目的是,让系统知道使用者是谁(认证)?是什么样的身份?允许他做什么?禁止他做什么?通常的做法是要求用户输入自己的用户名和密码,来实现登录和鉴权的过程。

常规攻击防范在 Spring Security 安全框架中是默认开启的,常见的威胁抵御方式有:

  • 防止伪造跨站请求(CSRF)
  • 安全响应头(HTTP Response headers)
  • HTTP 通讯安全

作为 Spring 大家族的一员,Spring Security 在与 Spring 引用,尤其是与 Spring boot 应用的结合时,显得极为便利。

图片描述

Spring Security 三大功能

3. 功能模块

Spring Security 安全框架,内置一系列的安全子模块,用来满足不同类型的应用场景。自 3.0 版本开始,这些子模块被分散到了不同的 Jar 包中,开发者可以更加清晰地、直接地选择自己需要的模块,简单有效地完善自己的业务功能。

Spring Security 包含的功能模块如下:

  • Core

    核心模块,包含认证、访问控制、集成支持、配置接口等,所有 Spring Security 项目都需要依赖它。

    对应的 Jar 文件:spring-security-core.jar。

  • Remoting

    Spring security 中的 Remoting 模块提供了与 Spring Remoting 集成的能力。当我们要开发远程客户端的时候需要用到此模块。

    对应的 Jar 文件:spring-security-remoting.jar。

  • Web

    Spring security 中的 Web 模块,提供了接口过滤器和 Web 安全的基础代码。例如 Servlet 应用接口。如果我们开发的是基于 Web 认证的服务,或者是基于 URL 的访问控制时,将需要用到此模块。

    对应的 Jar 文件:spring-security-web.jar

  • Config

    Spring security 中的 Config 模块,包含了安全框架命名空间的解析功能与提供了 Java 配置代码。当我们需要使用 XML 方式或者 Java 配置方式时,需要用到此模块。

    对应的 Jar 文件:spring-security-config.jar

  • LDAP

    Spring security 中的 Ldap 模块,提供了对 Ldap 认证的支持,当我们使用 Ldap 认证时,需要用到此模块。

    对应的 Jar 文件:spring-security-ldap.jar

  • OAuth 2.0 相关模块

    Spring security 提供了对 OAuth 2.0 的支持,具体分为以下几个模块。

    • OAuth 2.0 Core

      OAuth 2.0 Core 模块是 Spring security 安全框架中,对 OAuth 2.0 支持的核心模块,包含了认证功能与 OpenID 的基本支持。

      对应的 Jar 文件:spring-security-oauth2-core.jar

    • OAuth 2.0 Client

      OAuth 2.0 Client 模块是 OAuth 2.0 客户端认证授权基础,当我们需要在客户端实现 OAuth 2.0 登录功能时,需要添加此模块。

      对应的 Jar 文件:spring-security-oauth2-client.jar

    • OAuth 2.0 JOSE

      OAuth 2.0 JOSE (Javascript Object Signing and Encryption)模块,提供了基于 JS 对象的认证与加解密功能,核心目标是实现 JS 安全传输能力。主要功能有:JWT、 JWS、JWE、JWK。

      对应的 Jar 文件:spring-security-oauth2-jose.jar

    • OAuth 2.0 Resource Server

      OAuth 2.0 resource server 模块,提供了 OAuth 2.0 资源服务的基本功能,也就是对资源的访问控制。

      对应的 Jar 文件:spring-security-oauth2-resource-server.jar

  • ACL

    ACL 模块提供了基于域对象的访问控制。

    对应的 Jar 文件:spring-security-acl.jar

  • CAS

    CAS 模块适用于需要使用 CAS 单点登录的系统,可以用于单点登录客户端的集成。

    对应的 Jar 文件:spring-security-cas.jar

  • OpenID

    OpenID 模块适用于需要集成外部 OpenID 的认证系统。使用该模块功能同时还需要依赖 OpenID4Java 。

    对应的 Jar 文件:spring-security-openid.jar

  • Test

    Test 模块提供了对 Spring security 进行单元测试的能力。

    对应的 Jar 文件:spring-security-test.jar

4. 开始前准备

Spring Security 要求使用 JDK 8 以上的 Java 编译版本。

在 Spring Boot 项目中添加 Spring Security 支持非常方便,只需要使用 Spring Boot 提供的 spring-boot-starter-security 启动器即可。

在非 Spring Boot 项目中使用 Spring Security 则需要添加 Spring Security 核心组件,如:spring-security-config 和 spring-security-web 等。

5. 小结

Spring Security 是 Spring 家族中规范化的安全框架。它帮助我们轻松地构建应用安全环境,可以快速地实现「认证」和「权限」管理,它帮助我们规范化开发过程,是一套完整、成熟、易用的开发框架。

下一节,我们将尝试创建第一个 Spring Security 应用。

  • 划线
  • 写笔记
  • 复制

0/1000

 

下一节

Spring Security 起步

我要提出意见反馈
· 最近更新于 请填写更新时间
使用手机查看
最近更新
向你推荐
更多
索引目录
Spring Security 简介
1. 前言
2. Spring Security 简介
2.1 Spring Security 的诞生
2.2 Spring Security 和同类型框架的比较
2.3 Spring Security 相关资源:
3. Spring Security 的特性
3. 功能模块
4. 开始前准备
5. 小结
意见反馈 收藏教程 标记书签
使用 Ctrl+D 可将网站添加到书签
  • 企业服务
  • 网站地图
  • 网站首页
  • 关于我们
  • 联系我们
  • 讲师招募
  • 帮助中心
  • 意见反馈
  • 代码托管

Copyright© 2023 imooc.com All Rights Reserved | 京ICP备 12003892号-11 京公网安备11010802030151号

意见反馈 常见问题 APP下载
官方微信
返回顶部