Servlet、servletContext小结

1、Servlet是sun提供的一种规范,用于服务器端处理http请求。一般需要我们继承Servlet接口或者HttpServlet接口。并实现其中的方法。(Servlet接口需要实现service方法,HttpServlet接口需要实现doget和dopost方法)。Servlet要正常运行,需要在web.xml配置。 其生命周期是随着第一次访问而创建(或者设置了load-on-startup就随服务器一起创建),关闭服务器时销毁

2、servletContext是servlet的上下文。一个web工程有一个servletContext,其作用是配置此工程的一些相关参数,可以向其写和读取相关参数信息(servletContext是一个域对象),以及读取文件路径

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns="http://java.sun.com/xml/ns/javaee"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
	version="2.5">
	<display-name>s3-user-web-jk</display-name>
	<welcome-file-list>
		<welcome-file>index.html</welcome-file>
		<welcome-file>index.htm</welcome-file>
		<welcome-file>index.jsp</welcome-file>
		<welcome-file>default.html</welcome-file>
		<welcome-file>default.htm</welcome-file>
		<welcome-file>default.jsp</welcome-file>
	</welcome-file-list>
	
	<!--FirstServlet实现servlet接口  -->
	<servlet>
	<!--servlet-name用于路径映射到具体的Servlet类,即具有相同servlet-name的mapping的路径会映射到相同名字的servlet的类  -->
		<servlet-name>abc</servlet-name>
		<servlet-class>cn.andy.servlet.FirstServlet</servlet-class>
		<!--可以给servlet添加属性,这些属性可以通过servletconfig进行读取  -->
		<init-param>
			<param-name>name</param-name>
			<param-value>lucy</param-value>
		</init-param>
		<!--load-on-startup意味着此servlet是随着服务器启动而生成的,要不然servlet只会在第一次访问时才会生成  -->
		<load-on-startup>1</load-on-startup>
	</servlet>
	<servlet-mapping>
		<servlet-name>abc</servlet-name>
		<!-- url-pattern就是访问路径,即主机名:port/工程名/url-pattern可以访问到相同servlet-name的servlet类 -->
		<!--当url-pattern配置成/时,表示该servlet是缺省servlet,即所有映射不匹配时,就会匹配这个servlet。在srpingMvc里会用到 -->
		<url-pattern>/firstServlet</url-pattern>
	</servlet-mapping>
	
	<!--一个web.xml可以配置多个servlet  -->
	<servlet>
		<servlet-name>second</servlet-name>
		<servlet-class>cn.andy.servlet.SecondServlet</servlet-class>
	</servlet>
	<servlet-mapping>
		<servlet-name>second</servlet-name>
		<url-pattern>/secondServlet</url-pattern>
	</servlet-mapping>

    <!-- 这个servlet实现httpServlet接口 -->
	<servlet>
		<servlet-name>httpservlet1</servlet-name>
		<servlet-class>cn.andy.servlet.FirstHttpServlet</servlet-class>
		<init-param>
			<param-name>name</param-name>
			<param-value>Lili</param-value>
		</init-param>

	</servlet>

	<servlet-mapping>
		<servlet-name>httpservlet1</servlet-name>
		<url-pattern>/firstHttpServlet</url-pattern>

	</servlet-mapping>
	
	
	<!--context-param存的是此servletContext的参数,可以被 servletContext读取 -->
	<context-param>
		<param-name>jdbc</param-name>
		<param-value>mysql</param-value>

	</context-param>


</web-app>

FirstServlet 实现Servlet接口,主要关注service方法和init方法。

public class FirstServlet implements Servlet{
	
	
	@Override
	public void service(ServletRequest request, ServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		 System.out.println("启动.....");
		 
		 System.out.println(request.getCharacterEncoding());
		 System.out.println(request.getLocalAddr());
		 		 
		 
	}


	@Override
	public void destroy() {
		// TODO Auto-generated method stub
		
	}


	@Override
	public ServletConfig getServletConfig() {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public String getServletInfo() {
		// TODO Auto-generated method stub
		return null;
	}

	/* (non-Javadoc)
	 * @see javax.servlet.Servlet#init(javax.servlet.ServletConfig)
	 * /*ServletConfig能获取什么
		 *   1、获取servlet的参数
		 *   2、获取servlet的servletcontext
		 */
	 
	@Override
	public void init(ServletConfig config) throws ServletException {
		// TODO Auto-generated method stub
		
		String parameter = config.getInitParameter("name");
		System.out.println(parameter);
		
			
	}

	/* (non-Javadoc)
	 * @see javax.servlet.Servlet#service(javax.servlet.ServletRequest, javax.servlet.ServletResponse)
	 */


}

FirstHttpServlet 实现HttpServlet 接口,主要关注doget方法和dopost方法以及init()方法

public class FirstHttpServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public FirstHttpServlet() {
        super();
        // TODO Auto-generated constructor stub
    }
    
