参考:
参考:
①、xmlns:h="http://xmlns.jcp.org/xml/ns/javaee"
为h
元素定义一个命名空间,"http://xmlns.jcp.org/xml/ns/javaee"
是标识该空间的唯一字符串(常采用URL形式)
②、xmlns="http://xmlns.jcp.org/xml/ns/javaee"
默认空间的唯一标识符"http://xmlns.jcp.org/xml/ns/javaee"
对于命名空间的标识符, URI 的作用仅仅是保证唯一性, 它并不需要对应一个可以访问的资源或文件 ! 但是, 有很多公司都会让namespace 的 URI 指向一个包含该命名空间信息的网页。
③、xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
④、xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
根据之前的知识我们可以理解, xmlns:xsi 定义了一个命名空间前缀 xsi
对应的唯一字符串 http://www.w3.org/2001/XMLSchema-instance
。 但是读者会发现, 这个 xmlns:xsi
在不同的 xml 文档中似乎都会出现。 这是因为, xsi
已经成为了一个业界默认的用于 XSD(XML Schema Definition) 文件的命名空间。 而 XSD 文件(也常常称为 Schema 文件)是用来定义 xml 文档结构的。
注: XML 解析器可以根据 一个 XSD 文件的内容来解析另一个 XML 文件, 判断该文件的结构是否和 XSD 文件中定义的一致。 XSD 文件 可以理解为 XML 文档可以自定义的语法或格式检查器
④这行的语法其实是, xsi:schemaLocation
= "键" “值”
,即 xsi
命名空间下 schemaLocation
元素的值为一个由空格分开的键值对。
前一个“键”
http://maven.apache.org/POM/4.0.0
指代 【命名空间】, 只是一个全局唯一字符串而已。
后一个值指代 【XSD location URI】 , 这个值指示了前一个命名空间所对应的 XSD 文件的位置, xml parser
可以利用这个信息获取到 XSD 文件, 从而通过 XSD 文件对所有属于 命名空间 http://maven.apache.org/POM/4.0.0
的元素结构进行校验, 因此这个值必然是可以访问的, 且访问到的内容是一个 XSD 文件的内容。
例:
xmlns="http://www.springframework.org/schema/beans"
就是定义了一个默认命名空间, xmlns
的值可以随便改,只要是唯一的就行,如果更改了这里的值,下面的xsi:schemaLocation
中的也要修改为对应的值。xmlns:context="http://www.springframework.org/schema/context"
就是定义了一个 context
的命名空间,使用 context
下的元素,需要加上 context
前缀。xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
,创建了一个 xsi
命名空间,可以通过xsi:schemaLocation
来定义 xsd
文件的位置,以便 XML 解析器解析 XML 文件。wecome1.jsp wecome2.jsp 欢迎页面
上面代码中就配置了两个欢迎页面 wecome1.jsp 和 wecome2.jsp,显示时按照配置顺序显示,如果能找到 wecome1.jsp 文件就显示该文件,如果找不到就找第二个,依次类推。
欢迎页面是用于访问 web 工程时,只给了根名,没有给出具体的页面,这时就回去访问配置的欢迎页面,如果没有配置欢迎页面,不同的应用服务器可能会有不同的行为。对于 Tomcat 来说,会默认先查找 index.html 文件,如果找到了,就将其返回给浏览器;如果没有找到,就继续查找 index.jsp 文件,如果都没有找到,那么 Tomcat 就会显示 The requested resource is not available 的页面。
欢迎页面只是在没有给出具体的访问页面时会被用到,如果指定了具体页面,只要访问的路径正确,是可以正常访问的。
为Servlet
命名和定制URL
TestServlet com.yiyu.servlet.showAllServlet TestServlet /TestServlet
:注册的名字
:配置的 Servlet 的全类名
:为这个 Servlet 映射一个对外访问路径
servlet 和 url-pattern 之间的关系是 一对多的关系。
参考:
过滤器配置
Filter1 D2020128.TestFilter Filter1 /TestServlet Filter1 /*
url-pattern
中配置的路径是访问已经存在的网络资源,如静态页面、jsp、servlet等。url-pattern
之间的关系是 多对多的关系。即,Filter可负责拦截多个请求或响应;一个请求或响应也可被多个Filter拦截。(多个 filter 会根据 web.xml
中配置的顺序组成 filter 链)。常用场合:
(1)认证Filter
(2)日志和审核Filter
(3)图片转换Filter
(4)数据压缩Filter
(5)密码Filter
(6)令牌Filter
(7)触发资源访问事件的Filter
(8)XSLT Filter
(9)媒体类型链Filter
此时你就可以对请求或响应(Request、Response)统一设置编码,简化操作;同时还可进行逻辑判断,如用户是否已经登陆、有没有权限访问该页面等等工作。它是随你的web应用启动而启动的,只初始化一次,以后就可以拦截相关请求,只有当你的web应用停止或重新部署的时候才销毁
过滤器生命周期:初始化init() → 过滤doFilter() → 析构(销毁)destroy()
过滤器有四种拦截方式!分别是:REQUEST、FORWARD、INCLUDE、ERROR。
过滤器链 顺序:按照web.xml中配置的顺序
类似于servlet,需两步
第一步:创建Filter处理类(一般我们都用现有的)
Filter必须实现javax.servlet.Filter接口,在该接口中定义了三个方法:
(1) void init(FilterConfig config):用于Filter的初始化。FilteConfig用于访问Filter的配置信息。
(2) void destroy():Filter销毁前的操作,例如完成某些资源的回收。
(3) void doFilter(ServletRequest request,ServletResponse response,FilterChain chain):
实现过滤功能的核心方法,实现对请求request进行预处理,也可以实现对服务器响应response进行后处理—它们的分界线为是否调用了chain.doFilter(request,response),执行该方法之前,即对用户请求request进行预处理,执行该方法之后,即对服务器响应response进行后处理。
第二步:Web.xml文件中配置Filter
Filter配置与Servlet的配置非常相似,区别在于Servlet通常只配置一个URL,而Filter可以同时配置多个请求的URL。配置Filter有两种方式:
(1). 在Filter类中通过Annotation进行配置。
(2). 在web.xml文件中通过配置文件进行配置。
InitParamServlet InitParamServlet encoding utf-8 helloween password admin admin babyface babyface 1 InitParamServlet /initParamServlet
public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {String username = request.getParameter("username");String password = request.getParameter("password");Enumeration params = this.getInitParameterNames(); // 所有的初始化参数名称while (params.hasMoreElements()) {String nameParam = (String) params.nextElement(); // 获取参数名String valueParam = this.getInitParameter(nameParam); // 获取参数值// 如果用户名,密码匹配则显示notice.htmlif (nameParam.equalsIgnoreCase(username) && valueParam.equalsIgnoreCase(password)) { request.getRequestDispatcher("/WEB-INF/notice.html").forward(request, response);return;}}this.doGet(request, response); // 若username,password不匹配,显示登录页面。}
使用到了枚举类型: Enumeration params = this.getInitParameterNames();
- 获取web.xml中所有的参数名: this.getInitParameterNames();
- 对枚举的遍历: while (params.hasMoreElements()){ …}
- 获取下一个元素: params.nextElement();
- 获取名称对应的值: getInitParameter(nameParam);
- 重定向: request.getRequestDispatcher(“/WEB-INF/notice.html”).forward(request,response);