//一、使用@Valid @NotNull 启动项目请求,参数为空,
// 好像没有效果。原因是只加了jar包:javax.validation:validation-api,这个包是一个规范,并没有实现
// spring 的默认实现是 org.hibernate:hibernate-validator 加上即可。
// 再次请求 返回400,
//看日志是校验未通过,接下来就是校验异常后处理了。使用以下代码处理
@ResponseBody
@ExceptionHandler(MethodArgumentNotValidException.class)
public String bindException(MethodArgumentNotValidException e) {
QrResponse res = new QrResponse();
res.setBack("中文");
String result = JSON.toJSONString(res);
return result;//(本项目是返回json字符串)
}
//不在显示400异常stack了。
//然而仔细看返回的json ,发现出现了乱码
//二、网上一查全是说@Notnull等的提示信息乱码
//@NotNull等注解是可以自定义提示信息的,都是说这个提示信息乱码怎么解决。
//我并不关心提示信息,整了半天,最后clean了重新打包好了
//三、自定义校验
public class ScanValidator implements ConstraintValidator<ScanAnnotation,ADTO> {
//ScanAnnotation 自定义注解,可以放到类上,属性上,仿@notnull
//ADTO 需要校验的类或属性
}
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE})
@Constraint(validatedBy = ScanValidator.class) //这句别忘了
public @interface ScanAnnotation {
}$# 表示传入脚本的参数2. grep -a xx 筛选文件内容(解决报错binary 问题)
grep -C num 显示搜索内容的前后num行
-v 反向查询
-i 忽略大小写
3. 自定义命令
alias cdl='cd /home/wtposp/logs/'
alias cdc='cd /var/www/pro/transaction_agent/current/transaction_agent/WEB-INF/classes/'
alias cdt='cd /var/www/apps/transaction_agent/java/apache-tomcat-8.5.24/bin'
永久生效: 修改~/.bashrc 文件,source ~/.bashrc
4. 切换用户 :
su : switch user 切换用户 , 参数 - 表示切换用户,并且切换到用户环境。默认不写用户是切到root
sudo 临时获取root权限执行命令。
sudo su 临时获取root权限执行命令su切换到root ,
su username 切换到普通用户,exit 即可回到root 用户。
5. ps -aux |grep 查看进程cpu ,内存占用情况
top -p pid 查看进程资源占用情况。
【其他】
1. solid原则:单一,开闭,里氏,接口,依赖倒置,迪米特。
2. win + shift + s win系统自带【截图工具】,截图后点击后上角复制即可复制。
3. alt + A 微信自带截图工具
4. xshell 快捷键 ctrl +w 删除光标前一个单词,ctrl+u 删除光标前所有单词 , crtl+Y 撤销删除
5. maven生命周期有三个: 默认default , clean 和 site . 常用的clean 和 install(默认生命周期)不在一个生命周期里(重点)。
所以不要以为install会自动执行clean(尤其在你删除了文件后,不clean,直接install可能会发现删除的文件还在包里,晕).
install 对应的default 生命周期为: validate,compile,test,package,verify,install,deploy
6. 如果excel不能编辑,可以先打开word,再重新打开excel 即可编辑。
7. ThreadPoolExecutor.submit() 可以返回的含义:其实是sumbit方法内部将线程包装成futureTask,仍然调用的是execute()方法,然后返回包装后的可以通过
的futureTask 而不是说submit直接返回线程执行结果。 用户如需获取线程返回值,可以通过futureTask.get()方法阻塞线程等待线程返回。