行业资讯 2025年06月7日
0 收藏 0 点赞 162 浏览 2194 个字
摘要 :

1.拦截器(Interceptor):定义一个实现HandlerInterceptor接口的拦截器。拦截器就是对一个完整的HTTP请求的各个步骤做一些判断。实现HandlerInterceptor接口需要实现preHa……

1.拦截器(Interceptor):定义一个实现HandlerInterceptor接口的拦截器。拦截器就是对一个完整的HTTP请求的各个步骤做一些判断。实现HandlerInterceptor接口需要实现preHandler,postHandler,afterCompletion方法。

preHandler在请求开始之前需要做的一些事情,判断等。(如通过request.getCookies() ,读取cookie中的ticket,判断ticket是否不为空,没有过期等从而用户是否有效,并确定当前线程用户。每个线程访问的用户不同,需要为每个线程保存一个用户[利用线程本地变量ThreadLocal保存])

postHandler:在渲染之前,将用户传给模板(前端html页面);

afterCompletion:结束之后将当前用户清理干净。

>>拦截器写完之后要注册到MVC中。注册类WebConfiguration需要继承WebMvcConfigurerAdapter类,重写addInterceptors()方法;

>>定义拦截器和定义拦截器的注册类时需要添加注解@Component

2.AOP:面向切面编程。所有业务都需要处理的业务。把遍布应用各处的功能分离出来形成可重用组件。如日志、事务管理等。

 通过切面的注解@Aspect,切入到所有的切点的业务中。

@Before("execution(* com.example.third.controller.*Controller.*(..))")//前置通知,()内表示切点。然后定义在执行所有的ocntroller方法之前要做的事情public void beforeMethod(JoinPoint joinPoint){…}

@After("execution(* com.example.third.controller.IndexController.*(..))")//后置通知,然后定义在执行所有的ocntroller方法之后要做的事情 public void afterMethod(JoinPoint joinPoint){…}

切面=切点+通知;切点表示何处,通知表示时机和方法内容。 

织入:将切面应用到目标对象来创建新的代理对象的过程。Spring的切面由包裹了目标对象的代理类实现,代理类处理方法的调用,执行额外的切面逻辑,并调用目标方法。 

3.基于Redis:

(1)Redis是一个kv(key-value)数据库,它是通过各种命令读取或设置数据。

(2)Redis支持get,set,数值的操作,列表操作(用于最近来访,粉丝列表,消息队列),hash(可变字段,对某些对象的不定属性进行一些设置),集合(点赞用户群,共同好友),排序集合(SortSet,给每个属性设置score.用于排行榜)

(3)Redis的连接方式:

a.简单的一个连接 Jedis jedis=new Jedis()  ;

b.连接池 JedisPool pool=new JedisPool() ;  Jedis jedis=pool.getResource();  用完之后要关闭jedis.close(); 

(4)对于高并发的网页访问,先将相关值存储到redis内存中,隔段时间后再同步更新到数据库。

    (如果直接对数据库操作,对于有上千万个用户同时访问的网页,会不断的更新数据库,update的过程有个锁,过程会很慢);应用redis有上千万个用户同时访问的网页时,访问量不会一直变化,但刷新之后该值会增加很大。

(5)redis用于缓存。数据库MySQL上层加缓存(redis),用户更新以后,缓存失效。每次读取数据优先从缓存中读取,缓存无时再从数据库中查找,减小数据库的压力。

4.异步框架:要执行所有的数据,不是立刻执行,而是通过一个队列,利用EventProducer和EventConsumer来处理。

当用户在登录时,登录以后还想异步做一些事,通过EventProducer发送一个事件,然后会有返回。EventConsumer会初始化好,不断查数据,当EventProducer发送一个事件时,EventConsumer就会收到事件,在根据注册的所有的handler,对事件进行处理。

异步化:把复杂的业务处理流程分开,将需要及时反馈的数据及时反馈,对滞后更新的数据通过事件处理函数由后台逐渐更新。

异步的优势:假设后面一部分流程异常,对主体业务无影响,只是某些操作延后,重启服务器后只要队列还在就可以继续执行相应的操作。

5.云存储(七牛云)SDK:可以把的图片MultipartFile直接传到七牛云上,返回七牛云生成的url

6.登录,注册的核心是HostHolder; 在拦截器里面都保存了当前用户hostHolder,这个用户是从每一次访问的cookie中获取。cookie通过loginTicket在用户登录时存储了用户数据,即每个用户都会分发一个唯一的ticket; 通过ticket识别一个用户。

7.单元测试:(JUnit) 初始化数据;执行要测试的业务;验证测试数据;清理数据。

————————————————

原文链接:https://blog.csdn.net/lvliang2017232003/java/article/details/96020102

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/4097.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

1,043
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

512
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

379
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

479
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

549
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

863
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号