前言:
而今姐妹们对“webflux 分页”大约比较关怀,小伙伴们都想要学习一些“webflux 分页”的相关知识。那么小编也在网络上汇集了一些对于“webflux 分页””的相关内容,希望朋友们能喜欢,姐妹们快快来学习一下吧!yue-library简介
yue-library是一个基于SpringBoot封装的增强库
内置丰富的JDK工具自动装配了一系列的基础Bean与环境配置项快速构建SpringCloud项目,让微服务变得更简单版本更新日志
此版本重点实现:密钥交换加解密、增强Bean转换能力、JDBC新增Elasticsearch-SQL、达梦、PostgreSQL方言。
新特性【base】ParamUtils提示优化,添加错误原因【base】添加JSONListConverter类型转换器从而支持List<JSONObject>类型处理(JDBC实体数据库查询映射时JSONArray格式文本数据不支持映射成List<JSONObject>)【base】优化fastjson bean转换的jsonstr识别方式【base】增强DateUtils与规范UUID工具类为IdUtils并优化IdUtils实现【base】增强fastjson JavaBean转换能力,支持Character类型【base】MapUtils增强值提取,支持list根据key提取map提取值支持map、fastjson pulls !17【crypto】新增重磅特性-密钥交换加密:支持@RequestDecrypt注解实现请求自动解密【crypto】新增重磅特性-密钥交换加密:支持@ResponseEncrypt注解实现响应内容加密【crypto】密钥交换加密:默认提供本地Map与Redis两种交换密钥存储方案【crypto】密钥交换加密:@RequestDecrypt与@ResponseEncrypt注解支持使用交换密钥加密或自定义密钥等特性【web】修复ApiVersion注解minimumVersion值等于的情况下410【web】优化响应结果处理器在标准HTTP状态码时的空值处理【web】新增ServletUtils.getAuthToken()方法,获取请求中的OAuth2 Token【webflux】修复ApiVersion注解minimumVersion值等于的情况下410【jdbc】对jdbc方言实现进行完善与优化,新增Elasticsearch-SQL、达梦、PostgreSQL方言【jdbc】db.queryForObject 自动识别Bean类型与简单类型【jdbc】参数美化增强支持JSONArray数据类型与List<JSONObject>数据类型【jdbc】优化多行查询结果转换为单行查询结果实现【jdbc】所有mappedClass查询方法自动识别所需RowMapper类型,实现JavaBean、map、基本类型结果自动匹配【jdbc】规范内部部分常量命名与移除分页中不优雅的泛型实例PageTVO【jdbc】增强自动方言识别,根据驱动类自动识别所需方言类型【jdbc】默认Db Bean实现根据不同驱动类型,使用对应方言配置【jdbc】优化DAO实现,抽象基础DAO【jdbc】优化所有jdbc方法注释,描述更简洁,表达更清晰,注释更规范【jdbc】删除早期存在的部分过时方法【es】支持配置ConnectTimeout与SocketTimeout,并调大各自默认值为25与15秒Bug修复【base】修复fastjson JavaBean转换BUG #3688【jdbc】修复isDataSize()方法可能因为数据库存在多行数据,而返回false的隐患【jdbc】修复因错误测试而删除的参数类型美化(现已支持:Character、JSONObject、LocalDateTime进行特殊转换处理与布尔值映射识别)Maven仓库实际发布版本号
j8.2.3.2、j11.2.3.2
关键pom.xml依赖:
依赖
版本
spring-boot
2.3.8.RELEASE
spring-cloud
Hoxton.SR10
spring-cloud-alibaba
2.2.5.RELEASE
hutool
5.6.3
fastjson
1.2.76
工程结构
. yue-library├── yue-library 基础库│ ├── yue-library-dependencies 父pom│ ├── yue-library-base 基础库提供了丰富的Java工具包,同时也自动装配了一系列基础Bean等│ ├── yue-library-base-crypto 基于Hutool实现的加解密模块,提供诸如数据脱敏此类的更多特性│ ├── yue-library-web 基础库WebMvc实现,用于servlet项目│ ├── yue-library-webflux 基础库WebFlux实现,用于响应式编程项目(如:SpringCloudGateway)│ ├── yue-library-data-jdbc 基于SpringJDBC进行二次封装,拥有着强大性能的同时又不失简单、灵活等│ ├── yue-library-data-redis 基于SpringRedis进行二次封装,更简单灵活,提供全局token与登录相关特性等│ ├── yue-library-auth-service 基于SpringSecurity进行二次封装,更简单灵活,提供全局token与登录等特性│ ├── yue-library-auth-client auth-client为auth-service客户端模块,提供获取当前登录用户状态信息等特性│ ├── yue-library-pay 基于pay-java-parent进行二次封装,让你真正做到一行代码实现支付聚合│ ├── yue-library-cloud-oss│ └── yue-library-cloud-sms├── yue-library-samples 基础库示例│ ├── yue-library-test yue-library代码测试项目:单元测试、接口测试、代码示例│ ├── yue-library-test-webflux yue-library-webflux代码测试项目:单元测试、接口测试、代码示例│ ├── yue-library-template-simple yue-library模版:SpringBoot项目模版│ └── yue-library-template-ssc yue-library模版:SpringCloud项目模版,SOA共享架构(阿里巴巴中台)└── yue快速开始引入项目依赖
maven项目,在pom.xml文件中添加如下一段代码,并将${version}替换为对应版本号:
<parent> <groupId>ai.ylyue</groupId> <artifactId>yue-library-dependencies</artifactId> <version>${version}</version></parent>
随后引入所需要的模块,如WebMvc项目引入:yue-library-web
依赖说明:yue-library-base为基础模块,一般情况下不需要单独引入,如:web、data-jdbc、data-redis等模块皆已默认依赖。
<dependencies> <dependency> <groupId>ai.ylyue</groupId> <artifactId>yue-library-web</artifactId> </dependency> ...</dependencies>启动项目
新建一个SpringBoot main方法启动类:
@SpringBootApplicationpublic class TestApplication { public static void main(String[] args) throws Exception { SpringApplication.run(TestApplication.class, args); }}
写一个测试接口:
@RestController@RequestMapping("/quickstart")public class QuickstartController { @GetMapping("/get") public Result<?> get(JSONObject paramJson) { return ResultInfo.success(paramJson); } }
访问接口测试,如:
{ "code": 200, "msg": "成功", "flag": true, "count": null, "data": {}}密钥交换
密钥交换加密可以实现如下几个特性:
每次会话的密钥时随机的,客户端与服务端事先无需约定密钥未直接存储在客户端与服务端中,避免了泄露风险密钥交换过程中,密钥的传输是加密的密钥交换流程
密钥交换步骤一:客户端请求传输加密公钥
客户端使用密钥存储key,请求获得服务端公钥(用于步骤二请求加密)密钥存储key:作为会话唯一键,在步骤一、步骤二、步骤三中属于必填参数密钥存储key:在用户未登录时一般会随机生成一个UUID,用户登陆后再用token作为别名密钥存储key:用户已登录情况,一般会以用户本次会话token作为存储key服务端收到请求后,生成用于后续传输加解密的公私钥并绑定存储key服务端将生成的公钥返回给客户端
密钥交换步骤二:客户端请求最终交换密钥
客户端获得服务端的公钥后,创建客户端自身的公私钥客户端使用服务端的公钥加密自身生成的公钥,向服务端请求最终的交换密钥服务端使用私钥解密获得客户端公钥服务端生成最终交换密钥,并使用客户端公钥进行响应加密客户端获得加密的交换密钥后使用客户端私钥解密,获得交换密钥
密钥交换步骤三(可选):客户端为服务端密钥的存储key添加别名
适用场景:步骤一时用户未登录,使用临时的UUID作为服务端密钥存储key,用户登录后想使用token作为密钥存储key,方便后续传输
使用交换密钥加解密
客户端获得交换密钥后,请求需要参数加密的接口时,以约定的方式带上密钥存储key,并加密请求参数约定方式:默认为OAuth2 Token认证,故:若步骤一使用UUID作为存储key,需将token添加为存储别名约定方式:除默认方式外支持:Header传参约定、URL Param传参约定(具体传参key为服务端定义,默认key值:Yue-ExchangeKey-StorageKey)服务端解密参数处理业务逻辑后,使用@ResponseEncrypt注解自动加密响应的data参数客户端解密响应结果接口说明
默认算法名称
RSA_AES:
/** RSA算法,此算法用了默认补位方式为RSA/ECB/PKCS1Padding */ RSA_ECB_PKCS1("RSA/ECB/PKCS1Padding"), /** 默认的AES加密方式:AES/ECB/PKCS5Padding */ AES("AES"),SM2_SM4
/** * 算法EC */ private static final String ALGORITHM_SM2 = "SM2"; public static final String ALGORITHM_NAME = "SM4";
密钥交换-第一步:获得加密公钥
接口地址:POST /open/v2.3/keyExchange/{storageKey}
参数
说明
参数示例
storageKey
RESTful路径参数,密钥存储key
23ef1f9418e84cc884187e1720ac1529
exchangeKeyType
交换密钥类型,枚举值:RSA_AES、SM2_SM4
RSA_AES
密钥交换-第二步:获得交换密钥
接口地址:POST /open/v2.3/keyExchange/{storageKey}
参数
说明
参数示例
storageKey
RESTful路径参数,密钥存储key
23ef1f9418e84cc884187e1720ac1529
exchangeKeyType
交换密钥类型,枚举值:RSA_AES、SM2_SM4
RSA_AES
encryptedClientPublicKey
使用服务端公钥加密的客户端公钥(encryptBase64)
SsowXMaZfQiec39 ..略n.. uv/DbVr6gslrjY3Q==
密钥交换-第三步:添加存储key别名
接口地址:POST /open/v2.3/keyExchange/{storageKey}/addAlias
参数
说明
参数示例
storageKey
RESTful路径参数,密钥存储key
23ef1f9418e84cc884187e1720ac1529
storageKeyAlias
存储别名
cbf55767c47e4d4e9feb90cfa2bdf5aa
配置
yue: crypto: key-exchange: enabled: true # 默认false,启用密钥交换 key-exchange-storage-type: redis # 使用redis作为密钥交换存储类型注解使用说明
@RequestDecrypt请求解密注解:
必须与@RequestBody注解一同使用@RequestBody注解只支持使用Body传参,并映射为实体参数。Content-Type=application/json;charset=UTF-8
@RequestDecrypt @PostMapping("/decrypt") public Result<?> decrypt(@RequestBody UserIPO userIPO) { return R.success(userIPO); }
@ResponseEncrypt响应加密注解:
必须与@ResponseBody注解一同使用,@RestController注解默认已集成@ResponseBody必须使用Result作为返回类型,并且加密的是data参数
@ResponseEncrypt @GetMapping("/{encrypt}") public Result<?> encrypt(@PathVariable String encrypt) { return R.success(encrypt); }
收藏一波以表支持吧(≧▽≦)/!
标签: #webflux 分页 #交换加密算法有哪些特点