首先我们先识别web.xml中的各项标签元素的加载顺序,结论如下:
context-param(上下文参数) -> listener -> filter -> servlet
不同层次的标签元素的加载顺序并不按照标签元素的书写顺序加载
但是同级的(如两个filter)标签元素加载顺序与书写顺序有关
注意:某些标签元素存在关联的
如:filter-mapping必须出现在filter之后,否则当解析到filter-mapping时,它所对应的filter-name还未定义
listener 用于监听 Servlet,核心接口是 ServletContextListener,继承自 EventListener。
监听客户端的请求、服务端的操作等。
通过监听器,可以触发一些操作,比如监听在线的用户的数量、监听session超时与否等。
<!-- Session超时检测类 -->
<listener>
<listener-class>com.mebugs.listener.HttpSessionTimeOutListener</listener-class>
</listener>
filter 用于过滤到 servlet 的 request。
filter 可以改变一个 request 和修改一个 response,实现 Filter 接口。
filter 不是 servlet,不能产生 response,能够在一个 request 到达 servlet 之前预处理,也可以在离开 servlet 时处理 response。
<!-- 过滤资源请求,要求登录后才能请求页面 -->
<filter>
<filter-name>GetUrlRequestFilter</filter-name>
<filter-class>com.mebugs.filter.GetUrlRequestFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>GetUrlRequestFilter</filter-name>
<url-pattern>/mebugs/page/*</url-pattern>
</filter-mapping>
servlet 容器可以理解为一个服务端接受端,继承 HttpServlet。
servlet 可以接受request请求,通过相应的逻辑处理,并返回reponse,一个通俗的前后台交互层。
<!-- 秘钥一键登录鉴权 -->
<servlet>
<servlet-name>OneKeyLogin</servlet-name>
<servlet-class>com.net.sobest.login.OneKeyLoginAction</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>OneKeyLogin</servlet-name>
<url-pattern>/OneKey_Authenticate</url-pattern>
</servlet-mapping>
现阶段的开发进入微服务时代,大家已经习惯直接使用 SpringBoot 进行 web 服务开发。
但实际上在底层依旧使用了这些技术。
当前还没有观点发布,欢迎您留下足迹!
JAVA中通过继承Thread类、实现Runnable接口以及实现Callable接口配合Future接口实现创建多线程,三种方式各有优缺点,而第三种则具备更多的增强能力
SpringBoot 可以通过 spring.profiles.active 属性指定生效不同配置文件来满足多环境要求,多环境更为复杂的场景,就需要理解配置文件生效优先级,考虑直接引入外部配置项和配置文件
在JAVA的WEB工程中我们可以将JSP页面文件放在WEB-INFO中限制用户进行URL直接访问,但静态资源如js、css文件却是需要被外部直接访问的,直接对外暴露又不太安全,可以通过自定义过滤器处理
scope属性主要用于控制依赖范围,主要分为编译、打包、运行、测试、依赖传递等各个常见,scope不同于optional提供了更多可选择的配置参数用于应对不同的依赖场景。
JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;动态获取的信息以及动态调用对象的方法的功能。
在绝大多数的JAVA经典应用框架中广泛使用到了单例设计模式,单例设计模式最普遍的分类方式分类分为懒汉模式与饿汉模式两种,其主要区别在于初始化创建对象的时机不同。