JavaWeb ——servlet学习4之HttpServletRequest、HttpServletResponse和资源下载

JavaWeb ——servlet学习4之HttpServletRequest、HttpServletResponse和资源下载

Web 服务器收到客户端的 http 请求,会针对每一次请求,分别创建一个用于 代表请求的 request 对象和 代表响应的 response 对象。request 和 response 对象代表请求和响应:获取客户端数据,需要通过request 对象; 向客户端输出数据,需要通过 response 对象。HttpServletResponse 的主要功能用于服务器对客户端的请求进行响应,将Web 服务器处理后的结果返回给客户端。service()方法中形参接收的是HttpServletResponse 接口的实例化对象,这个对象中封装了向客户端发送数据、发送响应头,发送响应状态码的方法。

HttpServletRequest

获取客户端的信息

获取客户端信息

getRequestURL:返回客户端发出请求时的完整URL。

getRequestURI:返回请求行中的资源名部分。

getQueryString :返回请求行中的参数部分。

getPathInfo:返回请求URL中的额外路径信息。额外路径信息是请求URL中的位

于Servlet的路径之后和查询参数之前的内容,它以“/”开头。

getRemoteAddr:返回发出请求的客户机的IP地址。

getRemoteHost:返回发出请求的客户机的完整主机名。

getRemotePort:返回客户机所使用的网络端口号。

getLocalAddr:返回WEB服务器的IP地址。

getLocalName:返回WEB服务器的主机名。

获得客户请求头

getHeader(string name):String getHeaders(String name):Enumeration getHeaderNames()方法

获得客户机请求参数(客户端提交的数据)

  • getParameter(String) (常用)

  • getParameterValues(String name)(常用)

若出现乱码问题,需要进行处理

  • get请求处理乱码:

//get请求过来的数据,在url地址栏上就已经经过编码了,所以我们取到的就是乱码,
//tomcat收到了这批数据,getParameter 默认使用ISO-8859-1去解码

//先让文字回到ISO-8859-1对应的字节数组 , 然后再按utf-8组拼字符串
username = new String(username.getBytes("ISO-8859-1") , "UTF-8");
System.out.println("userName="+username+"==password="+password);

直接在tomcat里面做配置,以后get请求过来的数据永远都是用UTF-8编码。
在tomcat里面做设置处理 conf/server.xml 加上URIEncoding="utf-8"
<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8"/>
  • Post请求处理乱码:

在getParameter之前,进行格式配置request.setCharacterEncoding("UTF-8");

HttpServletResponse

HttpServletResponse四类功能:

  1. 设置响应头信息;addHeader(“reFresh”, “5;URL=xxxx”);

  2. 发送状态码;sendError(404);

  3. *设置响应正文;getWriter().print(“fdsfdsa”);*

  4. *重定向:sendRedirect(“path”);*

设置正文:

//以字符流的方式写数据	
response.getWriter().print("3秒后跳转到注册页面");  //3秒后跳转到1.html页面
response.setHeader("reFresh", "3;URL=/request_demo5/1.html");

//以字节流的方式写数据 
response.getOutputStream().write("hello response2222...".getBytes());

设置状态码,一般不需要我们自己设置,这是由tomcat来分析的

response.setStatus(404);

设置响应头

Date date = new Date(0);
response.setHeader("name", "xuefu");
response.addIntHeader("age", 18);
response.addDateHeader("birthday",date.getTime());
response.addHeader("name", "xueli");
response.setIntHeader("age", 20);

设置重定向

//没有响应,告知客户端重定向到servlet2
//1设置状态码
response.setStatus(302);
//2.设置响应头Location
response.setHeader("Location", "/WEBpro/servlet2");

处理乱码问题

设置编码,如果响应类型为文本,我们需要设置响应编码和文本编码

response.setContentType("text/html;charset=UTF-8") :设置响应类型和编码
response.setCharacterEncoding("UTF-8"):    设置文本编码

资源下载

tomcat默认下载servlet

以超链接的方式下载,不写任何代码。 也能够下载东西下来。

<a href="download/aa.jpg">aa.jpg</a><br>
<a href="download/bb.txt">bb.txt</a><br>
<a href="download/cc.rar">cc.rar</a><br>

原因是tomcat里面有一个默认的Servlet -- DefaultServlet 。这个DefaultServlet 专门用于处理放在tomcat服务器上的静态资源。

自己设置下载

//1. 获取要下载的文件名字 aa.jpg  --- inputStream
String fileName = request.getParameter("filename");

//2. 获取这个文件在tomcat里面的绝对路径地址
String path = getServletContext().getRealPath("download/"+fileName);

//让浏览器收到这份资源的时候, 以下载的方式提醒用户,而不是直接展示。 
response.setHeader("Content-Disposition", "attachment; filename="+fileName);

response.sendRedirect("login_success.html");

//3. 转化成输入流
InputStream is = new FileInputStream(path);
OutputStream os = response.getOutputStream();

int len = 0 ;
byte[]buffer = new byte[1024];
while( (len = is.read(buffer)) != -1){
  os.write(buffer, 0, len);
}

os.close();
is.close();

文件名字中带有中文处理

IE、Google用URLEncoding编码

FireFox使用Base64编码

String clientType = request.getHeader("UserAgent");
if(clientType = "firefox"){
  filename = DownLoadUtil.Base64EncodingFileName(filename)
}
filename = URLEncoding.encode(filename,"UTF-8");

重定向与请求转发

// 重定向:
response.setStatus(302);
response.setHeader("Location", "login_success.html");
//重定向写法: 重新定位方向 参数即跳转的位置
response.sendRedirect("login_success.html");

// 请求转发
request.getRequestDispatcher("login_success.html").forward(request, response);

异同:

重定向:

  1. 地址上显示的是最后的那个资源的路径地址

  2. 请求次数最少有两次, 服务器在第一次请求后,会返回302 以及一个地址, 浏览器在根据这个地址,执行第二次访问

  3. 可以跳转到任意路径。 不是自己的工程也可以跳

  4. 效率稍微低一点, 执行两次请求。

  5. 后续的请求,没法使用上一次的request存储的数据,或者 没法使用上一次的request对象,因为这是两次不同的请求

请求转发:

  1. 地址上显示的是请求servlet的地址。 返回200 ok

  2. 请求次数只有一次, 因为是服务器内部帮客户端执行了后续的工作。

  3. 只能跳转自己项目的资源路径 。

  4. 效率上稍微高一点,因为只执行一次请求。

  5. 可以使用上一次的request对象。

 

 

 

 

 

 

 

 

 

 

 

 

 

上一篇:java生成前端验证码+验证「kaptcha」


下一篇:restful的put请求(坑),和HttpServletRequest做参数的作用