  /*
   * init在servlet初始化时候启动,可以做一些初始化的工作,比如复位统计等
   * 
   */
    @Override
    public void init() throws ServletException {
    	// TODO Auto-generated method stub
    	super.init();
    	int count=0;
    	ServletContext servletContext = getServletContext();
    	servletContext.setAttribute("count",count);
    	
       System.out.println(this.getServletConfig().getInitParameter("name"));
    }

	
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		
		//获得servletContext,servletContext读取配置参数
		ServletContext servletContext = getServletContext();
		String parameter = servletContext.getInitParameter("jdbc");
		System.out.println(parameter);
		
		//向servletcontext设置参数,servletcontext的参数向此工程的servlet开放
		int count = (int) servletContext.getAttribute("count");
		servletContext.setAttribute("count", count++);
		
		
		//读取文件路径
	System.out.println("3.html-->"+	servletContext.getRealPath("3.html"));
	System.out.println("2.html-->"+	servletContext.getRealPath("WEB-INF/2.html"));
	System.out.println("1.html-->"+	servletContext.getRealPath("classes/1.html"));
	
	
	System.out.println("count-->"+	count);
	    
	    //打印所有的参数	    
	    Map<String,String> parameterMap = request.getParameterMap();
	    Set keSet=parameterMap.entrySet();  
	    Iterator<Map.Entry<String, String>> iterator = keSet.iterator();
	   while (iterator.hasNext()) {
		Entry<String, String> it = (Entry<String, String>) iterator.next();
		String key = it.getKey();
		//getValue返回的有可能是String[].所以需要处理一下
		Object valueObj = it.getValue();
		String value="";
		if (valueObj instanceof String) {
			System.out.println("key is "+key+";value is "+valueObj); 
		}else{
		
			//
			String[] values = (String[])valueObj;  
          
            value = values[0];  
            System.out.println("key is "+key+";value is "+value); 
		}
		
		
	}
	  	 //打印http请求的编码,有时候会打印出null  	    
	    System.out.println("getCharacterEncoding:"+request.getCharacterEncoding());
		response.getWriter().append("Served at: ").append(request.getContextPath());
	}

	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// post的编码必须在此处手动设置utf-8,否则有可能有乱码
		  request.setCharacterEncoding("utf-8");
		   System.out.println("getCharacterEncoding:"+request.getCharacterEncoding());
		    System.out.println("parameter:"+request.getParameter("username"));
		    System.out.println("parameter:"+request.getParameter("password"));
    
		    System.out.println("getCharacterEncoding:"+request.getCharacterEncoding());
			response.getWriter().append("Served at: ").append(request.getContextPath());
	}

}

乱码问题: 乱码问题是由于浏览器和服务器两端的编码不一致导致,需要我们设置。对于get请求,可以在tomcat的conf文件夹下的server.xml文件中, 加上URIEncoding=“UTF-8”

  <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
			    URIEncoding="UTF-8"
               redirectPort="8443" />

而post请求则需要手动设置 request.setCharacterEncoding(“utf-8”);
具体原因参考:
对于发送数据,服务器按照response.setCharacterEncoding—contentType—pageEncoding的优先顺序,对要发送的数据进行编码。

对于接收数据,要分三种情况。一种是浏览器直接用URL提交的数据,另外两种是用表单的GET和POST方式提交的数据。

对于表单中POST方式提交的数据,只要在接收数据的JSP中正确request.setCharacterEncoding参数,即将对客户端请求进行重新编码的编码设置成浏览器编码,就可以保证得到的参数编码正确。有写读者可能会问,那如何得到浏览器编码呢?上面我们提过了,在默认请情况下,浏览器编码就是你在响应该请求的JSP页面中response.setCharacterEncoding设置的值。所以对于POST表单提交的数据,在获得数据的JSP页面中request.setCharacterEncoding要和生成提交该表单的JSP页面的 response.setCharacterEncoding设置成相同的值。

对于URL提交的数据和表单中GET方式提交的数据,在接收数据的JSP中设置request.setCharacterEncoding参数是不行的,因为在Tomcat5.0中,默认情况下使用ISO- 8859-1对URL提交的数据和表单中GET方式提交的数据进行重新编码(解码),而不使用该参数对URL提交的数据和表单中GET方式提交的数据进行重新编码(解码)。要解决该问题,应该在Tomcat的配置文件的Connector标签中设置useBodyEncodingForURI或者 URIEncoding属性,其中useBodyEncodingForURI参数表示是否用request.setCharacterEncoding 参数对URL提交的数据和表单中GET方式提交的数据进行重新编码,在默认情况下,该参数为false(Tomcat4.0中该参数默认为true); URIEncoding参数指定对所有GET方式请求(包括URL提交的数据和表单中GET方式提交的数据)进行统一的重新编码(解码)的编码。 URIEncoding和useBodyEncodingForURI区别是,URIEncoding是对所有GET方式的请求的数据进行统一的重新编码(解码),而useBodyEncodingForURI则是根据响应该请求的页面的request.setCharacterEncoding参数对数据进行的重新编码(解码),不同的页面可以有不同的重新编码(解码)的编码。所以对于URL提交的数据和表单中GET方式提交的数据,可以修改 URIEncoding参数为浏览器编码或者修改useBodyEncodingForURI为true,并且在获得数据的JSP页面中 request.setCharacterEncoding参数设置成浏览器编码。(源自https://blog.csdn.net/fancylovejava/article/details/7700683)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值