org.bouncycastle 是一个广泛使用的开源加密库,它为Java平台提供了丰富的密码学算法实现,包括对称加密、非对称加密、哈希算法、数字签名等。
在国密算法中,SM2是一种基于椭圆曲线的非对称加密算法,可以用于公开密钥加密、数字签名、随机数生成等多种用途
bcprov-jdk18on 和 bcpkix-jdk18on 是两个不同的Java库,它们都由Bouncy Castle提供,并且针对JDK 1.8及以上版本。
bcprov-jdk18on 主要用于加密算法的实现,而 bcpkix-jdk18on 则专注于处理PKIX证书链和X.509证书。
每日一曲 青花瓷 粤语版
各种数据对象之间的转换,
BeanUtil.copyProperties 可以实现,但是性能差且容易出问题。
MapStruct 类似于lombok ,在编译期生成代码,不存在运行时性能问题。
清炖牛腱子
冷水下锅煮 去浮沫 多去几次 干净为止 ,
放入电炖锅 加开水 加生姜醋 ,一小时后 ,用筷子能戳进去就可以 ,
加盐 ,二十分钟后 拿出来 放凉 ,保鲜膜封住 ,放冰箱冷藏 ,
冷藏定型后切片,可蘸料吃,
Vue开发,一般会使用构建工具(Vite、webpack等)开发单页面应用,
这种构建方式下可以直接使用单文件组件(.vue)创建一个组件,有代码提示补全等,
并且可以使用npm、yarn等包管理器安装Vue全家桶、Sass(动态样式语言)、TS(静态类型语言)、ESlint(代码修复与检查)、Prettier(代码格式化)、Axios(请求库)等一系列包提升开发效率。
对于小项目可能并不需要构建工具,
vue在传统的HTML中使用和单文件组件中使用的语法一致,不同点在于未使用构建工具时没有相应的代码提示,不能使用包管理器,单文件组件不能以.vue形式创建,
所有使用的组件都需要在script中以对象的形式创建,每个组件其实就是一个vue实例,组件实例的模板需要在template中创建。
Vue.js是一套构建用户界面的渐进式框架。
Vue 只关注视图层, 采用自底向上增量开发的设计。
Vue 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。
MapStruct 通过注解处理器在编译时自动生成映射实现类,
生成的代码位于 target/generated-sources/annotations 目录下
EasyCode是基于IntelliJ IDEA Ultimate版开发的一个代码生成插件,
主要通过自定义模板(基于velocity)来生成各种你想要的代码。
通常用于生成Entity、Dao、Service、Controller。
2002年,iBatis框架发布,引入SQL映射
2010年,iBatis框架改名为MyBatis,迁移到Google Code
2013年,MyBatis迁移到Github
MyBatis流行的主要原因
消除了大量的JDBC冗余代码,包括参数设置、结果集封装等
SQL语句单独写在XML配置文件中,可控制,方便优化
学习成本比较低
与Spring集成
Mybatis插件的实现主要基于动态代理和责任链模式。
通过拦截器(interceptor)对Mybatis的核心对象进行拦截和增强,从而实现对SQL执行行为的定制和扩展,
通过JDK动态代理技术,将核心对象(如Executor、ParameterHandler、ResultSetHandler和StatementHandler)包装成代理对象。
这些代理对象在执行方法时,会先检查是否存在对应的插件拦截器,如果存在,则按照配置的拦截顺序执行拦截器链中的各个拦截器。
PageHelper插件通过实现Interceptor接口,在intercept方法中插入分页逻辑来实现分页功能 ,它在Executor的query执行前后进行分页处理
日期格式化 SimpleDateFormat DateTimeFormatter yyyy-MM-dd HH:mm:ss.SSS
Vue 3.0 从 2020 年 9 月份中旬正式发布,到 2022 年 2 月份代替 Vue 2 成为 Vue 的默认版本
.vue 文件,单文件组件 , Single-File Component
.vue 文件里写 HTML / CSS / JS 代码, 语法与 html 类似
< template /> 部分 HTML 代码
< style /> 部分 CSS 代码
< script /> 部分 JavaScript 代码
Vue 提供 Vue Router 实现路由功能,利用 History API 实现单页面模式,
在一个 HTML 页面里也可以体验 “页面跳转” 这样的体验,
但如果页面很多,所有代码都堆积在一个 HTML 页面里,就很难维护。
借助前端工程化的构建工具,开发者可以编写 .vue 单组件文件,
将多个页面的代码根据其功能模块进行划分,可拆分到多个单组件文件里维护并进行合理复用,
最终通过构建工具编译再合并,最终生成浏览器能访问的 HTML / CSS / JS 文件,
这样的开发过程,用户体验没有影响,但开发体验大大提升。
国内源 npmmirror ,下载速度快且同步率高
npm config set registry https://registry.npmmirror.com
npm run dev 启动前端项目开发服务器,
执行 package.json 文件中的 dev 脚本,启动本地服务器并提供实时预览和调试功能,同时确保依赖项的正确安装和配置
HMR 模块热替换 Hot Module Replacement
code_show
hutool 实现下划线与驼峰 互转
String underlineString = "hello_world";
String camelCaseString = StrUtil.toCamelCase (underlineString);
System.out.println (camelCaseString);
System.out.println (StrUtil.toUnderlineCase(camelCaseString));
第一页
上一页
下一页
最后一页