web14 HttpServletResponse

  • 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响应的响应行,响 应头和响应体
Paste_Image.png
  • 通过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的值
Paste_Image.png
  • 也就是在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)
  • 默认重定向就是编码结束时候
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,934评论 6 13
  • 一、概念(载录于:http://www.cnblogs.com/EricaMIN1987_IT/p/3837436...
    yuantao123434阅读 8,337评论 6 152
  • Http协议详解 标签(空格分隔): Linux 声明:本片文章非原创,内容来源于博客园作者MIN飞翔的HTTP协...
    Sivin阅读 5,212评论 3 82
  • 苹果服务器数据 地理编码:将具体位置转换为经纬度 CLGeocoder 地理编码对象 反地理编码:经纬度转换为具体位置
    rebeccaBull阅读 239评论 0 0