WebMvcConfigurer配置类其实是Spring内部的一种配置方式,采用JavaBean的形式来代替传统的xml配置文件形式进行针对框架个性化定制,可以自定义一些Handler,Interceptor,ViewResolver,MessageConverter。基于java-based方式的spring mvc配置,需要创建一个配置类并实现WebMvcConfigurer接口;
在Spring Boot 1.5版本都是靠重写WebMvcConfigurerAdapter的方法来添加自定义拦截器,消息转换器等。SpringBoot 2.0 后,该类被标记为@Deprecated(弃用)。官方推荐直接实现WebMvcConfigurer或者直接继承WebMvcConfigurationSupport,方式一实现WebMvcConfigurer接口(推荐),方式二继承WebMvcConfigurationSupport类。
public interface WebMvcConfigurer { void configurePathMatch(PathMatchConfigurer var1); void configureContentNegotiation(ContentNegotiationConfigurer var1); void configureAsyncSupport(AsyncSupportConfigurer var1); void configureDefaultServletHandling(DefaultServletHandlerConfigurer var1); void addFormatters(FormatterRegistry var1); void addInterceptors(InterceptorRegistry var1); void addResourceHandlers(ResourceHandlerRegistry var1); void addCorsMappings(CorsRegistry var1); void addViewControllers(ViewControllerRegistry var1); void configureViewResolvers(ViewResolverRegistry var1); void addArgumentResolvers(List<HandlerMethodArgumentResolver> var1); void addReturnValueHandlers(List<HandlerMethodReturnValueHandler> var1); void configureMessageConverters(List<HttpMessageConverter<?>> var1); void extendMessageConverters(List<HttpMessageConverter<?>> var1); void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> var1); void extendHandlerExceptionResolvers(List<HandlerExceptionResolver> var1); Validator getValidator(); MessageCodesResolver getMessageCodesResolver(); }
快捷键组合 | 实现效果 |
---|---|
psvm + Tab键 / main + Tab键 | public static void main(String[] args) |
sout + Tab键 | System.out.println() |
Ctrl + X | 删除当前行 |
Ctrl +D | 复制当前行 |
Alt+Insert(或右键Generate) | 生成代码(如get,set方法,构造函数等) |
Ctrl+Alt+T | 生成try catch (或者 Alt+enter选择) |
CTRL+ALT+T | 把选中的代码放在 TRY{} IF{} ELSE{} 里 |
Ctr+shift+U | 实现大小写之间的转化 |
ALT+回车 | 导入包,自动修正 |
CTRL+ALT+L | 格式化代码 |
CTRL+ALT+I | 自动缩进 |
CTRL+E | 最近更改的代码 |
fori | 生成for (int i = 0; i < ; i++) {} |
Alt + <–左右–>键 | 实现窗口左右更换(多窗口) |
Ctrl + 鼠标点击 | 快速找到成员变量的出处 |
Shift+F6 | 重构/重命名 (包、类、方法、变量、甚至注释等) |
CTRL+Q | 查看当前方法的声明 |
Ctrl+Alt+V | 自动创建变量(new 对象();之后选择按快捷键) |
Ctrl+O | 重写方法 |
Ctrl+I | 实现方法 |
ALT+/ | 代码提示 |
Ctrl+Shift+R | 在当前项目中替换指定内容 |
Ctrl+E | 最近编辑的文件列表 |
Ctrl+P | 显示方法参数信息 |
Ctrl+Shift+Insert | 查看历史复制记录,idea可以保留历史复制的 100 条记录 |
Lombok 是一款好用顺手的工具,就像 Google Guava 一样。可用来帮助开发人员消除 Java 的冗长代码,尤其是对于简单的 Java 对象(POJO)。它通过注释实现这一目的。
通过在开发环境中实现 Lombok,开发人员可以节省构建诸如hashCode()和equals()这样的方法以及以往用来分类各种 accessor 和 mutator 的大量时间。
idea插件市场搜索lombok,安装lombok插件 maven中引入lombok
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.16.8</version> </dependency>
最简单使用就是在对象上使用@Data,就可以自动生成get、set方法
注解 | 含义 |
---|---|
val | 使用val注解可以取代任意类型作为局部变量,这样我们就不用写复杂的ArrayList和Map.Entry类型了 |
@NonNull | 给方法参数增加这个注解,会自动在方法内对该参数进行是否为空的校验,如果为空,则抛出 NPE(NullPointerException) |
@Cleanup | 自动管理资源,用在局部变量之前,在当前变量范围内即将执行完毕退出之前会自动清理资源,自动生成 try-finally 这样的代码来关闭流 |
@Getter/@Setter | 用在属性上,再也不用自己手写 setter 和 getter 方法了,还可以指定访问范围 |
@ToString | 用在类上,可以自动覆写 toString 方法,当然还可以加其他参数,例如@ToString(exclude=”id”)排除 id 属性,或者@ToString(callSuper=true, includeFieldNames=true)调用父类的 toString 方法,包含所有属性 |
@EqualsAndHashCode | 用在类上,自动生成 equals 方法和 hashCode 方法 |
@NoArgsConstructor, @RequiredArgsConstructor and @AllArgsConstructor | 用在类上,自动生成无参构造和使用所有参数的构造函数以及把所有@NonNull 属性作为参数的构造函数,如果指定 staticName = “of”参数,同时还会生成一个返回类对象的静态工厂方法,比使用构造函数方便很多 |
@Data | 注解在类上,相当于同时使用了@ToString、@EqualsAndHashCod- e、@Getter、@Setter 和@RequiredArgsConstrutor 这些注解,对于 POJO 类十分有用 |
@Value | 用在类上,是@Data 的不可变形式,相当于为属性添加 final 声明,只提供 getter 方法,而不提供 setter 方法 |
@Builder | 用在类、构造器、方法上,为你提供复杂的 builder APIs,让你可以像如下方式一样调用 Person.builder().name("Adam Savage").city("San Francisco").job("Mythbusters").job("Unchained Reaction").build();更多说明参考 Builder |
@SneakyThrows | 自动抛受检异常,而无需显式在方法上使用 throws 语句 |
@Synchronized | 用在方法上,将方法声明为同步的,并自动加锁,而锁对象是一个私有的属性 或LOCK,而 java 中的 synchronized 关键字锁对象是 this,锁在 this 或者自己的类对象上存在副作用,就是你不能阻止非受控代码去锁 this 或者类对象,这可能会导致竞争条件或者其它线程错误 |
@Getter(lazy=true) | 可以替代经典的 Double Check Lock 样板代码 |
@Accessors(chain = true) | 加上参数以后就可以开启链式编程 |
@Log | 根据不同的注解生成不同类型的 log 对象,但是实例名称都是 log,有六种可选实现类 |
@CommonsLog | Creates log = org.apache.commons.logging.LogFactory.getLog(LogExample.class); |
@Log | Creates log = java.util.logging.Logger.getLogger(LogExample.class.getName()); |
@Log4j | Creates log = org.apache.log4j.Logger.getLogger(LogExample.class); |
@Log4j2 | Creates log = org.apache.logging.log4j.LogManager.getLogger(LogExample.class); |
@Slf4j | Creates log = org.slf4j.LoggerFactory.getLogger(LogExample.class); |
@XSlf4j | Creates log = org.slf4j.ext.XLoggerFactory.getXLogger(LogExample.class); |
函数作用:从两个表达式中返回一个非null值
用例:select nvl(father_name, mother_name) parent_name from student where student_id = '12345' 注意: 如果expression1的值非空,优先取expression1的值; 如果expression1的值空且expression2的值非空,则取expression2的值; 如果expression1和expression2均为空,则结果为NULL
函数作用:类似if...else...语句块,针对某个字段,如果它的值为value1,则转换为newValue1,如果值为value2,则转换为newValue2,其他情况显示默认值
用例:select decode(id,'1','A','2','B',id) from A; 注意: decode(field_name, value1, new_value1, value2, new_value2, default_value)其中的value1,newValue1等可以是一个表达式
函数作用:将数据集按照某个字段排序,并产生序号字段
用例:select row_number() over(order by name) no,id,name from a;
函数作用:将字符串转换为日期类型
用例:select to_date('20190809','yyyyMMdd') from dual; 注意: 'yyyyMMdd','yyyymmdd','yyyy-MM-dd','yyyy-mm-dd'都可以
函数作用:将其他类型转换为字符串类型
用例1:select to_char(sysdate, 'yyyymmdd') from dual 用例2:select to_char(99, 'fm999.00') from dual 注意: 用例1中还有很多其他的日期格式,如yyyy,mm,dd,D,DD,DDD等 用例2中fm,9,0都有不同的含义,如下表所示
字符标志 | 含义 |
---|---|
9 | 如果存在数字则显示数字,不存在则显示空格 |
0 | 如果存在数字则显示数字,不存在则显示0,即占位符 |
Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很大。 easyexcel重写了poi对07版Excel的解析,一个3M的excel用POI sax解析依然需要100M左右内存,改用easyexcel可以降低到几M,并且再大的excel也不会出现内存溢出;03版依赖POI的sax模式,在上层做了模型转换的封装,让使用者更加简单方便.
<dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.2.0</version> </dependency>
/** * 最简单的读 * <p>1. 创建excel对应的实体对象 参照{@link DemoData} * <p>2. 由于默认一行行的读取excel,所以需要创建excel一行一行的回调监听器,参照{@link DemoDataListener} * <p>3. 直接读即可 */ @Test public void simpleRead() { String fileName = TestFileUtil.getPath() + "demo" + File.separator + "demo.xlsx"; // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭 EasyExcel.read(fileName, DemoData.class, new DemoDataListener()).sheet().doRead(); }
/** * 最简单的写 * <p>1. 创建excel对应的实体对象 参照{@link com.alibaba.easyexcel.test.demo.write.DemoData} * <p>2. 直接写即可 */ @Test public void simpleWrite() { String fileName = TestFileUtil.getPath() + "write" + System.currentTimeMillis() + ".xlsx"; // 这里 需要指定写用哪个class去读,然后写到第一个sheet,名字为模板 然后文件流会自动关闭 // 如果这里想使用03 则 传入excelType参数即可 EasyExcel.write(fileName, DemoData.class).sheet("模板").doWrite(data()); }