首先介绍一下基础概念。
基础概念目前,软件架构主要分为以下两种:
C/S:客户端/服务器端,客户端就是QQ、微信、酷狗音乐等。B/S:浏览器/服务器端,浏览器就是像Github、学校的官网管理系统等。
资源种类主要分为静态资源和动态资源:静态资源:所有用户访问后,得到的结果都是一样的,称为静态资源。静态资源可以直接被浏览器解析。如:html,css,JavaScript等。
动态资源:每个用户访问相同资源后,得到的结果可能不一样,称为动态资源。动态资源被访问后,需要先转换为静态资源,再返回给浏览器。如:servlet/jsp,php,asp等。ASP(Active Server Pages 动态服务器页面)是一种生成动态交互性网页的强有力工具。PHP是一种创建动态交互性站点的强有力的服务器端脚本语言。
网络通信三要素是IP、端口、传输协议:IP:电子设备(计算机)在网络中的唯一标识。
端口:应用程序在计算机中的唯一标识, 范围是0~65536。
传输协议:规定了数据传输的规则。
基础的传输协议有以下两种: tcp:安全协议,三次握手,速度稍慢,QQ邮箱等。 udp:不安全协议,速度快,如腾讯会议等。最后介绍一下关于服务器的知识。计算机是硬件,安装了服务器软件的计算机就是一台服务器,具体来说,安装了mysql服务器软件的计算机就是mysql服务器,安装了web服务器软件的计算机就是web服务器。服务器软件可以接收用户的请求,处理请求,做出响应。web服务器是可以向发出请求的浏览器提供文档的程序。在web服务器软件中,可以部署web项目,让用户通过浏览器来访问这些项目。由于动态资源只能运行在web服务器软件中,因此web服务器也被称为 web容器。常用的服务器是 Tomcat,它由Apache基金组织管理,是中小型的JavaEE服务器,仅仅支持少量的JavaEE规范servlet/jsp,是开源、免费的。在JavaWeb中有三大组件:Servlet、Filter、Listener。Servlet是非常重要的, Filter 和 Li stener比较简单,了解会用即可。 Servlet Servlet是server applet的缩写,顾名思义,运行在服务器端的小程序。可以把Servlet看成一个接口,它定义了Java类被浏览器访问到(tomcat识别)的规则。下面看一个Demo,自定义一个类,实现Servlet接口,复写方法。1. 创建JavaEE项目2. 定义一个类,实现Servlet接口 public class ServletDemo1 implements Servlet3. 实现接口中的抽象方法4. 在web.xml中配置Servlet
package com.zhu.servlet;public class ServletDemo1 implements Servlet { @Override public void init(ServletConfig servletConfig) throws ServletException { System.out.println("ServletDemo1"); } @Override public ServletConfig getServletConfig() { return null; } @Override public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException { } @Override public String getServletInfo() { return null; } @Override public void destroy() { }}
<servlet> <servlet-name>demo1servlet-name> <servlet-class>com.zhu.servlet.ServletDemo1servlet-class> servlet> <servlet-mapping> <servlet-name>demo1servlet-name> <url-pattern>/demo1url-pattern> servlet-mapping>
Tomcat配置如下:
1.被创建:执行init方法,只执行一次。默认情况下,第一次被访问时,Servlet被创建。可以进行如下配置执行Servlet的创建时机。
在标签下配置:a.第一次被访问时,创建on-startup>的值为负数b.在服务器启动时,创建on-startup>的值为
Servlet的init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的,多个用户同时访问时,可能存在线程安全问题。
解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对修改值
2.提供服务:执行service方法,执行多次,每次访问Servlet时,Service方法都会被调用一次。
3.被销毁:执行destroy方法,只执行一次。Servlet被销毁时执行。服务器关闭时,Servlet被销毁.只有服务器正常关闭时,才会执行destroy方法。destroy方法在Servlet被销毁之前执行,一般用于释放资源.
目前,Servlet3.0版本支持注解配置,可以不需要web.xml。1. 创建JavaEE项目,选择Servlet的版本3.0以上,可以不创建web.xml2. 定义一个类,实现Servlet接口3. 复写方法4. 在类上使用@WebServlet注解,进行配置 @WebServlet("/资源路径")
package com.zhu.servlet;@WebServlet("/demo11")public class ServletDemo1 implements Servlet { @Override public void init(ServletConfig servletConfig) throws ServletException { System.out.println("ServletDemo1"); } @Override public ServletConfig getServletConfig() { return null; } @Override public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException { } @Override public String getServletInfo() { return null; } @Override public void destroy() { }}
同理,在浏览器访问http://localhost:8080/s2/demo11即可。Servlet相关配置说明如下:
1.urlpartten:Servlet访问路径:一个Servlet可以定义多个访问路径:@WebServlet({"/d1","/dd1","/ddd1"})2.路径定义规则:a. /xxx:路径匹配b. /xxx/xxx:多层路径,目录结构c. *.do:扩展名匹配
最后,介绍一下Servlet的体系结构。
Servlet :接口。
GenericServlet :抽象类,只复写了service方法,其他方法为空。将Servlet接口中其他的方法做了默认空实现,只将service()方法作为抽象。定义Servlet类时,可以继承GenericServlet,实现service()方法即可
HttpServlet :抽象类,对http协议的一种封装,简化操作。
平时使用最多的就是 HttpServlet抽象类,使用步骤如下:定义类继承HttpServlet复写doGet/doPost方法
public class HelloServletDemo extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { System.out.println("hellodemo"); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); }}
Filter
在日常生活中,过滤器有如净水器,空气净化器等;在web中,当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能。过滤器一般用于完成通用的操作。如:登录验证、统一编码处理、敏感字符过滤等。
使用方法如下:
1. 定义一个类,实现接口Filter 2. 复写方法 3. 配置拦截路径 1. web.xml 2. 注解
@WebFilter("/*")//访问所有资源之前,都会执行该过滤器 public class FilterDemo1 implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { System.out.println("filterDemo1被执行了...."); //放行 filterChain.doFilter(servletRequest,servletResponse); } @Override public void destroy() { } }
web.xml配置:
<filter> <filter-name>demo1filter-name> <filter-class>com.zhu.filter.FilterDemo1filter-class>filter><filter-mapping> <filter-name>demo1filter-name> <url-pattern>/*url-pattern>filter-mapping>
这里的/*表示拦截路径而不是访问路径。
一般地,过滤器执行流程如下:
1. 执行过滤器2. 执行放行后的资源3. 回来执行过滤器放行代码下边的代码
过滤器生命周期及其方法如下:
1. init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次。用于加载资源2. doFilter:每一次请求被拦截资源时,会执行。执行多次3. destroy:在服务器关闭后,Filter对象被销毁。如果服务器是正常关闭,则会执行destroy方法。只执行一次。用于释放资源
关于过滤器,有如下几种配置说明:
拦截路径配置:
1. 具体资源路径:/index.jsp 只有访问index.jsp资源时,过滤器才会被执行2. 拦截目录:/user/* 访问/user下的所有资源时,过滤器都会被执行3. 后缀名拦截:*.jsp 访问所有后缀名为jsp资源时,过滤器都会被执行4. 拦截所有资源:/* 访问所有资源时,过滤器都会被执行
拦截方式配置:资源被访问的方式
注解配置:
设置dispatcherTypes属性1. REQUEST:默认值。浏览器直接请求资源2. FORWARD:转发访问资源3. INCLUDE:包含访问资源4. ERROR:错误跳转资源5. ASYNC:异步访问资源
web.xml配置
设置<dispatcher>dispatcher>标签
当需要配置多个过滤器时可以使用过滤器链,
假设有两个过滤器
过滤器1和过滤器2,则执行顺序为:
1. 过滤器12. 过滤器23. 资源执行4. 过滤器25. 过滤器1
过滤器先后顺序问题:
1. 注解配置:按照类名的字符串比较规则比较,值小的先执行,如:AFilter 和 BFilter,AFilter就先执行了。2. web.xml配置:<filter-mapping>谁定义在上边,谁先执行。
至此,Filter介绍完了,Filter可以对request对象进行增强,增强获取参数相关方法,可以放行,传递代理对象。
Listener
首先,什么是事件监听机制?事件
就是一件事情,事件源即该事件发生的地方,监听器是一个对象,注册监听就是将事件、事件源、监听器绑定在一起。当事件源上发生某个事件后,执行监听器代码。Listener并不非常重要,开发中用的不多。
ServletContextListener:监听ServletContext对象的创建和销毁
方法:
void contextDestroyed(ServletContextEvent sce)ServletContext对象被销毁之前会调用该方法void contextInitialized(ServletContextEvent sce)ServletContext对象创建后会调用该方法
使用步骤如下:
1. 定义一个类,实现ServletContextListener接口2. 复写方法3. 配置
1. web.xml <listener> <listener-class>com.zhu.listener.ContextLoaderListenerlistener-class> listener> 指定初始化参数<context-param>2. 注解: @WebListener
至此,web三大组件基本介绍完毕。