2024年最新JSP的Web监听器(Listener),前端高级工程师每日面试题精选

最后

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

❤️ 谢谢支持,喜欢的话别忘了 关注、点赞哦。

前端校招面试题精编解析大全

实现方式:直接实现HttpSessionListener接口:

public class MyHttpSessionListener implements HttpSessionListener{

public void sessionCreated(HttpSessionEvent arg0) {

}

public void sessionDestroyed(HttpSessionEvent arg0) {

}

}

ServletRequest监控:对应监控request内置对象的创建和销毁。

当访问某个页面时,出发一个request请求,执行requestInitialized方法;当页面关闭时,执行requestDestroyed方法。

实现方式,直接实现ServletRequestListener接口:

public class MyServletRequestListener implements ServletRequestListener{

public void requestDestroyed(ServletRequestEvent arg0) {

}

public void requestInitialized(ServletRequestEvent arg0) {

}

}

  1. 按照监听事件划分:

监听事件自身的创建和销毁:同上面的按对象划分。

监听属性的新增、删除和修改也是划分成三种,分别针对于ServletContext、HttpSession、ServletRequest对象:

ServletContext,实现ServletContextAttributeListener接口:

通过调用ServletContextAttribtueEvent的getName方法可以得到属性的名称。

public class MyServletContextAttrListener implements ServletContextAttributeListener{

public void attributeAdded(ServletContextAttributeEvent hsbe) {

System.out.println("In servletContext added :name = "+hsbe.getName());

}

public void attributeRemoved(ServletContextAttributeEvent hsbe) {

System.out.println("In servletContext removed :name = "+hsbe.getName());

}

public void attributeReplaced(ServletContextAttributeEvent hsbe) {

System.out.println("In servletContext replaced :name = "+hsbe.getName());

}

}

HttpSession,实现HttpSessionAttributeListener接口:

public class MyHttpSessionAttrListener implements HttpSessionAttributeListener{

public void attributeAdded(HttpSessionBindingEvent hsbe) {

System.out.println("In httpsession added:name = "+hsbe.getName());

}

public void attributeRemoved(HttpSessionBindingEvent hsbe) {

System.out.println("In httpsession removed:name = "+hsbe.getName());

}

public void attributeReplaced(HttpSessionBindingEvent hsbe) {

System.out.println("In httpsession replaced:name = "+hsbe.getName());

}

}

ServletRequest,实现ServletRequestAttributeListener接口:

public class MyServletRequestAttrListener implements ServletRequestAttributeListener{

public void attributeAdded(ServletRequestAttributeEvent hsbe) {

System.out.println("In servletrequest added :name = "+hsbe.getName());

}

public void attributeRemoved(ServletRequestAttributeEvent hsbe) {

System.out.println("In servletrequest removed :name = "+hsbe.getName());

}

public void attributeReplaced(ServletRequestAttributeEvent hsbe) {

System.out.println("In servletrequest replaced :name = "+hsbe.getName());

}

}

  1. 监听对象的状态:

针对某些POJO类,可以通过实现HttpSessionBindingListener接口,监听POJO类对象的事件。例如:

public class User implements HttpSessionBindingListener,Serializable{

private String username;

private String password;

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username = username;

}

public String getPassword() {

return password;

}

public void setPassword(String password) {

this.password = password;

}

public void valueBound(HttpSessionBindingEvent hsbe) {

System.out.println("valueBound name: "+hsbe.getName());

}

public void valueUnbound(HttpSessionBindingEvent hsbe) {

System.out.println("valueUnbound name: "+hsbe.getName());

}

}

Session数据的钝化与活化:

由于session中保存大量访问网站相关的重要信息,因此过多的session数据就会服务器性能的下降,占用过多的内存。因此类似数据库对象的持久化,web容器也会把不常使用的session数据持久化到本地文件或者数据中。这些都是有web容器自己完成,不需要用户设定。

不用的session数据序列化到本地文件中的过程,就是钝化;

当再次访问需要到该session的内容时,就会读取本地文件,再次放入内存中,这个过程就是活化。

类似的,只要实现HttpSeesionActivationListener接口就是实现钝化与活化事件的监听:

public class User implements HttpSessionBindingListener,

HttpSessionActivationListener,Serializable{

private String username;

private String password;

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username = username;

}

public String getPassword() {

return password;

}

public void setPassword(String password) {

this.password = password;

TCP协议

  • TCP 和 UDP 的区别?
  • TCP 三次握手的过程?
  • 为什么是三次而不是两次、四次?
  • 三次握手过程中可以携带数据么?
  • 说说 TCP 四次挥手的过程
  • 为什么是四次挥手而不是三次?
  • 半连接队列和 SYN Flood 攻击的关系
  • 如何应对 SYN Flood 攻击?
  • 介绍一下 TCP 报文头部的字段
  • TCP 快速打开的原理(TFO)
  • 说说TCP报文中时间戳的作用?
  • TCP 的超时重传时间是如何计算的?
  • TCP 的流量控制
  • TCP 的拥塞控制
  • 说说 Nagle 算法和延迟确认?
  • 如何理解 TCP 的 keep-alive?

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

浏览器篇
  • 浏览器缓存?
  • 说一说浏览器的本地存储?各自优劣如何?
  • 说一说从输入URL到页面呈现发生了什么?
  • 谈谈你对重绘和回流的理解
  • XSS攻击
  • CSRF攻击
  • HTTPS为什么让数据传输更安全?
  • 实现事件的防抖和节流?
  • 实现图片懒加载?

ive?

[外链图片转存中…(img-zMgo6Xg9-1715064521111)]

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

浏览器篇
  • 浏览器缓存?
  • 说一说浏览器的本地存储?各自优劣如何?
  • 说一说从输入URL到页面呈现发生了什么?
  • 谈谈你对重绘和回流的理解
  • XSS攻击
  • CSRF攻击
  • HTTPS为什么让数据传输更安全?
  • 实现事件的防抖和节流?
  • 实现图片懒加载?

[外链图片转存中…(img-hP5MXeeo-1715064521112)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值