JAVA基础之HttpServletResponse响应
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
JAVA基础之HttpServletResponse响应
⽤户在客户端输⼊⽹址(虚拟路径)时,开始发送⼀个HTTP请求(请求⾏、请求头、请求体)⾄服务器。
服务器内的Tomcat引擎会解析请求的地址,去找XML⽂件,然后根据虚拟路径找Servlet的真实路径,真实的Servlet会将请求的信息封装成request(请求)对象,然后再创建⼀个response(响应)对象,(此时的response内是空的)同时创建servlet对象,并调⽤service⽅法(或doGet和doPost⽅法)。
这样就是把两个对象传给了服务器内的某个servlet的service⽅法,通过这个⽅法,我们可以获得request的所有的信息,并且向response内设置信息。
response.getwriter().write()将内容写到response的缓冲区,这样service⽅法结束了,⽅法返回后,tomcat引擎会将从该response缓冲区中获取的设置信息封装成⼀个HTTP响应(响应⾏、响应头、响应体),发送给客户端。
客户端解析响应回来的东西继⽽进⾏显⽰。
我们可以通过设置修改响应的信息进⾏相应的重定向(⽤户访问的⽹页不存在并跳转到其他⽹页上)、修改响应⽂本(需要修改浏览器和服务器两边的编码,并且还得处理兼容问题)。
⼀、概述:
我们在创建Servlet时会覆盖service()⽅法,或doGet()/doPost(),这些⽅法都有两个参数,⼀个为代表请求的request和代表响应response。
service⽅法中的response的类型是ServletResponse,⽽doGet/doPost⽅法的response的类型是
HttpServletResponse,HttpServletResponse是ServletResponse的⼦接⼝,功能和⽅法更加强⼤
⼆、运⾏流程:
三、内容:
响应⾏、响应头、响应体;
四、通过response 设置响应⾏:
设置响应⾏的状态码:setStatus( int sc)
五、通过response 设置响应头:
setHeader(String name,String value) 设置
public class RefreshServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//设置定时刷新的头
response.setHeader("refresh","5;url=https://");
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript">
window.onload=function(){
//获取span元素
var second=document.getElementById("second");
//定义秒数
var time =5;
//设置定时器
var timer=setInterval(function(){
second.innerHTML=time;
time--;
if(time < 0){
clearInterval(timer);
location.href="https://";
}
},1000);
}
</script>
</head>
<body>
恭喜您,注册成功!
<span id="second" style="color:red">5</span>
秒后跳转,如没跳转,请点击<a href="https://">这⾥</a>
</body>
</html>
1、重定向:(请求服务器两次,地址栏变化)
①、状态码:302;
②、响应头:location 代表重定向地址;
public class Servlet01 extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
/*// 设置响应状态码
response.setStatus(302);
//设置响应头中的Location
response.setHeader("Location","/WEB0/Servlet02");*/
//重定向
response.sendRedirect("/WEB0/Servlet02");
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
public class Servlet02 extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.getWriter().write("Servlet02");
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
六、通过response 设置响应体:
1、响应体设置⽂本:
PrintWriter getWriter()
获得字符流,通过字符流的write(String s)⽅法可以将字符串设置到response 缓冲区中,随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览器端。
关于设置中⽂的乱码问题
原因:response缓冲区的默认编码是iso8859-1,此码表中没有中⽂,可以通过 response的setCharacterEncoding(String charset) 设置response的编码,
但我们发现客户端还是不能正常显⽰⽂字。
原因:我们将response缓冲区的编码设置成UTF-8,但浏览器的默认编码是本地系统的编码,因为我们都是中⽂系统,所以客户端浏览器的默认编码是GBK,我们可以⼿动修改浏览器的编码是UTF-8。
我们还可以在代码中指定浏览器解析页⾯的编码⽅式,通过response的setContentType(String type)⽅法指定页⾯解析时的编码是UTF-8。
response.setContentType("text/html;charset=UTF-8");
上⾯的代码不仅可以指定浏览器解析页⾯时的编码,同时也内含 setCharacterEncoding的功能,所以在实际开发中只要编写response.setContentType("text/html;charset=UTF-8"),就可以解决页⾯输出中⽂乱码问题。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<a href="/WEB0/DownloadServlet?file=乱码.png">乱码.png</a>
<a href="/WEB0/DownloadServlet?file=a.txt">a.txt</a>
<a href="/WEB0/DownloadServlet?file=a.zip">a.zip</a>
</body>
</html>
package com.oracle;
import java.io.FileInputStream;
import java.io.IOException;
import .URLEncoder;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import sun.misc.BASE64Encoder;
public class DownloadServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //服务器获取⽂件名(⽂件名是中⽂的话,获取的时候就成了乱码了)
String filename = request.getParameter("file");//??.png
//get请求中---解决⽂件名中⽂乱码问题
filename =new String(filename.getBytes("ISO-8859-1"),"UTF-8");//乱码.png
//获取User-Agent获取客户端浏览器到底是哪个浏览器
String agent=request.getHeader("User-Agent");
String filenameEncoder="";
if (agent.contains("MSIE")) {
// IE浏览器
filenameEncoder= URLEncoder.encode(filename, "utf-8");
filenameEncoder= filenameEncoder.replace("+", " ");
} else if (agent.contains("Firefox")) {
// ⽕狐浏览器
BASE64Encoder base64Encoder = new BASE64Encoder();
filenameEncoder= "=?utf-8?B?"
+ base64Encoder.encode(filename.getBytes("utf-8")) + "?=";
} else {
// 其它浏览器
filenameEncoder= URLEncoder.encode(filename, "utf-8");
}
//告知浏览器⽂件的类型(响应体)
response.setContentType(getServletContext().getMimeType(filename));
//告知浏览器以附件的⽅式提供下载功能⽽不是解析
response.setHeader("Content-Disposition","attachment;filename="+filenameEncoder);
//服务器获取后开始进⾏复制的程序:获取字节输出流
ServletOutputStream sos = response.getOutputStream();
//获取数据源的绝对路径
String realpath = getServletContext().getRealPath("download/"+filename);
//获取字节输⼊流
FileInputStream fis =new FileInputStream(realpath);
//开始复制
byte[] bytes=new byte[1024];
int len=0;
while((len=fis.read(bytes))!=-1){
sos.write(bytes, 0, len);
}
//释放资源
fis.close();
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response);
}
}
2、response细节点:
①、response获得的流不需要⼿动关闭,web容器(tomcat容器)会帮助我们关闭,
②、getWriter和getOutputStream不能同时调⽤
③、重定向语句⼀般作为终结代码。