PS:以下仅为个人学习笔记,涩及方面略窄
####################### Request #######################
/**
* request代表用户通过浏览器发起的请求:
* Request对象将浏览器发送来的Http请求
* 解析为对象的属性.只要使用request对象
* 的方法就可以获取Http请求的全部信息
*/
1. 获取请求头的名称
Enumeration<String> names = req.getHeaderNames();
request中有一个 getHeaderNames()方法,用来获取全部请求头的名称
返回值是一个Enumeration(枚举,java老旧的一种迭代器,现被Iterator替代)
2. 可通过HeaderNames获取对应请求头
可以获得 ->
主机IP和端口,连接方式,缓存控制,用户代理 等信息.
while (names.hasMoreElements()) { String name = names.nextElement(); System.out.println(name+": "+req.getHeader(name)); }
由于Enumeration有着迭代器的性质,可以通过迭代获取所有信息,控制台输出举例如下:
host: localhost:8088 connection: keep-alive cache-control: max-age=0 user-agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36 upgrade-insecure-requests: 1 accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8 accept-encoding: gzip, deflate, br accept-language: zh-CN,zh;q=0.9
3. URI 和 URL区别
String uri = req.getRequestURI(); StringBuffer utl = req.getRequestURL();
System.out.println("uri: "+uri); System.out.println("url: "+utl.toString());
URI,是uniform resource identifier,统一资源标识符,用来唯一的标识一个资源。
(可以理解成一个资源名)
而URL是uniform resource locator,统一资源定位器,它是一种具体的URI,即URL可以用来标识一个资源,而且还指明了如何locate这个资源。
(可以理解成一个资源的完整名称,包括文件所在位置)
至于区别输出如下:
uri: /Dpl_7_Servlet/request
url: http://localhost:8088/Dpl_7_Servlet/request
(项目名) (servlet名)
4.如何读取请求参数值?
(1)request提供的getParameter方法。
String getParameter(String paramName);
注:
a.如果请求参数名写错,会返回null值。
b.如果不填写任何数据,会获得空字符串。
(2)request提供的getParameterValues
####################### Response #######################
/**
* 任何发送到浏览器的响应信息都可以
* 利用response对象来设置并且发送到客户端
*/
# 设置响应状态码 (就是设置响应状态行)
response.setStatus(200);
HTTP协议中有多种状态码:如 200-请求成功 404-请求失败,未找到资源 500-服务器遭遇错误 等
# 设置响应头部
response.setContentType("text/html;charset=utf-8");
text/html: 代表响应类型
charset=utf-8: 浏览器在解码时会使用不同的编码,这里设置编码是给浏览器解码时统一的编码
# 设置响应Body中的编码
response.setCharacterEncoding("UTF-8");
在输出时,默认使用iso-8859-1来编码,
所以在
Servlset输出
中文时会乱码,
为了解决乱码问题会使用response设置字符编码
# 发送body内容,利用流发送
//使用Printwriter 发送文本
1 PrintWriter pw = response.getWriter();
2 pw.println("世界你好!");
//使用OutputStream 发送非文本(如图片等)
//获取文件输入流
BufferedInputStream bis
= new BufferedInputStream(
new FileInputStream(
new File("1.jpg")));
//响应状态行 response.setStatus(200); //发送响应头 response.setContentType("image/jpg"); response.setContentLength((int)pngFile.length()); //发送body OutputStream out = response.getOutputStream(); int b ; while( (b=bis.read())!=-1){ out.write(b); } bis.close(); out.close();
####################### 重定向 #######################
(1)什么是重定向?
服务器通知浏览器,向一个新地址发送请求。
注:
服务器可以发送一个302状态码以及一个location消息头(
值是一个地址,称之为重定向地址)给浏览器,浏览器收到之
后,会立即向重定向地址发送请求。
(2)如何重定向?
response.sendRedirect(String url);
注:url就是重定向地址。
注: 重定向之前,容器会清空response对象上存放的所有数据。
也就是说,实体内容里面是没有任何数据的。
(3)特点
a.重定向地址是任意的。
b.重定向之后浏览器地址会发生变化。
2.Servlet容器如何处理请求资源路径?
比如 http://ip:port/servlet-day03/abc.html "/servlet-day03/abc.html" step1. 容器默认会认为访问的是一个servlet 即查找和"/abc.html"匹配的servlet。 注: 匹配规则: a.精确匹配: <url-pattern>/abc.html</url-pattern> b.通配符匹配: <url-pattern>/*</url-pattern> <url-pattern>/demo/*</url-pattern> *:匹配零个或者多个任意的字符。 c.后缀匹配: <url-pattern>*.do</url-pattern> *.do 匹配所有以.do结尾的请求。 step2.如果找不到匹配的servlet,则访问对应的文件。 找到了就返回该文件。如果找不到,返回404。
3.如何让一个servlet处理多种请求?
step1. 采用后缀匹配。
step2. 分析请求资源路径,依据分析结果,来调用
不同的分支来处理。