当Servlet 容器启动的时候 会为每个web应用创建一个ServletContext 对象代表当前的web应用。
在web.xml 文件中不止可以配置Servlet的初始化信息 还可以给整个web应用配置初始化信息。
1、获取web 程序启动时初始化参数
web.xml 设置需要初始化的参数
1
2
3
4
5
6
7
8
9
|
<!--1、获取web应用程序初始化参数--> < context-param > < param-name >name</ param-name > < param-value >crush</ param-value > </ context-param > < context-param > < param-name >school</ param-name > < param-value >hngy</ param-value > </ context-param > |
写一个Servlet继承HttpServlet
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
/** * @Author: crush * @Date: 2021-05-09 16:32 * version 1.0 */ @WebServlet ( "/servlet" ) public class ServletContextTest extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //设置响应头 resp.setContentType( "text/html;charset=utf-8" ); PrintWriter writer = resp.getWriter(); ServletContext servletContext = this .getServletContext(); // 根据名称 获取单个初始化参数 String parameter = servletContext.getInitParameter( "name" ); writer.print(parameter); writer.print( "<br><hr>" ); // 获取全部初始化参数 Enumeration<String> initParameterNames = servletContext.getInitParameterNames(); while (initParameterNames.hasMoreElements()){ String name = initParameterNames.nextElement(); String value = servletContext.getInitParameter(name); writer.print(name+ ":" +value); writer.print( "<hr>" ); } } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } } |
@WebServlet("/servlet6") 作用等于
1
2
3
4
5
6
7
8
|
< servlet > < servlet-name >/servlet1</ servlet-name > < servlet-class >com.crush.servlet.ServletContextTest</ servlet-class > </ servlet > < servlet-mapping > < servlet-name >/servlet1</ servlet-name > < url-pattern >/servlet1</ url-pattern > </ servlet-mapping > |
2、实现多个Servlet 对象共享数据
一个web 应用中所有Servlet都共享ServletContext对象。在一定时候,ServletContext 也可以拿来传递信息
或者全局都需要的对象或者数据可以放进ServletContext中。
ServletContext接口的方法:这里讲解增加、获取、删除、设置ServletContext 域属性四个方法。
方法 | 描述 |
---|---|
Enumeration getAttributeNames(); | 返回一个Enumeration其中包含该ServletContext中所有的属性名称 |
Object getAttribute(String name); | 返回具有给定名称的servlet容器属性; |
void removeAttribute(String name); | 从此ServletContext中删除具有给定名称的属性。 |
setAttribute(String name,Object obj) |
在此ServletContext中将对象绑定到给定的属性名称。 如果指定的名称已经用于属性,则此方法将使用新的属性替换该属性。 如果在ServletContext上配置了侦听器,则容器会相应地通知它们。 |
设置值: ServletContextTest1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
/** * @Author: crush * @Date: 2021-05-09 16:59 * version 1.0 */ @WebServlet ( "/servlet1" ) public class ServletContextTest1 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 获取ServletContext对象 ServletContext servletContext = this .getServletContext(); //设置值 ServletContext 域属性 name 域属性名 obj是值 // 往ServletContext 中放进 username=crush 这个键值对 servletContext.setAttribute( "username" , "crush" ); // 在控制台给出提示 System.out.println( "值已经设置完成" ); // 重定向 // resp.sendRedirect("/servlet2"); // 转发 req.getRequestDispatcher( "servlet2" ).forward(req, resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } } |
取出值 :ServletContextTest2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
/** * @Author: crush * @Date: 2021-05-09 16:59 * version 1.0 */ @WebServlet ( "/servlet2" ) public class ServletContextTest2 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 获取ServletContext对象 ServletContext servletContext = this .getServletContext(); // 通过之前的设置的名字 取出username 的值 String username =(String) servletContext.getAttribute( "username" ); PrintWriter writer = resp.getWriter(); writer.print(username); //返回一个Enumeration其中包含该ServletContext中可用的属性名称 // Enumeration<String> attributeNames = servletContext.getAttributeNames(); //从此ServletContext中删除具有给定名称的属性。 // servletContext.removeAttribute(""); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } } |
测试:
先访问 /servlet1 存值进去
再访问 /servlet2 取值出来
3、读取web应用下的资源
使用ServletContext 可以读取web应用下的资源
常用方法
方法 | 描述 |
---|---|
String getRealPath(String path); | 获取与给定虚拟路径相对应的真实路径。 |
InputStream getResourceAsStream(String path); | 返回位于指定路径处的资源作为InputStream对象。 |
URL getResource(String path) | 返回映射到给定路径的资源的URL。 |
mysql.properties
1
2
3
4
|
user =root password =123456 url=jdbc:mysql://localhost:3306/mysql drive=com |
读取资源文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
/** * 读取资源内容 * @Author: crush * @Date: 2021-05-09 16:59 * version 1.0 */ @WebServlet ( "/servlet3" ) public class ServletContextTest3 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.setContentType( "text/html;charset=utf-8" ); ServletContext servletContext = this .getServletContext(); // 获取相对路径中的输入流对象 是要获取web应用程序的路径 InputStream inputStream = servletContext.getResourceAsStream( "\\WEB-INF\\classes\\mysql.properties" ); // 资源类对象 Properties properties = new Properties(); // load 从输入字节流中读取属性列表(键和元素对) properties.load(inputStream); PrintWriter writer = resp.getWriter(); writer.print( "user" +properties.getProperty( "user" )+ "<br>" ); writer.print( "password" +properties.getProperty( "password" )+ "<br>" ); writer.print( "url" +properties.getProperty( "url" )+ "<br>" ); writer.print( "drive" +properties.getProperty( "drive" )+ "<br>" ); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } } |
对于mysql. properties 为什么是从WEB-INF/classes/ 目录下取的解释
resources和java文件夹下的 在web程序下的路径都是classes的路径下的 到之后我们会学到classpath的 一个路径
会更了解一些。
第二种方式
直接将mysql.properties文件放在WEB-INF/目录下
这个时候取的路径就产生了变化了,可以直接那么取到
这个时候我们发现 如果文件是放在WEB-INF 下面 的话 编译完后 是直接就在WEB-INF 下面 而不是在classes目录下的。这个内容是maven 里的内容,好奇可以去查一查。
4、请求转发
ServletContextTest5 转发到 ServletContextTest 去
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
/** * 请求转发 * @Author: crush * @Date: 2021-05-09 16:59 * version 1.0 */ @WebServlet ( "/servlet5" ) public class ServletContextTest5 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.setContentType( "text/html;charset=utf-8" ); ServletContext servletContext = this .getServletContext(); // RequestDispatcher对象可用于将请求转发到资源或将资源包括在响应中。 资源可以是动态的也可以是静态的。 //路径名必须以/开头,并被解释为相对于当前上下文根。 使用getContext获取外部上下文中资源的RequestDispatcher servletContext.getRequestDispatcher( "/servlet" ).forward(req,resp); //forward:将请求从servlet转发到服务器上的另一个资源(servlet,JSP文件或HTML文件) } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } } |
乱码解决
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
/** * 乱码问题 * @Author: crush * @Date: 2021-05-09 16:59 * version 1.0 */ @WebServlet ( "/servlet6" ) public class ServletContextTest6 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 解决乱码 只是解决单独的响应乱码 如果有请求 还要设置请求的编码 req.setCharacterEncoding( "utf-8" ); resp.setContentType( "text/html;charset=utf-8" ); PrintWriter writer = resp.getWriter(); writer.print( "你好啊,JavaWeb" ); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } } |
总结
本篇文章就到这里了,希望能给你带来帮助,也希望能够您能够关注服务器之家的更多内容!
原文链接:https://blog.csdn.net/weixin_45821811/article/details/116571600