- response是在请求网址时候和request一起创建好的只不过是空的,在doget方法中写入返回的数据(写给的是response,之后toncat将响应行响应头一起和数据封装成返回给客户端的响应)
- 302是为了代码重定向使用的?重定向请求一次以上服务器
5秒之后跳转到百度:不常用因为是服务器端写死页面不会有动态效果
response.setHeader("refresh", "5,url=http://www.baidu.com");
html等辅助输入提示
继续打开web→html Files→Editor→Content Assist
修改Prompt when these characters are inserted:<=.abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVW
js 类似值 :.abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVW写图片先有字节输入流需要去读图片(绝对地址用相对地址去获得),写时候用快速方法byte【1024】,while((len=in.read(byte))>0){out.write(byte,0,len)}
1.响应的response的运行流程
- 因为response代表响应,所以我们可以通过该对象分别设置Http响应的响应行,响 应头和响应体
- 通过response设置响应行
设置响应行的状态码
setStatus(int sc) - 通过response设置响应头(add增加,set覆盖)
addHeader(String name, String value)
addIntHeader(String name, int value)
addDateHeader(String name, long date)
setHeader(String name, String value) ***
setDateHeader(String name, long date)
setIntHeader(String name, int value)
- 通过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");就可以解决页面输出中文乱码问题。
(2)响应头设置字节
ServletOutputStream getOutputStream()
获得字节流,通过该字节流的write(byte[] bytes)可以向response缓冲区中写入字 节,在由Tomcat服务器将字节内容组成Http响应返回给浏览器。
2.文件下载
-----------重定向路径----
设置两个头
// 设置状态码302
// response.setStatus(302);
// 重定向路径
// response.setHeader("Location", "/web14/servlet2");
// 效果一样
// response.sendRedirect( "/web14/servlet2");
//5秒后跳转
response.setHeader("refresh", "5,url=http://www.baidu.com");
-------乱码问题产生-------
有两方面:tomcat读取时候和读取完客户端展示时候
// 告诉tomcat存时候要utf-8
response.setCharacterEncoding("UTF-8");
// 告诉浏览器取时候要utf-8,仅这一句就可以让tomcat存时候也用u8
//response.setHeader("content-Type", "text/html;charset=utf-8");
//等同于
//response.setContentType( "text/html;charset=utf-8");
PrintWriter writer = response.getWriter();
writer.write("你好");
----------相当于上传图片浏览器展示---------------
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 使用response获得字节输出流
ServletOutputStream out = response.getOutputStream();
// 获得文件字节流
String path = getServletContext().getRealPath("a.jpg");
FileInputStream in = new FileInputStream(path);
int len = 0;
byte[] butter = new byte[1024];
while ((len = in.read(butter)) > 0) {
out.write(butter, 0, len);
}
in.close();
out.close();
}
-------------下载文件---------
----展示的下载页面-------
<a href="/web14/fileDownload?filename=a.flv">a.flv</a><br>
参数filename让response获取到文件名字
fileDownload是xml中url
----xml------
<servlet-mapping>
<servlet-name>FileDownload</servlet-name>
<url-pattern>/fileDownload</url-pattern>
</servlet-mapping>
--------servlet-------
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
主要修改两个头ContentType和Content-Disposition
// 从html的参数或取名字
String name = request.getParameter("filename");
// 告诉浏览器下载文件的类型参数是从全局web.xml中的mime类型转化
// response.setContentType(this.getServletContext().getMimeType(name));
// 告诉浏览器要附件下载而不是解开
response.setHeader("Content-Disposition", "attachment;filename=" + name);
FileInputStream in = new FileInputStream(this.getServletContext().getRealPath("download/" + name));
ServletOutputStream out = response.getOutputStream();
int len = 0;
byte[] buffer = new byte[1024];
while ((len = in.read(buffer)) > 0) {
out.write(buffer, 0, len);
}
in.close();
out.close();// out是response获取会自动被关闭
}
- 1)告知浏览器文件的类型:response.setContentType(文件的MIME类型);(不写也可以?)
- 2)告示浏览器文件的打开方式是下载:
response.setHeader("Content-Disposition","attachment;filename=文件名称"); - 但是,如果下载中文文件,页面在下载时会出现中文乱码或不能显示文件名的情况, 原因是不同的浏览器默认对下载文件的编码方式不同,ie是UTF-8编码方式,而火狐 浏览器是Base64编码方式。所里这里需要解决浏览器兼容性问题,解决浏览器兼容 性问题的首要任务是要辨别访问者是ie还是火狐(其他),通过Http请求体中的一个属性可以辨别其中agent就是请求头User-Agent的值
- 也就是在tomcat识别时候转成u8(new String(filename.getBytes("ISO8859-1"), "UTF-8")),在客户端识别之前根据不同客户端以不同形式转码(if (agent.contains("MSIE")) {)
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// *******文件名称是中文的下载*******
// 获得要下载的文件的名称
String filename = request.getParameter("filename");// ????.jpg
// 解决获得中文参数的乱码----
filename = new String(filename.getBytes("ISO8859-1"), "UTF-8");// 美女.jpg
// 获得请求头中的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");
}
// 要下载的这个文件的类型-----客户端通过文件的MIME类型去区分类型 response.setContentType(this.getServletContext().getMimeType(filename));
// 告诉客户端该文件不是直接解析 而是以附件形式打开(下载)----filename="+filename 客户端默认对名字进行解码
response.setHeader("Content-Disposition", "attachment;filename=" + filenameEncoder);
// 获取文件的绝对路径原来中文名字否则找不到
String path = this.getServletContext().getRealPath("download/" + filename);
// 获得该文件的输入流
InputStream in = new FileInputStream(path);
// 获得输出流---通过response获得的输出流 用于向客户端写内容
ServletOutputStream out = response.getOutputStream();
// 文件拷贝的模板代码
int len = 0;
byte[] buffer = new byte[1024];
while ((len = in.read(buffer)) > 0) {
out.write(buffer, 0, len);
}
in.close();
// out.close();
}
- //response.getOutputStream();
//response.getWriter();全局可以认为两种是一个不可以同时写(就算有多个servlet) - 默认重定向就是编码结束时候