- 保存或更新支付方式
知还215
mybatis-plus填充
由于保存和更新的时候前端不会传入is_deleted,create_time,update_time这三个字段,需要我们手动传入,但每张表手动输入会很繁琐,为了简化该操作可以用以下操作进行声明:is_delete=0表示该表未删除则·我们可以在建表的时候对该字段设置默认值为0·通过可视化工具手动设置对于create_time与update_time可以使用mybatis-plus的自动填充功能(在
- queryWapper的时间类型比较方法
Coder-thinking
数据库数据库mybatis
QueryWrapper是MyBatis-Plus中的一个非常实用的工具类,它可以帮助我们构建更加灵活的查询条件。在QueryWrapper中,我们可以使用各种比较操作符来进行时间比较。以下是一些常用的时间比较操作:等于(eq):queryWrapper.eq("create_time","2021-08-01");不等于(ne):queryWrapper.ne("create_time","20
- 苍穹外卖Day03
guslegend
苍穹外卖
公共字段填充这些字段属于公共字段,也就是也就是在我们的系统中很多表中都会有这些字段,如下:字段名含义数据类型create_time创建时间datetimecreate_user创建人idbigintupdate_time修改时间datetimeupdate_user修改人idbigint如果都按照上述的操作方式来处理这些公共字段,需要在每一个业务方法中进行操作,编码相对冗余、繁琐,那能不能对于这些
- Mybatis获取新增记录(insert)的主键值
博风
#MySQL#OracleMybatisMySQLOracle数据库主键
Mysql、SQLServer:insertintobs_test(uuid,create_time,update_time,status,dm_desc,dm_desc2)values(#{uuid,jdbcType=VARCHAR},now(),now(),#{status,jdbcType=INTEGER},#{dmDesc,jdbcType=VARCHAR},#{dmDesc2,jdbcT
- Oracle数据库表分区
我不许人间见白头
oracle数据库
Oracle数据库表分区表分区按月分区分表按照天分区分表:按照指定的数据分区表分区数据采集的表结构,打算按月分表,按天分区。这样在查询的时候会大大的减少工作量。按月分区分表createtablefq_test(idnumber,namevarchar2(32),create_timedate)partitionbyrange(create_time)interval(numtoyMinterval
- MySQL
Milo(xiu)
数据库mysql数据库
MySQL优化问题一:场景:有一个订单表,数据量千万级,其中有常见的订单状态status字段和创建时间create_time,有一个查询语句:SELECT*FROMordersWHEREstatus=?ORDERBYcreated_timeDESC;假设执行时间大约在十秒,需要优化。该怎么思考进行优化呢?分析过程1.条件:status=?(等值查询)2.排序:created_timeDESC(按创
- 数据库优化实战分享
繢鴻
数据库
数据库优化实战指南一、索引优化策略B+树索引适用场景范围查询(如$WHERE\create_time>'2023-01-01'$)排序操作($ORDER\BY\user_id$)高频等值查询($WHERE\order_no='ABC123'$)索引选择原则通过选择性公式判断索引价值:$$选择性=\frac{不同值数量}{总记录数}$$当选择性>0.3时建议创建索引二、架构设计优化读写分离架构分库分
- Error attempting to get column ‘create_time’ from result set. Cause: java.sql.SQLFeatureNotSupported
学习java的小昂子
javasqlspringboot
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档SpringBoot+MyBatisPlus报错:一、问题原因二、解决方法Errorattemptingtogetcolumn‘create_time’fromresultset.Cause:java.sql.SQLFeatureNotSupported.一、问题原因数据库表的create_time类型为DateTime,而Java中
- Error attempting to get column ‘create_time‘ from result set. Cause: java.sql.SQLFeatureNotSupporte
sui5yue6_
java开发语言mybatis
mysql查询报错,检查了语句是没有问题的2024-06-1217:04:51.742ERROR149792---[io-10000-exec-4]o.a.c.c.C.[.[.[/].[dispatcherServlet]:Servlet.service()forservlet[dispatcherServlet]incontextwithpath[]threwexception[Requestp
- mysql 统计时补全不存在的日期
abc小陈先生
mysqlmysqlsql数据库
需求将指定时间内的数据进行统计,并将无数据的日期补充0task_logs为目标表实际数据SELECTDATE_FORMAT(create_time,'%Y-%m-%d')create_timeFROMtask_logsGROUPBYDATE_FORMAT(create_time,'%Y-%m-%d');补全到目标时间后SELECT@cdate:=date_add(@cdate,INTERVAL-1
- SpringBoot获取用户信息——密码屏蔽问题、驼峰命名和数据库下划线命名不匹配问题
吃老虎的兔子
springboot数据库javaintellij-idea
一、问题描述1)密码屏蔽问题当在Controller类中获取用户信息并将其内容返回时,Jwt会将密码一并解析并输出,造成安全隐患。2)驼峰命名和数据库下划线命名不匹配问题在User类中,命名形式为createTime,而在数据库中对应命名为create_time,导致解析失败。二、解决方法1)在构建User类存储用户信息时,对于password属性添加@JsonIgnore注解//让springs
- MybatisPlus实现自动填充实体类字段值
咸鱼睡不醒_
javaspring开发语言
在软件开发中,实体类的公共字段(如create_time、update_time、create_by、update_by等)频繁需要根据业务规则赋值。传统实现方式通常通过手动编码为这些字段赋值,例如在插入或更新操作前,显式调用setCreateTime(newDate())或从上下文中获取操作人信息。然而,这种模式存在明显痛点:1.代码冗余:每个涉及公共字段的实体类都需要重复编写赋值逻辑,导致
- MySQL性能常用优化技巧总结
慧一居士
关系型数据库mysql数据库
1.索引优化创建合适的索引--为常用查询条件创建索引ALTERTABLEusersADDINDEXidx_email(email);ALTERTABLEordersADDINDEXidx_customer_date(customer_id,order_date);避免索引失效的情况--避免在索引列上使用函数SELECT*FROMusersWHEREDATE(create_time)='2023-0
- hive‘yyyyMMddhhmmssSSS‘字符串转时间‘yyyy-MM-dd HH:mm:ss.SSS‘
追逐☞
hivehive
1、‘yyyyMMddhhmmssSSS’字符串转’yyyy-MM-ddHH:mm:ss’split(from_unixtime(unix_timestamp(createtime,'yyyyMMddHHmmssSSS'),'yyyy-MM-ddHH:mm:ss.SSS'),".00")[0])ascjsj2、‘yyyyMMddhhmmssSSS’字符串转’yyyy-MM-ddHH:mm:ss.S
- 【EasyPan】发送邮箱验证码sendEmailCode
苏格拉没有底_coder
EasyPanjava
【EasyPan】项目常见问题解答(自用&持续更新中…)汇总版一、数据库设计CREATETABLE`email_code`(`email`varchar(150)NOTNULLCOMMENT'邮箱',`code`varchar(5)NOTNULLCOMMENT'验证码',`create_time`datetimeDEFAULTNULLCOMMENT'创建时间',`status`tinyint(1)
- js删除对象中的元素
桃花岛主70
Javascriptuni-appjavascript
if(e.data){letresult=JSON.parse(e.data)this.form=result.item//删除对象中的create_time,update_time元素deletethis.form.create_timedeletethis.form.update_timethis.index=result.indexthis.isedit=trueuni.setNavigat
- java数据分页查询_百万级数据分页查询优化
单单必成
java数据分页查询
一、模拟百万级数据量,采用爆炸式增长方式insertintommw_product(product_name,product_price,product_stock,prodct_barcode,product_img,class_id,status,create_time,update_time)selectproduct_name,product_price,product_stock,pro
- 使用Mybaits-plus自动填充过程中遇到的问题
寻梦人12138
Javamybatis后端java
使用Mybaits-plus自动填充过程中遇到的问题背景说明MetaObjectHandler实现类中的方法是不一样的调用service层中的方法时必须传入实体类对象背景说明在写Oj系统后端时,数据库表根据阿里巴巴java开发规范,每个表都有create_by、create_time、update_by、update_time四个字段,之前的ORM框架因为用的都是Mybatis,所以一直是通过AO
- 解决 Spring Boot 返回日期格式问题
乘风!
springboot后端java
springboot项目有个属性这样注解@DateTimeFormat(pattern="yyyy-MM-dd")privateDatecreateTime;表中是`create_time`datetimeDEFAULTNULL只使用了@DateTimeFormat注解来处理输入格式,但没有配置输出格式。返回给前端还是createTime:"2025-04-05T12:27:36.000+00:0
- MySQL时间转换
可儿·四系桜
#MySQLmysql数据库
1.bigint类型的时间戳1.1将bigint转为datetimeFROM_UNIXTIME(时间戳/1000)1.2将bigint转为date方式一:DATE(FROM_UNIXTIME(时间戳/1000))方式二:字符串隐式转换FROM_UNIXTIME(时间戳/1000,'%Y-%m-%d')1.3将bigint转为指定格式的varcharFROM_UNIXTIME(时间戳/1000,'%
- Flask 学习-95.Flask-SQLAlchemy 查询今天当天的数据
上海-悠悠
flaskflask学习python
前言查询今天的数据,或者查询某一天的数据SQLDATE()function使我们能够从特定的历史或当前时间戳值访问日期值。DATE()函数Date()函数返回从传递的datetime表达式中提取的日期。DATE(datetimeexpression)SQL语句按create_time获取某一天的数据select*frommytablewhereDATE(create_time)=='2022-11
- shell脚本的基础知识_sh脚本,2024年最新25岁成功入职阿里P7的小哥哥告诉你
2401_87298546
linux网络服务器
callappend(2,"#Version:")callappend(3,"#Create_Time:".strftime("%Y/%m/%d"))callappend(4,"#Mail:
[email protected]")callappend(5,"#Info:")callappend(6,"#")callappend(7,"####################################
- FlinkSQL将时间戳转为日期
MARSERERER
sql
FLOOR(TO_TIMESTAMP(FROM_UNIXTIME(CAST(`table_time`ASBIGINT)/1000,'yyyy-MM-ddHH:mm:ss'))TOminute),
- 使用doris过程中总结的与mysql中语法差异
数据游戏
数仓mysql数据库database
1.mysql中的varchar()长度与doris中长度不一致,导致导入失败2.doris中where后面时间与字符串比较需转化类型#当create_time为datetime类型,mysql中使用concat()函数可直接比较,doris则不行,需进行类型转化wheredate_format(create_time,'%Y-%m-%d%H:%i:%s')0
- PostgreSQL | 生成UUID 报错:HINT: No function matches the given name and argument types
慌途L
PostgreSQLpostgresqluuiduuid_generategen_random_uuid
在PG数据库上新建表结构:CREATETABLE"public"."t_test"("guid"uuidNOTNULLDEFAULTuuid_generate_v4(),"data"jsonb,"create_time"timestamptz(6)DEFAULTnow(),CONSTRAINT"test_pkey"PRIMARYKEY("guid"));报错:ERROR:functionuuid_
- postgresql 判断数据是否存在,存在更新,不存在则插入
llc的足迹
数据库postgresql
INSERTINTOtable_name(create_time,update_time,name,latest_time)VALUES(NOW(),NOW(),'name''2023-04-2519:05:50')ONCONFLICT(name)DOUPDATESETupdate_time=NOW(),target_name='name',latest_time='2023-04-2519:05
- THINKPHP like between 的array用法
kang1919
TP
if($title!=''){$_where['title']=array('LIKE','%'.$title.'%');}if(''!=$url){$_where['url']=array('LIKE','%'.$url.'%');}if(0<$start_time&&$start_time<$end_time){$_where['create_time']=array('between',ar
- 若依自动管理数据库表中的公用字段 -- activiti工作流养成计划(四)
唐田震
目标:自动管理数据库表中的公用字段这是个番外篇,略过不会产生任何影响上篇中约定了5个公用字段create_by、create_time、update_by、update_time、remark,其中前四个我都希望它能自己管理。比如我新增数据时它应该自己维护create_by、create_time;我修改数据时它应该自己维护update_by、update_time。有人说可以在mapper.xm
- MyBatis - 批量INSERT
chernyog
XML文件SELECTLAST_INSERT_ID()INSERTINTOmessage_user(user_id,message_id,create_time)values(#{model.userId},#{model.messageId},#{model.createTime})JAVA代码//部分代码messageService.insert(message);intmessageId=m
- 二百二十三、Kettle——从Hive增量导入到ClickHouse(根据day字段判断)
天地风雷水火山泽
Kettlehiveclickhousekettle
一、目的需要用Kettle从Hive的DWS层库表数据增量同步到ClickHouse的ADS层库表中,不过这次的增量判断字段是day字段,不像之前的create_time字段因为day字段需要转换类型,而create_time字段字段不需要转换类型,因此两者的Kettle任务配置有所不同,也踩了一些坑,因此再写一篇博客整理一下,根据day字段判断的情况下kettle如何配置才能从Hive增量导入到
- ios内付费
374016526
ios内付费
近年来写了很多IOS的程序,内付费也用到不少,使用IOS的内付费实现起来比较麻烦,这里我写了一个简单的内付费包,希望对大家有帮助。
具体使用如下:
这里的sender其实就是调用者,这里主要是为了回调使用。
[KuroStoreApi kuroStoreProductId:@"产品ID" storeSender:self storeFinishCallBa
- 20 款优秀的 Linux 终端仿真器
brotherlamp
linuxlinux视频linux资料linux自学linux教程
终端仿真器是一款用其它显示架构重现可视终端的计算机程序。换句话说就是终端仿真器能使哑终端看似像一台连接上了服务器的客户机。终端仿真器允许最终用户用文本用户界面和命令行来访问控制台和应用程序。(LCTT 译注:终端仿真器原意指对大型机-哑终端方式的模拟,不过在当今的 Linux 环境中,常指通过远程或本地方式连接的伪终端,俗称“终端”。)
你能从开源世界中找到大量的终端仿真器,它们
- Solr Deep Paging(solr 深分页)
eksliang
solr深分页solr分页性能问题
转载请出自出处:http://eksliang.iteye.com/blog/2148370
作者:eksliang(ickes) blg:http://eksliang.iteye.com/ 概述
长期以来,我们一直有一个深分页问题。如果直接跳到很靠后的页数,查询速度会比较慢。这是因为Solr的需要为查询从开始遍历所有数据。直到Solr的4.7这个问题一直没有一个很好的解决方案。直到solr
- 数据库面试题
18289753290
面试题 数据库
1.union ,union all
网络搜索出的最佳答案:
union和union all的区别是,union会自动压缩多个结果集合中的重复结果,而union all则将所有的结果全部显示出来,不管是不是重复。
Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
Union All:对两个结果集进行并集操作,包括重复行,不进行排序;
2.索引有哪些分类?作用是
- Android TV屏幕适配
酷的飞上天空
android
先说下现在市面上TV分辨率的大概情况
两种分辨率为主
1.720标清,分辨率为1280x720.
屏幕尺寸以32寸为主,部分电视为42寸
2.1080p全高清,分辨率为1920x1080
屏幕尺寸以42寸为主,此分辨率电视屏幕从32寸到50寸都有
适配遇到问题,已1080p尺寸为例:
分辨率固定不变,屏幕尺寸变化较大。
如:效果图尺寸为1920x1080,如果使用d
- Timer定时器与ActionListener联合应用
永夜-极光
java
功能:在控制台每秒输出一次
代码:
package Main;
import javax.swing.Timer;
import java.awt.event.*;
public class T {
private static int count = 0;
public static void main(String[] args){
- Ubuntu14.04系统Tab键不能自动补全问题解决
随便小屋
Ubuntu 14.04
Unbuntu 14.4安装之后就在终端中使用Tab键不能自动补全,解决办法如下:
1、利用vi编辑器打开/etc/bash.bashrc文件(需要root权限)
sudo vi /etc/bash.bashrc
接下来会提示输入密码
2、找到文件中的下列代码
#enable bash completion in interactive shells
#if
- 学会人际关系三招 轻松走职场
aijuans
职场
要想成功,仅有专业能力是不够的,处理好与老板、同事及下属的人际关系也是门大学问。如何才能在职场如鱼得水、游刃有余呢?在此,教您简单实用的三个窍门。
第一,多汇报
最近,管理学又提出了一个新名词“追随力”。它告诉我们,做下属最关键的就是要多请示汇报,让上司随时了解你的工作进度,有了新想法也要及时建议。不知不觉,你就有了“追随力”,上司会越来越了解和信任你。
第二,勤沟通
团队的力
- 《O2O:移动互联网时代的商业革命》读书笔记
aoyouzi
读书笔记
移动互联网的未来:碎片化内容+碎片化渠道=各式精准、互动的新型社会化营销。
O2O:Online to OffLine 线上线下活动
O2O就是在移动互联网时代,生活消费领域通过线上和线下互动的一种新型商业模式。
手机二维码本质:O2O商务行为从线下现实世界到线上虚拟世界的入口。
线上虚拟世界创造的本意是打破信息鸿沟,让不同地域、不同需求的人
- js实现图片随鼠标滚动的效果
百合不是茶
JavaScript滚动属性的获取图片滚动属性获取页面加载
1,获取样式属性值
top 与顶部的距离
left 与左边的距离
right 与右边的距离
bottom 与下边的距离
zIndex 层叠层次
例子:获取左边的宽度,当css写在body标签中时
<div id="adver" style="position:absolute;top:50px;left:1000p
- ajax同步异步参数async
bijian1013
jqueryAjaxasync
开发项目开发过程中,需要将ajax的返回值赋到全局变量中,然后在该页面其他地方引用,因为ajax异步的原因一直无法成功,需将async:false,使其变成同步的。
格式:
$.ajax({ type: 'POST', ur
- Webx3框架(1)
Bill_chen
eclipsespringmaven框架ibatis
Webx是淘宝开发的一套Web开发框架,Webx3是其第三个升级版本;采用Eclipse的开发环境,现在支持java开发;
采用turbine原型的MVC框架,扩展了Spring容器,利用Maven进行项目的构建管理,灵活的ibatis持久层支持,总的来说,还是一套很不错的Web框架。
Webx3遵循turbine风格,velocity的模板被分为layout/screen/control三部
- 【MongoDB学习笔记五】MongoDB概述
bit1129
mongodb
MongoDB是面向文档的NoSQL数据库,尽量业界还对MongoDB存在一些质疑的声音,比如性能尤其是查询性能、数据一致性的支持没有想象的那么好,但是MongoDB用户群确实已经够多。MongoDB的亮点不在于它的性能,而是它处理非结构化数据的能力以及内置对分布式的支持(复制、分片达到的高可用、高可伸缩),同时它提供的近似于SQL的查询能力,也是在做NoSQL技术选型时,考虑的一个重要因素。Mo
- spring/hibernate/struts2常见异常总结
白糖_
Hibernate
Spring
①ClassNotFoundException: org.aspectj.weaver.reflect.ReflectionWorld$ReflectionWorldException
缺少aspectjweaver.jar,该jar包常用于spring aop中
②java.lang.ClassNotFoundException: org.sprin
- jquery easyui表单重置(reset)扩展思路
bozch
formjquery easyuireset
在jquery easyui表单中 尚未提供表单重置的功能,这就需要自己对其进行扩展。
扩展的时候要考虑的控件有:
combo,combobox,combogrid,combotree,datebox,datetimebox
需要对其添加reset方法,reset方法就是把初始化的值赋值给当前的组件,这就需要在组件的初始化时将值保存下来。
在所有的reset方法添加完毕之后,就需要对fo
- 编程之美-烙饼排序
bylijinnan
编程之美
package beautyOfCoding;
import java.util.Arrays;
/*
*《编程之美》的思路是:搜索+剪枝。有点像是写下棋程序:当前情况下,把所有可能的下一步都做一遍;在这每一遍操作里面,计算出如果按这一步走的话,能不能赢(得出最优结果)。
*《编程之美》上代码有很多错误,且每个变量的含义令人费解。因此我按我的理解写了以下代码:
*/
- Struts1.X 源码分析之ActionForm赋值原理
chenbowen00
struts
struts1在处理请求参数之前,首先会根据配置文件action节点的name属性创建对应的ActionForm。如果配置了name属性,却找不到对应的ActionForm类也不会报错,只是不会处理本次请求的请求参数。
如果找到了对应的ActionForm类,则先判断是否已经存在ActionForm的实例,如果不存在则创建实例,并将其存放在对应的作用域中。作用域由配置文件action节点的s
- [空天防御与经济]在获得充足的外部资源之前,太空投资需有限度
comsci
资源
这里有一个常识性的问题:
地球的资源,人类的资金是有限的,而太空是无限的.....
就算全人类联合起来,要在太空中修建大型空间站,也不一定能够成功,因为资源和资金,技术有客观的限制....
&
- ORACLE临时表—ON COMMIT PRESERVE ROWS
daizj
oracle临时表
ORACLE临时表 转
临时表:像普通表一样,有结构,但是对数据的管理上不一样,临时表存储事务或会话的中间结果集,临时表中保存的数据只对当前
会话可见,所有会话都看不到其他会话的数据,即使其他会话提交了,也看不到。临时表不存在并发行为,因为他们对于当前会话都是独立的。
创建临时表时,ORACLE只创建了表的结构(在数据字典中定义),并没有初始化内存空间,当某一会话使用临时表时,ORALCE会
- 基于Nginx XSendfile+SpringMVC进行文件下载
denger
应用服务器Webnginx网络应用lighttpd
在平常我们实现文件下载通常是通过普通 read-write方式,如下代码所示。
@RequestMapping("/courseware/{id}")
public void download(@PathVariable("id") String courseID, HttpServletResp
- scanf接受char类型的字符
dcj3sjt126com
c
/*
2013年3月11日22:35:54
目的:学习char只接受一个字符
*/
# include <stdio.h>
int main(void)
{
int i;
char ch;
scanf("%d", &i);
printf("i = %d\n", i);
scanf("%
- 学编程的价值
dcj3sjt126com
编程
发一个人会编程, 想想以后可以教儿女, 是多么美好的事啊, 不管儿女将来从事什么样的职业, 教一教, 对他思维的开拓大有帮助
像这位朋友学习:
http://blog.sina.com.cn/s/articlelist_2584320772_0_1.html
VirtualGS教程 (By @林泰前): 几十年的老程序员,资深的
- 二维数组(矩阵)对角线输出
飞天奔月
二维数组
今天在BBS里面看到这样的面试题目,
1,二维数组(N*N),沿对角线方向,从右上角打印到左下角如N=4: 4*4二维数组
{ 1 2 3 4 }
{ 5 6 7 8 }
{ 9 10 11 12 }
{13 14 15 16 }
打印顺序
4
3 8
2 7 12
1 6 11 16
5 10 15
9 14
13
要
- Ehcache(08)——可阻塞的Cache——BlockingCache
234390216
并发ehcacheBlockingCache阻塞
可阻塞的Cache—BlockingCache
在上一节我们提到了显示使用Ehcache锁的问题,其实我们还可以隐式的来使用Ehcache的锁,那就是通过BlockingCache。BlockingCache是Ehcache的一个封装类,可以让我们对Ehcache进行并发操作。其内部的锁机制是使用的net.
- mysqldiff对数据库间进行差异比较
jackyrong
mysqld
mysqldiff该工具是官方mysql-utilities工具集的一个脚本,可以用来对比不同数据库之间的表结构,或者同个数据库间的表结构
如果在windows下,直接下载mysql-utilities安装就可以了,然后运行后,会跑到命令行下:
1) 基本用法
mysqldiff --server1=admin:12345
- spring data jpa 方法中可用的关键字
lawrence.li
javaspring
spring data jpa 支持以方法名进行查询/删除/统计。
查询的关键字为find
删除的关键字为delete/remove (>=1.7.x)
统计的关键字为count (>=1.7.x)
修改需要使用@Modifying注解
@Modifying
@Query("update User u set u.firstna
- Spring的ModelAndView类
nicegege
spring
项目中controller的方法跳转的到ModelAndView类,一直很好奇spring怎么实现的?
/*
* Copyright 2002-2010 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* yo
- 搭建 CentOS 6 服务器(13) - rsync、Amanda
rensanning
centos
(一)rsync
Server端
# yum install rsync
# vi /etc/xinetd.d/rsync
service rsync
{
disable = no
flags = IPv6
socket_type = stream
wait
- Learn Nodejs 02
toknowme
nodejs
(1)npm是什么
npm is the package manager for node
官方网站:https://www.npmjs.com/
npm上有很多优秀的nodejs包,来解决常见的一些问题,比如用node-mysql,就可以方便通过nodejs链接到mysql,进行数据库的操作
在开发过程往往会需要用到其他的包,使用npm就可以下载这些包来供程序调用
&nb
- Spring MVC 拦截器
xp9802
spring mvc
Controller层的拦截器继承于HandlerInterceptorAdapter
HandlerInterceptorAdapter.java 1 public abstract class HandlerInterceptorAdapter implements HandlerIntercep