1.HttpServletRequest
a)HttpServletRequest是一个接口,继承了ServletRequest接口;
b)HttpServletRequest对象由服务器创建,并作为参数传递给service方法,用于给Servlet提供客户端的请求信息。
c)获取请求行信息:
private void getReqLine(HttpServletRequest req) {
System.out.println("请求方式:" + req.getMethod());
System.out.println("资源路径(URL):" + req.getRequestURL());
System.out.println("资源路径(URI):" + req.getRequestURI());
System.out.println("协议版本号:" + req.getProtocol());
System.out.println("协议名:" + req.getScheme());
}
d)获取请求头信息
private void getReqHead(HttpServletRequest req) {
Enumeration<String> names = req.getHeaderNames();
while (names.hasMoreElements()) {
String name = names.nextElement();
System.out.println(name + "=" + req.getHeader(name));
}
}
e)获取请求实体
private void getReqEntity(HttpServletRequest req) {
// 获取一个值时使用getParameter
String uname = req.getParameter("uname");
// 获取多个值时使用getParameterValues
String[] hobs = req.getParameterValues("hob");
System.out.println("uname:" + uname);
System.out.println("hob:" + Arrays.toString(hobs));
}
f)获取请求信息的其他信息
private void getReqOthers(HttpServletRequest req) {
System.out.println("服务器的地址:" + req.getLocalAddr());
System.out.println("服务器的名称:" + req.getLocalName());
System.out.println("服务器端口号:" + req.getLocalPort());
System.out.println("客户端的地址:" + req.getRemoteAddr());
System.out.println("客户端的主机:" + req.getRemoteHost());
System.out.println("客户端端口号:" + req.getRemotePort());
System.out.println("获取上下文路径(当前项目):" + req.getContextPath());
}
2.HttpServletResponse
a)HttpServletResponse是一个接口,继承了ServletResponse接口;
b)HttpServletResponse对象由服务器,并作为参数传递service方法,用于帮助Servlet对客户端的请求做出响应。
c)HttpServletResponse对象用于设置响应头和响应实体;
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 设置响应头
resp.setHeader("Content-Type", "text/html;charset=utf-8");
resp.setHeader("pc", "DELL");
// 重名时也不会覆盖
resp.addHeader("pc", "Lenovo");
// 设置响应实体
resp.getWriter().print("<h1>今天天气不错!</h1>");
}
3.解决各种乱码问题
发生乱码问题的原因是由于编码方式不一致,因此,解决乱码的核心思想是统一编码方式,UTF-8被称为万国码,是一个非常好的选择。
3.1前台页面乱码
需要在页面中添加meta标签,告知浏览器使用utf-8编码。
<!-- 告诉浏览器要使用utf-8的方式编码页面 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
3.2后台乱码
Tomcat7.0及之前的版本,默认采用ISO-8859-1的编码方式。
Tomcat8.0开始,默认编码方式改为UTF-8。
3.2.1后台请求乱码
3.2.1.1post请求乱码
在接收数据前,设置请求实体编码方式为UTF-8即可
//设置请求的字符集
req.setCharacterEncoding("utf-8");
3.2.1.2get请求乱码
a) 方式一: 先用ISO-8859-1解码, 再用UTF-8编码.
String uname = req.getParameter("uname"); // 用iso-8859-1解码字符串 byte[] bytes = uname.getBytes("iso-8859-1"); // 用utf-8重新编码 uname = new String(bytes, "utf-8"); |
b) 方式二: 修改服务器配置文件server.xml, 使用UTF-8编码路径
<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8" /> |
c) 方式三: 修改服务器配置文件server.xml, 使用请求实体的编码方式来编码路径, 较为灵活.
<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" useBodyEncodingForURI="true" /> |
req.setCharacterEncoding("utf-8"); String uname = req.getParameter("uname"); |
3.2.2后台响应乱码
设置服务器使用UTF-8编码响应信息,同时,告知浏览器使用UTF-8编码响应信息;
//设置响应的字符集
resp.setCharacterEncoding("utf-8");
// 告诉浏览器使用utf-8编码响应内容
// resp.setHeader("Content-Type", "text/html;charset=utf-8");
resp.setContentType("text/html;charset=utf-8");
4.页面跳转的两种方式
4.1请求转发
a)只发送一次请求
b)地址栏不发生改变
c)数据可以一直传递
d)只能舔砖内部资源,不能访问外部资源
// 请求转发--getRequestDispatcher
req.getRequestDispatcher("dis2").forward(req, resp);
4.2重定向
a)会发送多次请求
b)地址栏会发生改变
c)数据不能继续传递
d)内部资源和外部资源都可以访问
// 重定向---sendRedirect
resp.sendRedirect("red2?mouse="+req.getParameter("mouse"));
5.ServletConfig
a)ServletConfig用于配置Servlet,在初始化Servlet的时候对Servlet进行配置;
b)Servlet容器会自动将<init-param>中的数据封装为ServletConfig对象,并将其传到init方法中,对Servlet进行初始化操作;
5.1通过配置文件配置init-param
<servlet>
<servlet-name>ConfigServlet</servlet-name>
<servlet-class>com.bjsxt.servlet.ConfigServlet</servlet-class>
<!-- 用于提供Servlet的配置信息, 供服务器封装ServletConfig对象使用 -->
<init-param>
<param-name>keyboard</param-name>
<param-value>Razer</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>ConfigServlet</servlet-name>
<url-pattern>/conf</url-pattern>
</servlet-mapping>
5.2通过注解配置init-param
@WebServlet(value="/conf2", initParams=@WebInitParam(name="keyboard", value="luoji"))
public class ConfigServlet extends HttpServlet {}
5.3 使用ServletConfig
@Override protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 获取ServletConfig对象 ServletConfig config = this.getServletConfig(); // 获取初始化参数 System.out.println("keyboard:" + config.getInitParameter("keyboard")); // 获取当前Servlet的名字 System.out.println("name:" + config.getServletName()); } |
1. ServletContext
a) ServletContext是Servlet的上下文对象, 代表了整个应用程序. 一个项目中只有一个ServletContext对象, 所以它经常被称之为Application.
b) 所有的Servlet共享ServletContext对象.
6.1 获取ServletContext对象的三种方式
// [1] 直接调用getServletContext方法 ServletContext ctx1 = this.getServletContext(); // [2] 通过ServletConfig对象获取 ServletContext ctx2 = getServletConfig().getServletContext(); // [3] 通过req对象获取 ServletContext ctx3 = req.getServletContext(); |
6.2 全局配置参数
<!-- 全局配置参数 --> <context-param> <param-name>computer</param-name> <param-value>Lenovo</param-value> </context-param> |
6.2 ServletContext常用功能
// [功能1] 获取全局配置参数 System.out.println("computer:" + ctx1.getInitParameter("computer")); // [功能2] 获取一些相关的路径 System.out.println("上下文路径:" + req.getContextPath()); System.out.println("上下文路径:" + ctx1.getContextPath()); System.out.println("获取当前项目的绝对路径:" + ctx1.getRealPath("")); System.out.println("获取upload的绝对路径:" + ctx1.getRealPath("upload")); // [功能3] 加载静态资源 InputStream is = ctx1.getResourceAsStream("WEB-INF/web.xml"); BufferedReader br = new BufferedReader(new InputStreamReader(is)); PrintWriter pw = new PrintWriter(System.out); String line = null; while((line = br.readLine()) != null) { pw.println(line); } pw.close(); br.close(); // [功能4] 请求转发 ctx1.getRequestDispatcher("/demo.html").forward(req, resp); |