培训机构Day27

今天看老师给我们实现了登录功能前后端实现,在不借助成熟框架来实现对于初学者来说难度确实很大。需要大量时间练习。

知识点:

设计模式:面向对象的语言。对某个特定领域特定场景问题的最佳解决方案。

1.单例模式。singleton。单个实例,单个对象。

1.1 懒汉式:将实例化延迟到第一次获取实例。可以通过双检锁(Double-check)实现线程安全。

1.2 饿汉式:提前创建类的唯一实现,线程安全的。

1.3 登记式:spring框架。可以对任意类进行单例。通用的。

volatile:表示禁止指令重排,禁止优化。一旦有写操作,其它线程第一时间可以看到。

int a = 10;

int b = 20;

int c = 30;

sout(a+b+c)

xxx.properties

xxx.xml

xxx.yml

============================================

监听器:监听特定的事件,当事件发生时,进行特定的业务处理。listener

1.ServletContextListener:最常用。只会触发一次。应用启动时触发。

2.ServletContextAttributeListener:监听全局域对象存储数据,修改数据,移除数据。

3.ServletRequestListener:监听请求创建和销毁的。反复触发。

4.ServletRequestAttributeListener:监听请求域对象存储数据,修改数据,移除数据。

5.HttpSessionListener:监听会话域的创建与销毁。

6.HttpSesssionAttributeListener:监听会话域对象存储数据,修改数据,移除数据。

域对象四种:存储数据的容器。

1.页面域。PageContext,仅限于当前jsp页面。通过页面域,可以获取其余三个域对象。pageContext

2.请求域。HttpServletRequest,每次请求,都会创建全新的请求域对象。request

3.会话域。HttpSession,从首次请求应用开始,直到离开应用,称之为一个会话。session

4.全局域。ServletContext。一个应用有唯一的一个全局域。application

jsp内置对象:9个内置对象。

1.pageContext:页面域

2.request:请求域

3.session:会话域对象

4.application:全局域对象

5.response:响应对象。

EL表达式取数据的顺序:页面域->请求域->会话域->全局域

会话保持技术:

1.Session:HttpSession。当用户离开应用(关闭浏览器窗口),会话消失。或者超过默认超时时间。安全的。

编号:jsessionid=xxxxxxxxxxxxxxxxxxxxxxxx

2.Cookie:客户端浏览器,在每次请求时,可以向服务器传输不大的数据。存储数据在客户端。

---3.使用参数传递。

---4.手动将jessionid设置到请求头中。

5.使用token代替cookie。

过滤器:filter

1.中文编码过滤器。

2.身份验证。

1.请求转发forward:服务器端转发,原来的请求对象和响应对象不变,直接转发到下一个servlet,客户端无感知,地址不变。

适合场景:两个Servlet是共同完成一个事情。

2.重定向redirect:服务器告知客户端改变请求地址,而是创建一个新的请求,客户端地址会发生改变。

适合场景:一个新的请求,完成一个新的事情。

1.认证过滤器,设置过滤/admin/*,尽量不要拦截/*。要求后台所有业务请求必须以/admin/开头,且静态资源文件必须不能以/admin开头。

相关推荐
Kakarotto12 分钟前
Canvas 直线点击事件处理优化
javascript·vue.js·canvas
爱玩泥巴的小t14 分钟前
new Thread().start()底层做了什么?
java
进击的尘埃42 分钟前
Playwright Component Testing 拆到底:组件怎么挂上去的,快照怎么在 CI 里不翻车
javascript
左夕1 小时前
最基础的类型检测工具——typeof, instanceof
前端·javascript
yuki_uix1 小时前
递归:别再"展开脑补"了,学会"信任"才是关键
前端·javascript
用户5757303346244 小时前
🐱 从“猫厂”倒闭到“鸭子”横行:一篇让你笑出腹肌的 JS 面向对象指南
javascript
码路飞4 小时前
GPT-5.4 Computer Use 实战:3 步让 AI 操控浏览器帮你干活 🖥️
java·javascript
进击的尘埃4 小时前
Service Worker 离线缓存这事,没你想的那么简单
javascript
进击的尘埃4 小时前
HTTP/3 的多路复用和 QUIC 到底能让页面快多少?聊聊连接迁移和 0-RTT
javascript
Maxkim5 小时前
前端工程化落地指南:pnpm workspace + Monorepo 核心用法与实践
前端·javascript·架构