- 掌握Apache Flink:实时数据处理与分析实操
泓三宝
本文还有配套的精品资源,点击获取简介:ApacheFlink是一个高效的开源流处理框架,专为实时数据处理和分析设计。本文将通过一个具体的代码示例,深入讲解Flink的核心概念如DataStream、FlatMap和ReduceMap,并展示如何将这些概念应用于实际场景。通过解析“wiki-edits”数据流的实例,我们将探讨如何使用Flink的API进行数据转换、聚合和实时分析,包括窗口和触发器的
- Android Room 持久化库:简化数据库操作
安卓开发者
AndroidJetpackandroid数据库
什么是Room?Room是Google官方推出的一个SQLite对象映射库,它是AndroidJetpack组件的一部分。Room在SQLite的基础上提供了一个抽象层,让开发者能够更流畅地访问数据库,同时又能充分利用SQLite的全部功能。Room的主要优势在于:编译时SQL查询验证减少了大量样板代码与LiveData、RxJava等无缝集成提供了简单的注解方式来定义数据库结构Room的核心组件
- 【安卓笔记】RxJava的Hook机制,整体拦截器
liosen
安卓笔记androidrxjavahook
0.环境:电脑:Windows10AndroidStudio:2024.3.2编程语言:JavaGradleversion:8.11.1CompileSdkVersion:35Java版本:Java111.使用场景整个项目都是用了RxJava,需要对整个/部分项目的RxJava进行监听(拦截)就会使用到Hook技术下面请看代码:publicvoidhookConfig(){RxJavaPlugin
- Android Room使用方法与底层原理详解
你过来啊你
androidroom
Room是一个强大的SQLite对象映射库,旨在提供更健壮、更简洁、更符合现代开发模式的数据库访问方式。核心价值:消除大量样板代码,提供编译时SQL验证,强制结构化数据访问,并流畅集成LiveData、Flow和RxJava以实现响应式UI。一、使用流程(Step-by-StepWorkflow)Room的使用遵循一个清晰的结构化流程:添加依赖://build.gradle(Module)depe
- RxJava 全解析:从原理到 Android 实战
Monkey-旭
javarxjava响应式编程android
在Android开发中,异步任务处理是绕不开的核心场景——网络请求、数据库操作、文件读写等都需要在后台执行,而结果需回调到主线程更新UI。传统的“Handler+Thread”或AsyncTask不仅代码冗余,还容易陷入“回调地狱”(嵌套回调导致代码可读性差)。RxJava作为一款基于响应式编程思想的异步框架,通过“链式调用”和“操作符”完美解决了这些问题,成为Android开发者的必备工具。本文
- Android开发中RxJava的使用与原理
你过来啊你
androidrxjava
RxJava是ReactiveExtensions在JVM上的实现,专为处理异步事件流和基于观察者模式的编程而设计。在Android开发中,它极大地简化了异步操作(如网络请求、数据库访问、UI事件处理)的管理、组合和线程调度,有效解决了回调地狱问题。一、RxJava核心概念Observable(可观察者):数据源或事件源。它负责发出数据项(onNext)或事件(成功完成onComplete/发生错
- 扔物线--Kotlin协程训练营2期-2
笔记仅做自己学习用,方便自己复习知识。若正好可以帮助到Viewer,万分欣喜~若博客侵权,扔物线大大不允许放上面,麻烦告知本文是扔物线Kotlin第二期协程训练营的第二篇文章没看过第一篇文章的可以先看第一篇:https://blog.csdn.net/bluerheaven/article/details/106969835目录一、Retrofit对协程的支持二、Retrofit和RxJava的结
- es6数组的flat(),flatMap()函数用法实例分析
PrinciplesMan
#Es6es6javascript开发语言
数组的成员有时还是数组,Array.prototype.flat()用于将嵌套的数组“拉平”,变成一维数组。该方法返回一个新数组,对原数据没有影响。[1,2,[3,4]].flat()//[1,2,3,4]上面代码中,原数组的成员里面有一个数组,flat()方法将子数组的成员取出来,添加在原来的位置。flat()默认只会“拉平”一层,如果想要“拉平”多层的嵌套数组,可以将flat()方法的参数写成
- 探索高效缓存:CoroutinesCache 开源库深度解析
龙香令Beatrice
探索高效缓存:CoroutinesCache开源库深度解析CoroutinesCacheInmobiledevelopmentexistssolutionforcachingwithRxJavausage,butthereisnosolutionsforKotlinCoroutines.Theprojectistoprovidethisfunctionalitytomobilecommunity.
- Reactor框架介绍,和使用示例
Reactor框架介绍Reactor是一个基于JVM的非阻塞响应式编程框架,遵循ReactiveStreams规范,专为构建高并发、低延迟的异步应用设计[2][4]。其核心特点包括:异步流处理提供Flux(处理0或N个元素)和Mono(处理0或1个元素)两个核心抽象,支持链式操作(如map、filter、flatMap等)实现数据的异步处理[5][4]。背压支持通过ReactiveStreams协
- JAVA List<String> 用 stream转为 List<Long>
墨着染霜华
javalist
可以使用JavaStream将List转换为List,前提是这些字符串可以被正确解析为数字。ListlongList=strList.stream().flatMap(s->{try{returnStream.of(Long.parseLong(s));}catch(NumberFormatExceptione){returnStream.empty();}}).collect(Collector
- EventBus之Reactor实战
太阳伞下的阿呆
reactoreventbus观察者模式
如果你想要使用一个轻量级的消息中间件,不需要分布式支持,那么可以选择RxJava或者Reactor,本文将讲述如何入门使用该框架,以及常用的一些功能生产者广播多消费者模式Sinks.Many:创建一个允许我们将数据推送到一个Flux的sink。我们使用Sinks.many().multicast().onBackpressureBuffer()来创建一个支持背压的多播Sink(广播模式)。Flux
- Android 异步操作库 RxJava
Just_Paranoid
Androidandroidrxjavarxandroid
RxJava概述RxJava是一种响应式编程,来创建基于事件的异步操作库。基于事件流的链式调用、逻辑清晰简洁。RxJava我的理解是将事件从起点(上游)流向终点(下游),中间有很多卡片对数据进操作并传递,每个卡片获取上一个卡片传递下来的结果然后对事件进行处理然后将结果传递给下一个卡片,这样事件就从起点通过卡片一次次传递直到流向终点。RxJava观察者模式传统观察者是一个被观察者多过观察者,当被观察
- 利用RxJava实现Android异步编程的深入探索
爱分析
RxJavaAndroid异步编程多线程进度显示UI事件处理
利用RxJava实现Android异步编程的深入探索背景简介RxJava作为响应式编程的一个重要工具,对于Android开发者来说,它极大地简化了异步操作的处理。通过本文,我们将深入探讨RxJava在Android平台中如何实现网络操作的异步处理,并且记录进度,以及如何处理UI事件。实现网络操作的异步处理和进度记录在Android开发中,网络操作通常需要在后台线程中进行,以避免阻塞主线程导致UI卡
- 【JAVA】List常用移除、过滤、去重、flatMap、peek等操作
愿做无知一猿
JAVAstreamlambdajava
List常用移除,过滤,去重操作ListItem.classimportlombok.Data;importlombok.experimental.Accessors;@Data@Accessors(chain=true)publicclassListItem{privateStringitem;privateStringqwe;}移除List中某个的元素publicstaticvoidmain(
- java Stream流常用操作
CC大煊
Java基础javajdk
文章目录1.简介1.1Stream流的概念1.2为什么需要使用Stream流2.Stream流的创建2.1从集合创建Stream2.2从数组创建Stream2.3使用Stream.of方法创建Stream2.4使用IntStream,LongStream,DoubleStream创建Stream3.Stream流的常用操作3.1filter操作3.2map操作3.3flatMap操作3.4dist
- ES6读书笔记——数组扩展
Jessie-moving
ES6ES6ES6数组方法ES数组拓展扩展运算符...
数组扩展1、扩展运算符(spread)2、Array.from()3、Array.of()4、数组实例的copyWithin()5、数组实例的find()和findIndex()6、数组实例的fill()7、数组实例的entries(),keys()和values()8、数组实例的includes()9、数组实例的flat(),flatMap()10、数组的空位1、扩展运算符(spread)扩展运
- Jetpack+MVVM
hc.Geng
jetpackandroid
本文包含Android中MVVM体系中的很多部分,主要对ViewModel+DataBinding+RxJava+LiveData+Lifecycle等笔者所使用的技术体系进行解析.本文字数较多,内容较为完整并且后续还会追加更新,阅读本篇文章需要较长时间,建议读者分段阅读.所有文字均为个人学习总结和理解,仅供参考,如有纰漏还请指出,笔者不胜感激.1.1配置环境笔者的AndroidStudio版本=
- Reactor — 基于异步数据流实现Reactive响应式编程
RachelHwang
streamjavanettyjavareactorjdk1.8编程语言设计模式
1、概述Reactor是ReactiveProgramming规范的一个具体实现(rxjava也是规范的一个实现),可以概括为:响应式编程是一种涉及数据流和变化传播的异步编程范例。这意味着可以通过所采用的编程语言轻松地表达静态(例如阵列)或动态(例如事件发射器)数据流。2、JDK8Stream2.1jdk8Streamjdkstream总纲:Java8Stream旨在有效地处理数据流(包括原始类型
- Spark--->转换算子
飝鱻.
Sparkspark大数据hadoopjava
Spark--->转换算子flatMap:数据的拆分、转换(一对多)map:转换(一对一)filter:过滤算子sort:排序算子mapPartitionsmapPartitionsWithIndexsample:取样,转换mapValueunionintersectionsubtratreduceByKeygroupByKeycombinerByKeyfoldByKeyaggregateByKe
- AsyncTask线程池瓶颈全解析:从原理到企业级解决方案
Android洋芋
AsyncTask线程池瓶颈Android性能优化内存泄漏异步处理企业级解决方案
简介本文将深入探讨AsyncTask线程池机制及瓶颈,提供自定义线程池、Kotlin协程、RxJava和WorkManager等替代方案的完整实现,并通过企业级实战案例展示如何优化异步任务处理,确保应用流畅运行。一、AsyncTask线程池机制与瓶颈分析AsyncTask是Android开发中一个轻量级的异步任务框架,用于在后台执行耗时操作并在主线程更新UI。然而,随着应用复杂度的增加,Async
- spark中的转换算子
只因只因爆
spark大数据分布式
importorg.apache.spark.{SparkConf,SparkContext}objectMain{defmain(args:Array[String]):Unit={//学习sparkRDD中的转换算子//1.map//2.filter:过滤//3.flatMap:flat(扁平化)+map(映射)//4.reduceByKey:键值对的数据(word,1),(hello,1)v
- Scala编写WordCount程序
「已注销」
大数据scala
首先对于给定的一个List数组vallist=List("roseisbeautiful","jennieisbeautiful","lisaisbeautiful","jisooisbeautiful")/***第一步,将list中的元素按照分隔符这里是空格拆分,然后展开*先map(_.split(""))将每一个元素按照空格拆分*然后flatten展开*flatmap即为上面两个步骤的整合*/
- spark:map 和 flatMap 的区别(Scala)
WZMeiei
Sparkspark大数据分布式scala
场景设定假设有一个包含句子的RDD:scalavalrdd=sc.parallelize(List("HelloWorld","HiSpark"))目标是:将每个句子拆分成单词。1.用map的效果代码示例scalavalresultMap=rdd.map(sentence=>sentence.split(""))resultMap.collect()输出结果scalaArray[Array[Str
- Spark RDD简介以及算子使用大全
Sheenky
大数据大数据sparkpython
目录一、sparkRDD(1)RDD简介(2)算子简介二、RDD的使用(基于Linux系统)(1)RDD创建①基于数据集合创建②基于外部数据源创建(2)transformation算子——map()(3)transformation算子——flatMap()(4)transformation算子——filter()(5)transformation算子——union()(6)transformat
- Android第三方常用库汇总
坚强的小水滴
android
网络请求RxEasyHttp基于RxJava2+Retrofit2实现简单易用的网络请求框架retrofitokhttpokhttp-OkGo封装了OkHttp的网络请求框架图片加载glideglide-transformations基于glide的图片变化库frescopicassoLargeImage加载大图可以高清显示10000*10000像素的图片,轻松实现微博长图功能视频播放器ExoPl
- Spark的RDD转换算子-map、mapPartitions、mapPartitionsWithIndex
牧码文
Sparksparkscalabigdata
Spark的RDD转换算子-map、mapPartitions、mapPartitionsWithIndexRDD算子包括RDD转换算子和RDD行动算子,其实算子就相当于一种方法,在方法中封装想要实现所需结果的逻辑,比如在将旧的RDD包装成新的RDD上,所使用的有map、flatMap等,其实这就是转换算子。在整个任务的调度和作业的执行方面,只有调用了collect之后,才会出发任务的执行,比如c
- Android 常用组件库,如果进行组件化开发如何分组
时小雨
android
以下整理了Android开发中常用的流行组件库,涵盖网络、异步、架构、UI、工具等核心场景,共20+个分类,并标注关键特性和推荐场景:一、网络请求OkHttp特性:高效HTTP客户端,支持同步/异步请求、连接池、缓存等。场景:基础网络层,常与Retrofit配合使用。Retrofit特性:类型安全的REST客户端,基于OkHttp,支持RxJava/协程。场景:快速构建API接口,适合结构化网络请
- Kotlin协程Flow浅析
web老猴子
kotlinandroid开发语言
Kotlin协程中的Flow主要用于处理复杂的异步数据,以一种”流“的方式,从上到下依次处理,和RxJava的处理方式类型,但是比后者更加强大。Flow基本概念Flow中基本上有三个概念,即发送方,处理中间层,接收方,可以类比水利发电站中的上游,发电站,下游的概念,数据从上游开始发送”流淌“至中间站被”处理“了一下,又流淌到了下游。flow{//发送方、上游emit(1)//挂起函数,发送数据em
- Kotlin 协程 vs RxJava vs 线程池:性能与场景对比
时小雨
kotlinrxjavaecharts
1.轻量级任务:10,000个并发延迟操作假设需要并发执行10,000个非阻塞延迟任务(如模拟定时请求):线程池实现ExecutorServiceexecutor=Executors.newFixedThreadPool(64);//最多64线程List>futures=newArrayList{Thread.sleep(100);//阻塞线程returnnull;}));}//需要手动等待所有F
- jquery实现的jsonp掉java后台
知了ing
javajsonpjquery
什么是JSONP?
先说说JSONP是怎么产生的:
其实网上关于JSONP的讲解有很多,但却千篇一律,而且云里雾里,对于很多刚接触的人来讲理解起来有些困难,小可不才,试着用自己的方式来阐释一下这个问题,看看是否有帮助。
1、一个众所周知的问题,Ajax直接请求普通文件存在跨域无权限访问的问题,甭管你是静态页面、动态网页、web服务、WCF,只要是跨域请求,一律不准;
2、
- Struts2学习笔记
caoyong
struts2
SSH : Spring + Struts2 + Hibernate
三层架构(表示层,业务逻辑层,数据访问层) MVC模式 (Model View Controller)
分层原则:单向依赖,接口耦合
1、Struts2 = Struts + Webwork
2、搭建struts2开发环境
a>、到www.apac
- SpringMVC学习之后台往前台传值方法
满城风雨近重阳
springMVC
springMVC控制器往前台传值的方法有以下几种:
1.ModelAndView
通过往ModelAndView中存放viewName:目标地址和attribute参数来实现传参:
ModelAndView mv=new ModelAndView();
mv.setViewName="success
- WebService存在的必要性?
一炮送你回车库
webservice
做Java的经常在选择Webservice框架上徘徊很久,Axis Xfire Axis2 CXF ,他们只有一个功能,发布HTTP服务然后用XML做数据传输。
是的,他们就做了两个功能,发布一个http服务让客户端或者浏览器连接,接收xml参数并发送xml结果。
当在不同的平台间传输数据时,就需要一个都能解析的数据格式。
但是为什么要使用xml呢?不能使json或者其他通用数据
- js年份下拉框
3213213333332132
java web ee
<div id="divValue">test...</div>测试
//年份
<select id="year"></select>
<script type="text/javascript">
window.onload =
- 简单链式调用的实现技术
归来朝歌
方法调用链式反应编程思想
在编程中,我们可以经常遇到这样一种场景:一个实例不断调用它自身的方法,像一条链条一样进行调用
这样的调用你可能在Ajax中,在页面中添加标签:
$("<p>").append($("<span>").text(list[i].name)).appendTo("#result");
也可能在HQ
- JAVA调用.net 发布的webservice 接口
darkranger
webservice
/**
* @Title: callInvoke
* @Description: TODO(调用接口公共方法)
* @param @param url 地址
* @param @param method 方法
* @param @param pama 参数
* @param @return
* @param @throws BusinessException
- Javascript模糊查找 | 第一章 循环不能不重视。
aijuans
Way
最近受我的朋友委托用js+HTML做一个像手册一样的程序,里面要有可展开的大纲,模糊查找等功能。我这个人说实在的懒,本来是不愿意的,但想起了父亲以前教我要给朋友搞好关系,再加上这也可以巩固自己的js技术,于是就开始开发这个程序,没想到却出了点小问题,我做的查找只能绝对查找。具体的js代码如下:
function search(){
var arr=new Array("my
- 狼和羊,该怎么抉择
atongyeye
工作
狼和羊,该怎么抉择
在做一个链家的小项目,只有我和另外一个同事两个人负责,各负责一部分接口,我的接口写完,并全部测联调试通过。所以工作就剩下一下细枝末节的,工作就轻松很多。每天会帮另一个同事测试一些功能点,协助他完成一些业务型不强的工作。
今天早上到公司没多久,领导就在QQ上给我发信息,让我多协助同事测试,让我积极主动些,有点责任心等等,我听了这话,心里面立马凉半截,首先一个领导轻易说
- 读取android系统的联系人拨号
百合不是茶
androidsqlite数据库内容提供者系统服务的使用
联系人的姓名和号码是保存在不同的表中,不要一下子把号码查询来,我开始就是把姓名和电话同时查询出来的,导致系统非常的慢
关键代码:
1, 使用javabean操作存储读取到的数据
package com.example.bean;
/**
*
* @author Admini
- ORACLE自定义异常
bijian1013
数据库自定义异常
实例:
CREATE OR REPLACE PROCEDURE test_Exception
(
ParameterA IN varchar2,
ParameterB IN varchar2,
ErrorCode OUT varchar2 --返回值,错误编码
)
AS
/*以下是一些变量的定义*/
V1 NUMBER;
V2 nvarc
- 查看端号使用情况
征客丶
windows
一、查看端口
在windows命令行窗口下执行:
>netstat -aon|findstr "8080"
显示结果:
TCP 127.0.0.1:80 0.0.0.0:0 &
- 【Spark二十】运行Spark Streaming的NetworkWordCount实例
bit1129
wordcount
Spark Streaming简介
NetworkWordCount代码
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
- Struts2 与 SpringMVC的比较
BlueSkator
struts2spring mvc
1. 机制:spring mvc的入口是servlet,而struts2是filter,这样就导致了二者的机制不同。 2. 性能:spring会稍微比struts快。spring mvc是基于方法的设计,而sturts是基于类,每次发一次请求都会实例一个action,每个action都会被注入属性,而spring基于方法,粒度更细,但要小心把握像在servlet控制数据一样。spring
- Hibernate在更新时,是可以不用session的update方法的(转帖)
BreakingBad
Hibernateupdate
地址:http://blog.csdn.net/plpblue/article/details/9304459
public void synDevNameWithItil()
{Session session = null;Transaction tr = null;try{session = HibernateUtil.getSession();tr = session.beginTran
- 读《研磨设计模式》-代码笔记-观察者模式
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.util.ArrayList;
import java.util.List;
import java.util.Observable;
import java.util.Observer;
/**
* “观
- 重置MySQL密码
chenhbc
mysql重置密码忘记密码
如果你也像我这么健忘,把MySQL的密码搞忘记了,经过下面几个步骤就可以重置了(以Windows为例,Linux/Unix类似):
1、关闭MySQL服务
2、打开CMD,进入MySQL安装目录的bin目录下,以跳过权限检查的方式启动MySQL
mysqld --skip-grant-tables
3、新开一个CMD窗口,进入MySQL
mysql -uroot
 
- 再谈系统论,控制论和信息论
comsci
设计模式生物能源企业应用领域模型
再谈系统论,控制论和信息论
偶然看
- oracle moving window size与 AWR retention period关系
daizj
oracle
转自: http://tomszrp.itpub.net/post/11835/494147
晚上在做11gR1的一个awrrpt报告时,顺便想调整一下AWR snapshot的保留时间,结果遇到了ORA-13541这样的错误.下面是这个问题的发生和解决过程.
SQL> select * from v$version;
BANNER
-------------------
- Python版B树
dieslrae
python
话说以前的树都用java写的,最近发现python有点生疏了,于是用python写了个B树实现,B树在索引领域用得还是蛮多了,如果没记错mysql的默认索引好像就是B树...
首先是数据实体对象,很简单,只存放key,value
class Entity(object):
'''数据实体'''
def __init__(self,key,value)
- C语言冒泡排序
dcj3sjt126com
算法
代码示例:
# include <stdio.h>
//冒泡排序
void sort(int * a, int len)
{
int i, j, t;
for (i=0; i<len-1; i++)
{
for (j=0; j<len-1-i; j++)
{
if (a[j] > a[j+1]) // >表示升序
- 自定义导航栏样式
dcj3sjt126com
自定义
-(void)setupAppAppearance
{
[[UILabel appearance] setFont:[UIFont fontWithName:@"FZLTHK—GBK1-0" size:20]];
[UIButton appearance].titleLabel.font =[UIFont fontWithName:@"FZLTH
- 11.性能优化-优化-JVM参数总结
frank1234
jvm参数性能优化
1.堆
-Xms --初始堆大小
-Xmx --最大堆大小
-Xmn --新生代大小
-Xss --线程栈大小
-XX:PermSize --永久代初始大小
-XX:MaxPermSize --永久代最大值
-XX:SurvivorRatio --新生代和suvivor比例,默认为8
-XX:TargetSurvivorRatio --survivor可使用
- nginx日志分割 for linux
HarborChung
nginxlinux脚本
nginx日志分割 for linux 默认情况下,nginx是不分割访问日志的,久而久之,网站的日志文件将会越来越大,占用空间不说,如果有问题要查看网站的日志的话,庞大的文件也将很难打开,于是便有了下面的脚本 使用方法,先将以下脚本保存为 cutlog.sh,放在/root 目录下,然后给予此脚本执行的权限
复制代码代码如下:
chmo
- Spring4新特性——泛型限定式依赖注入
jinnianshilongnian
springspring4泛型式依赖注入
Spring4新特性——泛型限定式依赖注入
Spring4新特性——核心容器的其他改进
Spring4新特性——Web开发的增强
Spring4新特性——集成Bean Validation 1.1(JSR-349)到SpringMVC
Spring4新特性——Groovy Bean定义DSL
Spring4新特性——更好的Java泛型操作API
Spring4新
- centOS安装GCC和G++
liuxihope
centosgcc
Centos支持yum安装,安装软件一般格式为yum install .......,注意安装时要先成为root用户。
按照这个思路,我想安装过程如下:
安装gcc:yum install gcc
安装g++: yum install g++
实际操作过程发现,只能有gcc安装成功,而g++安装失败,提示g++ command not found。上网查了一下,正确安装应该
- 第13章 Ajax进阶(上)
onestopweb
Ajax
index.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/
- How to determine BusinessObjects service pack and fix pack
blueoxygen
BO
http://bukhantsov.org/2011/08/how-to-determine-businessobjects-service-pack-and-fix-pack/
The table below is helpful. Reference
BOE XI 3.x
12.0.0.
y BOE XI 3.0 12.0.
x.
y BO
- Oracle里的自增字段设置
tomcat_oracle
oracle
大家都知道吧,这很坑,尤其是用惯了mysql里的自增字段设置,结果oracle里面没有的。oh,no 我用的是12c版本的,它有一个新特性,可以这样设置自增序列,在创建表是,把id设置为自增序列
create table t
(
id number generated by default as identity (start with 1 increment b
- Spring Security(01)——初体验
yang_winnie
springSecurity
Spring Security(01)——初体验
博客分类: spring Security
Spring Security入门安全认证
首先我们为Spring Security专门建立一个Spring的配置文件,该文件就专门用来作为Spring Security的配置