- ASP.NET Core JWT身份验证实战教程
司莹嫣Maude
ASP.NETCoreJWT身份验证实战教程ASPNETCore2JwtAuthenticationJwtAuthenticationwithoutASP.NETCoreIdentity项目地址:https://gitcode.com/gh_mirrors/as/ASPNETCore2JwtAuthentication项目介绍本教程基于VahidN的ASPNETCore2JwtAuthentica
- RC和RR隔离级别下SELECT操作的读取机制及差异
机械猿--
sql数据库mysqlmybatis
RC(读已提交)和RR(可重复读)隔离级别下不同的查询语句行为不同,读取到的数据可能不同,以下是详细分析:RC(读已提交)隔离级别1.select*fromtablewhereid=1forupdate:读取类型:不管是否在事务中执行forupdate,这都是一种当前读,能确保读取的数据是最新的,因为forupdate会对符合条件的记录加排他锁。因为RC级别下是每次执行forupdate都会新生成
- 分布式锁的实现,基于Redis实现分布式锁
轻浮j
Redis分布式redis数据库
分布式锁的实现,基于Redis实现分布式锁前言基于mysql实现分布式锁基于Reids实现分布式锁基于Redis的具体实现问题1:线程误删锁解决方案一:在删除锁时进行校验问题2:释放锁的检验和释放不具有原子性解决方案:基于lua脚本使检验和删除操作具有原子性其他问题前言对于一些业务来说,比如商品或者优惠卷的抢杀,我们常常需要进行一些加锁的操作比如synchronized等来避免商品的超卖问题,但是
- MyBatis-增删改查操作&一些细节
!!!525
mybatisjava数据库mybatisspringboot
目录删除新增修改查询小结:删除功能需求:根据ID删除用户信息SQL:deletefromuserwhereid=5;Mapper接口方法(注意这里不是实现类):/***根据id删除*/@Delete("deletefromuserwhereid=#{id}")publicvoiddeleteById(Integerid);编写单元测试方法进行测试@TestpublicvoidtestDeleteB
- python比较字符串是否一样,Python如何确定两个字符串是否相同
鲁东学子
python比较字符串是否一样
I'vetriedtounderstandwhenPythonstringsareidentical(akasharingthesamememorylocation).Howeverduringmytests,thereseemstobenoobviousexplanationwhentwostringvariablesthatareequalsharethesamememory:importsy
- MySQL 如何实现乐观锁?
不决问春风
MySQLmysql数据库
MySQL如何实现乐观锁?可以基于版本号实现乐观锁,修改数据的时候带上版本号(或者时间戳):UPDATEstudentSETname='小李',version=2WHEREid=100ANDversion=1在每次数据更新的时候,都带上版本号,同时将版本+1,比如现在要更新id=1,版本号为2的记录,这时候就要先获取id=1的版本号,然后更新语句写成UPDATEtableSETname="小明",
- 微生物数据的sparcc网络分析
桂渊泉树
数据分析r语言
sparcc网络分析运行sparcc首先先安装fastspar,地址https://github.com/scwatts/fastspar整理abundance_counts数据,abundance_counts.txt格式为第一列为featureID,且列名为#OTUID,其他列是样本的OTU丰度然后执行下列脚本fastspar--iterations50--exclude_iterations
- MySQL 大量 IN 的查询优化
陈挨踢
运维数据库mysql数据库优化查询优化sql
背景(1)MySQL8.0版本(2)业务中遇到大量IN的查询,例:SELECTid,username,iconFROMusersWHEREidIN(123,523,1343,...);其中id为主键,IN的列表长度有8000多个问题行数扫描30W+,无法用到主键索引造成MySQLCPU突升,其它的SQL堆积导致HTTP502响应原因MySQL的范围优化器在执行查询优化时,所需消耗的内存超出系统所配
- python提交事务_事务 - 廖雪峰的官方网站
weixin_39995943
python提交事务
在执行SQL语句的时候,某些业务要求,一系列操作必须全部执行,而不能仅执行一部分。例如,一个转账操作:--从id=1的账户给id=2的账户转账100元--第一步:将id=1的A账户余额减去100UPDATEaccountsSETbalance=balance-100WHEREid=1;--第二步:将id=2的B账户余额加上100UPDATEaccountsSETbalance=balance+10
- 【springboot开发】Redis缓存
idiotyi
springboot开发redis缓存springboot
目录1.Redis简介1.1数据类型1.2redis的使用2.Springboot整合Reids2.1添加依赖2.2修改配置2.3开启缓存2.4Config设置2.5使用redis缓存2.6redisrepository方法2.6.1修改config文件2.6.2修改实体类2.6.3repository使用redis2.7keyGenerator2.7.1自定义规则2.7.1使用自定义规则前言:每
- sqli-libs-1字符型
AAran
http://localhost/Less-1/?id=1'测试注入点,出现报错数据库语句应该是:select...from...whereid=’1’......http://localhost/Less-1/?id=1'“使用”不报错,判断为字符型注入,因此需要闭合字符串http://localhost/Less-1/?id=1'orderby4--+http://localhost/Less
- Windows 下python安装redis
luckybabying
一.redis介绍Redis是非关系型的缓存数据库,是一个高性能的key—value数据库二.Python安装redispipinstallredis三.python连接redis1.需要先下载一个Windows版的redis,但是官方的reids并不支持Windows系统,GitHub上有一个开源项目可以下载Windows版的redis,redis下载。https://github.com/Mi
- 秒杀(防止超卖)
Sunny_yiyi
Java精英阶级python前端算法
库存递减Dao/****库存递减*递减数量*商品ID*------->控制超卖andseckill_num>=#{count}秒杀的数量不能大于剩余库存数量*/@Update("updatetb_skusetseckill_num=seckill_num-#{count}whereid=#{id}andseckill_num>=#{count}andislock=1")intdcount(@Par
- Mybatis注解写SQL语句
江西昊仔
达内学习mybatis
1.根据ID查询数据Mapper接口中//注意事项:映射文件和注解二选一@Select("select*fromdemo_userwhereid=#{id}")UserfindUserById(intid);Test中@AutowiredprivateUserMapperuserMapper;//根据ID查询数据@TestpublicvoidfindUserById(){Useruser=user
- Docker
珍珠是蚌的眼泪
云原生dockerk8s
文章目录一.Docker1.1Docker_基础一.Docker参见此篇文章,配合尚硅谷视频。1.1Docker_基础docker就像是一个鲸鱼背上驮着很多的集装箱,每个集装箱是一个容器实例。比如有三个reids实例,就对应三个集装箱,每个集装箱之间互不影响。
- 【笔记】MyBatis配置allowMultiQueries=true允许使用foreach标签批量插入或更新数据
xbronze
代码人生MyBatis
执行update更新操作updatetest_tableoutput_amount=#{item.a},invoice_amount=#{item.b},payment_amount=#{item.c},whereid=#{item.id}执行报错:Errorupdatingdatabase.Cause:java.sql.SQLSyntaxErrorException:Youhaveanerror
- 面试复盘(北京某小公司)
无所畏惧的man
面经面试职场和发展
北京某小公司一面复盘先和面试官做了自我介绍,然后他问了我的一些基本情况。然后开始问项目问:谈一谈项目中有哪些亮点?我用redis来做验证码的缓存,当用户登录时,刷新得到验证码,验证码会被放到redis当中,key为生成的随机字符串,value即为言验证码内容,在cookie当中也会存储这个字符串,当用户提交表单时,后端会取到cookie的值,然后从reids缓存中根据key取到验证码的值进行判断即
- 计算机设计大赛 行人重识别(person reid) - 机器视觉 深度学习 opencv python
iuerfee
python
文章目录0前言1技术背景2技术介绍3重识别技术实现3.1数据集3.2PersonREID3.2.1算法原理3.2.2算法流程图4实现效果5部分代码6最后0前言优质竞赛项目系列,今天要分享的是深度学习行人重识别(personreid)系统该项目较为新颖,适合作为竞赛课题方向,学长非常推荐!学长这里给一个题目综合评分(每项满分5分)难度系数:3分工作量:3分创新点:5分更多资料,项目分享:https:
- FACEBOOK投资人的创业十条之“直面拒绝”
溪水旁葡萄树
"Followthese10commandmentsandyou’llbeonyourwaytostartupsuccess,lifesuccess,aswellasyourhero’sjourney"-TimFerriss"AlloftheadviceIgiveentrepreneurscomesfromlessonsthatIhavepersonallylearned."-ReidHoffma
- Docker创建Reids容器
会飞的麦兜63
redisdocker容器运维
1.默认拉取Redis最新镜像版本dockerpullredis2.下载redis配置文件https://download.redis.io/releases/3.下载配置文件后手动更改密码,链接时间等信息绑定地址(bind):默认情况下,Redis只会监听localhost上的连接。如果需要从外部访问Redis服务器,需要将该配置项设置为服务器的IP地址或者0.0.0.0,以便允许所有网络接口上
- Cesium插件系列——3dtiles压平
搞GIS图形的sky.
cesiumcesium
本系列为自己基于cesium写的一套插件具体实现。这里是根据Cesium提供的CustomShader来实现的。在CustomShader的vertexShaderText里,需要定义vertexMain函数,例如下:structVertexInput{Attributesattributes;FeatureIdsfeatureIds;Metadatametadata;MetadataClassm
- 懒加载配置在mybatis.xml里
别叫我小新
select*fromBlogwhereid=#{id}image.png这个位置在这里哦
- 体验文心一言AI大模型生成一篇关于OpenAI、Notepad++、WPS、pycharm、git、svn、Webstorm、Chrome、Edge和向日葵客户端的报告
「已注销」
文心一言人工智能notepad++
OpenAI是一家非营利性人工智能研究公司,致力于研究人工智能和其他机器学习技术1。OpenAI由一群科技领袖,包括山姆·阿尔特曼(SamAltman)、彼得·泰尔(PeterThiel)、里德·霍夫曼(ReidHoffman)和埃隆·马斯克(ElonMusk)等人创办于2015年12。OpenAI免费体验OpenAIOpenAI是一个人工智能研究实验室,由营利组织OpenAILP与母公司非营利组
- 为什么要学redis,我来告诉你 ❤️
卢卢在路上
redis数据库memcached高并发
曾经并肩往前的伙伴,在举杯祝福后都走散!一、引言为啥需要redis?没有reids有啥问题?↓1.1数据库压力过大由于用户量增大,请求数量也随之增大,数据压力过大1.2数据不同步多台服务器之间,数据不同步1.3传统锁失效多台服务器之间的锁,已经不存在互斥性了redis如何解决这些问题?↓二、Redis介绍2.1NoSQL介绍Redis就是一款NoSQL。NoSQL->非关系型数据库->NotOnl
- 行人重识别
NineDays66
人工智能
在人的感知系统所获得的信息中,视觉信息大约占到80%~85%。行人重识别(personre-identification)是近几年智能视频分析领域兴起的一项新技术,属于在复杂视频环境下的图像处理和分析范畴,是许多监控和安防应用中的主要任务,并且在计算机视觉领域获得了越来越多的关注。下面我们就仔细来聊聊行人重识别(ReID)。1.什么是行人重识别行人重识别(PersonRe-identificat
- MySQL之单表操作
爱吃柠檬的天天
数据库mysql数据库
MySQL之单表操作文章目录MySQL之单表操作一、单表查询二、单表操作1、复制表结构2、插入数据3、删除数据4、更新数据5、排序6、限量7、分组三、常用函数一、单表查询单表查询的语句为SELECTFROM,同时可以在后面加入WHERE属性进行条件限制。这里以查询学号为123456的全部数据为例。SELECT*FROMstudentWHEREID='123456';除此以外还能对数据进行判断符操作
- Redis主从集群
钗头风
redis数据库缓存
一.架构模式二.资源分布操作系统:Centos7Redis版本:6.2.14IP端口角色192.168.157.1306379master192.168.157.1316379slave1192.168.157.1326379slave2三.流程1.创建三台虚拟机IP及端口如上且安装好Reids说明:安装好Redis的意思是无需额外配置;Redis能正常启动即可2.修改三个redis.conf配置
- MyBatis进阶学习
m0_57408062
mybatis学习java
1.如何复制Maven项目1.复制文件夹,修改名字2.修改.iml文件的名字和文件夹名字一致3.修改.xml中为文件夹名字2.MyBatis增删改查MyBatis三种开发方式①接口代理的开发方式(重点)②使用注解的开发方式(重点)③传统DAO实现类的开发方式(目前淘汰)1.根据id查询注意:#{变量}select*fromuserwhereid=?;?表示占位符,是预编译的效果,不会有SQL注入的
- 1.15 freertos 计数器生产和消费模型
久驻
开发语言
osSemaphoreId_tmyCountingSem01Handle;constosSemaphoreAttr_tmyCountingSem01_attributes={.name="myCountingSem01"};myCountingSem01Handle=osSemaphoreNew(5,0,&myCountingSem01_attributes);voidStartTask02(vo
- MyBatis联表查询时,主查询表的字段怎么统一加别名(通用方案)
晓晓先生
一般来说,MyBatis生成的xmlsql文件中,会有一个Base_Column_List,方便查询时直接引用。如下:selectfromtbl_productwhereid=id可是有时候需要联表查询,这时候如果依然这样写显然是不行的,两个表很可能有许多相同的字段,这时候就需要给查询的字段加上表名:selecttp.id,tp.name,tp....fromtbl_producttpleftjo
- 多线程编程之卫生间
周凡杨
java并发卫生间线程厕所
如大家所知,火车上车厢的卫生间很小,每次只能容纳一个人,一个车厢只有一个卫生间,这个卫生间会被多个人同时使用,在实际使用时,当一个人进入卫生间时则会把卫生间锁上,等出来时打开门,下一个人进去把门锁上,如果有一个人在卫生间内部则别人的人发现门是锁的则只能在外面等待。问题分析:首先问题中有两个实体,一个是人,一个是厕所,所以设计程序时就可以设计两个类。人是多数的,厕所只有一个(暂且模拟的是一个车厢)。
- How to Install GUI to Centos Minimal
sunjing
linuxInstallDesktopGUI
http://www.namhuy.net/475/how-to-install-gui-to-centos-minimal.html
I have centos 6.3 minimal running as web server. I’m looking to install gui to my server to vnc to my server. You can insta
- Shell 函数
daizj
shell函数
Shell 函数
linux shell 可以用户定义函数,然后在shell脚本中可以随便调用。
shell中函数的定义格式如下:
[function] funname [()]{
action;
[return int;]
}
说明:
1、可以带function fun() 定义,也可以直接fun() 定义,不带任何参数。
2、参数返回
- Linux服务器新手操作之一
周凡杨
Linux 简单 操作
1.whoami
当一个用户登录Linux系统之后,也许他想知道自己是发哪个用户登录的。
此时可以使用whoami命令。
[ecuser@HA5-DZ05 ~]$ whoami
e
- 浅谈Socket通信(一)
朱辉辉33
socket
在java中ServerSocket用于服务器端,用来监听端口。通过服务器监听,客户端发送请求,双方建立链接后才能通信。当服务器和客户端建立链接后,两边都会产生一个Socket实例,我们可以通过操作Socket来建立通信。
首先我建立一个ServerSocket对象。当然要导入java.net.ServerSocket包
ServerSock
- 关于框架的简单认识
西蜀石兰
框架
入职两个月多,依然是一个不会写代码的小白,每天的工作就是看代码,写wiki。
前端接触CSS、HTML、JS等语言,一直在用的CS模型,自然免不了数据库的链接及使用,真心涉及框架,项目中用到的BootStrap算一个吧,哦,JQuery只能算半个框架吧,我更觉得它是另外一种语言。
后台一直是纯Java代码,涉及的框架是Quzrtz和log4j。
都说学前端的要知道三大框架,目前node.
- You have an error in your SQL syntax; check the manual that corresponds to your
林鹤霄
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'option,changed_ids ) values('0ac91f167f754c8cbac00e9e3dc372
- MySQL5.6的my.ini配置
aigo
mysql
注意:以下配置的服务器硬件是:8核16G内存
[client]
port=3306
[mysql]
default-character-set=utf8
[mysqld]
port=3306
basedir=D:/mysql-5.6.21-win
- mysql 全文模糊查找 便捷解决方案
alxw4616
mysql
mysql 全文模糊查找 便捷解决方案
2013/6/14 by 半仙
[email protected]
目的: 项目需求实现模糊查找.
原则: 查询不能超过 1秒.
问题: 目标表中有超过1千万条记录. 使用like '%str%' 进行模糊查询无法达到性能需求.
解决方案: 使用mysql全文索引.
1.全文索引 : MySQL支持全文索引和搜索功能。MySQL中的全文索
- 自定义数据结构 链表(单项 ,双向,环形)
百合不是茶
单项链表双向链表
链表与动态数组的实现方式差不多, 数组适合快速删除某个元素 链表则可以快速的保存数组并且可以是不连续的
单项链表;数据从第一个指向最后一个
实现代码:
//定义动态链表
clas
- threadLocal实例
bijian1013
javathreadjava多线程threadLocal
实例1:
package com.bijian.thread;
public class MyThread extends Thread {
private static ThreadLocal tl = new ThreadLocal() {
protected synchronized Object initialValue() {
return new Inte
- activemq安全设置—设置admin的用户名和密码
bijian1013
javaactivemq
ActiveMQ使用的是jetty服务器, 打开conf/jetty.xml文件,找到
<bean id="adminSecurityConstraint" class="org.eclipse.jetty.util.security.Constraint">
<p
- 【Java范型一】Java范型详解之范型集合和自定义范型类
bit1129
java
本文详细介绍Java的范型,写一篇关于范型的博客原因有两个,前几天要写个范型方法(返回值根据传入的类型而定),竟然想了半天,最后还是从网上找了个范型方法的写法;再者,前一段时间在看Gson, Gson这个JSON包的精华就在于对范型的优雅简单的处理,看它的源代码就比较迷糊,只其然不知其所以然。所以,还是花点时间系统的整理总结下范型吧。
范型内容
范型集合类
范型类
- 【HBase十二】HFile存储的是一个列族的数据
bit1129
hbase
在HBase中,每个HFile存储的是一个表中一个列族的数据,也就是说,当一个表中有多个列簇时,针对每个列簇插入数据,最后产生的数据是多个HFile,每个对应一个列族,通过如下操作验证
1. 建立一个有两个列族的表
create 'members','colfam1','colfam2'
2. 在members表中的colfam1中插入50*5
- Nginx 官方一个配置实例
ronin47
nginx 配置实例
user www www;
worker_processes 5;
error_log logs/error.log;
pid logs/nginx.pid;
worker_rlimit_nofile 8192;
events {
worker_connections 4096;}
http {
include conf/mim
- java-15.输入一颗二元查找树,将该树转换为它的镜像, 即在转换后的二元查找树中,左子树的结点都大于右子树的结点。 用递归和循环
bylijinnan
java
//use recursion
public static void mirrorHelp1(Node node){
if(node==null)return;
swapChild(node);
mirrorHelp1(node.getLeft());
mirrorHelp1(node.getRight());
}
//use no recursion bu
- 返回null还是empty
bylijinnan
javaapachespring编程
第一个问题,函数是应当返回null还是长度为0的数组(或集合)?
第二个问题,函数输入参数不当时,是异常还是返回null?
先看第一个问题
有两个约定我觉得应当遵守:
1.返回零长度的数组或集合而不是null(详见《Effective Java》)
理由就是,如果返回empty,就可以少了很多not-null判断:
List<Person> list
- [科技与项目]工作流厂商的战略机遇期
comsci
工作流
在新的战略平衡形成之前,这里有一个短暂的战略机遇期,只有大概最短6年,最长14年的时间,这段时间就好像我们森林里面的小动物,在秋天中,必须抓紧一切时间存储坚果一样,否则无法熬过漫长的冬季。。。。
在微软,甲骨文,谷歌,IBM,SONY
- 过度设计-举例
cuityang
过度设计
过度设计,需要更多设计时间和测试成本,如无必要,还是尽量简洁一些好。
未来的事情,比如 访问量,比如数据库的容量,比如是否需要改成分布式 都是无法预料的
再举一个例子,对闰年的判断逻辑:
1、 if($Year%4==0) return True; else return Fasle;
2、if ( ($Year%4==0 &am
- java进阶,《Java性能优化权威指南》试读
darkblue086
java性能优化
记得当年随意读了微软出版社的.NET 2.0应用程序调试,才发现调试器如此强大,应用程序开发调试其实真的简单了很多,不仅仅是因为里面介绍了很多调试器工具的使用,更是因为里面寻找问题并重现问题的思想让我震撼,时隔多年,Java已经如日中天,成为许多大型企业应用的首选,而今天,这本《Java性能优化权威指南》让我再次找到了这种感觉,从不经意的开发过程让我刮目相看,原来性能调优不是简单地看看热点在哪里,
- 网络学习笔记初识OSI七层模型与TCP协议
dcj3sjt126com
学习笔记
协议:在计算机网络中通信各方面所达成的、共同遵守和执行的一系列约定 计算机网络的体系结构:计算机网络的层次结构和各层协议的集合。 两类服务: 面向连接的服务通信双方在通信之前先建立某种状态,并在通信过程中维持这种状态的变化,同时为服务对象预先分配一定的资源。这种服务叫做面向连接的服务。 面向无连接的服务通信双方在通信前后不建立和维持状态,不为服务对象
- mac中用命令行运行mysql
dcj3sjt126com
mysqllinuxmac
参考这篇博客:http://www.cnblogs.com/macro-cheng/archive/2011/10/25/mysql-001.html 感觉workbench不好用(有点先入为主了)。
1,安装mysql
在mysql的官方网站下载 mysql 5.5.23 http://www.mysql.com/downloads/mysql/,根据我的机器的配置情况选择了64
- MongDB查询(1)——基本查询[五]
eksliang
mongodbmongodb 查询mongodb find
MongDB查询
转载请出自出处:http://eksliang.iteye.com/blog/2174452 一、find简介
MongoDB中使用find来进行查询。
API:如下
function ( query , fields , limit , skip, batchSize, options ){.....}
参数含义:
query:查询参数
fie
- base64,加密解密 经融加密,对接
y806839048
经融加密对接
String data0 = new String(Base64.encode(bo.getPaymentResult().getBytes(("GBK"))));
String data1 = new String(Base64.decode(data0.toCharArray()),"GBK");
// 注意编码格式,注意用于加密,解密的要是同
- JavaWeb之JSP概述
ihuning
javaweb
什么是JSP?为什么使用JSP?
JSP表示Java Server Page,即嵌有Java代码的HTML页面。使用JSP是因为在HTML中嵌入Java代码比在Java代码中拼接字符串更容易、更方便和更高效。
JSP起源
在很多动态网页中,绝大部分内容都是固定不变的,只有局部内容需要动态产生和改变。
如果使用Servl
- apple watch 指南
啸笑天
apple
1. 文档
WatchKit Programming Guide(中译在线版 By @CocoaChina) 译文 译者 原文 概览 - 开始为 Apple Watch 进行开发 @星夜暮晨 Overview - Developing for Apple Watch 概览 - 配置 Xcode 项目 - Overview - Configuring Yo
- java经典的基础题目
macroli
java编程
1.列举出 10个JAVA语言的优势 a:免费,开源,跨平台(平台独立性),简单易用,功能完善,面向对象,健壮性,多线程,结构中立,企业应用的成熟平台, 无线应用 2.列举出JAVA中10个面向对象编程的术语 a:包,类,接口,对象,属性,方法,构造器,继承,封装,多态,抽象,范型 3.列举出JAVA中6个比较常用的包 Java.lang;java.util;java.io;java.sql;ja
- 你所不知道神奇的js replace正则表达式
qiaolevip
每天进步一点点学习永无止境纵观千象regex
var v = 'C9CFBAA3CAD0';
console.log(v);
var arr = v.split('');
for (var i = 0; i < arr.length; i ++) {
if (i % 2 == 0) arr[i] = '%' + arr[i];
}
console.log(arr.join(''));
console.log(v.r
- [一起学Hive]之十五-分析Hive表和分区的统计信息(Statistics)
superlxw1234
hivehive分析表hive统计信息hive Statistics
关键字:Hive统计信息、分析Hive表、Hive Statistics
类似于Oracle的分析表,Hive中也提供了分析表和分区的功能,通过自动和手动分析Hive表,将Hive表的一些统计信息存储到元数据中。
表和分区的统计信息主要包括:行数、文件数、原始数据大小、所占存储大小、最后一次操作时间等;
14.1 新表的统计信息
对于一个新创建
- Spring Boot 1.2.5 发布
wiselyman
spring boot
Spring Boot 1.2.5已在7月2日发布,现在可以从spring的maven库和maven中心库下载。
这个版本是一个维护的发布版,主要是一些修复以及将Spring的依赖提升至4.1.7(包含重要的安全修复)。
官方建议所有的Spring Boot用户升级这个版本。
项目首页 | 源