一.配置
Servlet3.0开始,支持两种配置
1.在Servlet类中使用 @WebServlet Annotation进行配置
@WebServlet(name="Demo1",urlPatterns={"/Demo1"})
注意:如果使用Annotation配置,不要在web.xml文件的根元素(<web-app../>)中指定 metadata-complete=”true”
<metadata-complete>元素通知Web容器是否要寻找注解,为false或不设置则表示启用注解支持,设置为true则忽略注解。
如果既使用了注解又配置了web.xml 那么servlet容器优先查找的是web.xml配置里的,所以不建议同时配置两种。
2.在web.xml文件中进行配置
<servlet> <servlet-name>Test1</servlet-name> <servlet-class>cn.xxx.servlet.Test1</servlet-class> </servlet> <servlet-mapping> <servlet-name>Test1</servlet-name> <url-pattern>/servlet/Test1</url-pattern> </servlet-mapping>
Servlet名字:对应在web.xml的<servlet/>元素里
Servlet的URL:对应在web.xml的<servlet-mapping/>元素里
load-no-startip Servlet:标志在Web容器启动时加载这个servlet类,数值越小,优先实例化
可以通过上面两种方式进行配置。(相当于自启动)
Servlet配置参数,可以实现更好的移植性,避免硬编码
配置参数也由两种方式:1.@WebServlet的 initParams 的属性来定,2.通过web.xml文件中<servlet/>元素中添加子元素<init-param…/>来定
访问Servlet配置参数通过 ServletConfig对象完成,方法为 getInitParameter获取参数(JSP的内置对象config就是ServletConfig)
@WebServlet(name="testServlet" , urlPatterns={"/testServlet"} , initParams={ @WebInitParam(name="driver", value="com.mysql.jdbc.Driver"), @WebInitParam(name="url", value="jdbc:mysql://localhost:3306/javaee"), @WebInitParam(name="user", value="root"), @WebInitParam(name="pass", value="root")})
默认Servlet的配置(tomcat的conf目录中web.xml中配置了所有网站的共性)
<servlet> <servlet-name>default</servlet-name> <servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class> <init-param> <param-name>debug</param-name> <param-value>0</param-value> </init-param> <init-param> <param-name>listings</param-name> <param-value>false</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet>
二.中文乱码问题(Resquest、Response)
Request处理请求中文乱码分两种:1.Get提交方式 2.Post提交方式
1.Get提交方式因为是浏览器url后面,已经编码了,所以针对获取此类中文,需要将其以ISO8859-1解码后再用你想要的编码进行编码
String name = request.getParameter("name"); String name_value = new String(name.getBytes("iso8859-1"),"UTF-8");
2.POST提交方式:request.setCharacterEncoding("utf-8"); 此处的编码与你网页编码应一致
原因在于网页如果是以utf-8进行编码,那么传来的值也是utf-8编码的,如果不设置编码则默认以iso8859-1进行解码,造成乱码,有的时候还是乱码的话,请检查网页是否是以UTF-8进行保存的
------------------------------------------------------------------------------------
Response处理中文乱码:response.setContentType("text/html,charset=utf-8")
上面那句是这句的简写 response.setHeader("content-type", "text/html;charset=utf-8");
而 response.setCharacterEncoding(“utf-8”) 是专门处理字符输出流数据的,并且response.setContentType("text/html,charset=utf-8") 已经包含此功能,也就是说最好使用response.setContentType
response.setCharacterEncoding("UTF-8");//处理字符输出流 PrintWriter out = resp.getWriter();//字符输出流 out.println("<html>"); out.println("<head>"); out.println("<title>访问Servlet初始化参数测试</title>"); out.println("</head>"); out.println("<body>"); out.println("欢迎您!"); out.println("</body>"); out.println("</html>");
如果用的是 PrintStream out =new PrintStream(resp.getOutputStream()); 字节流来输出页面,使用 这个 response.setContentType("text/html,charset=utf-8")会出现乱码,按我的理解是,你当前系统是用什么编码,你就应该setContentType里设置什么编码来解码,比如我们中国默认是GB2312的,如果你指定UTF-8就出现乱码,这时你把浏览器的编码改成GB2312就正常显示了(这里难道是输出字节流的时候是以当前系统编码为主,所以解码也要和当前系统编码一样?)所以如果使用这个来做的话,请设置 GBK 或GB2312