WEB核心【response对象(重点),案例:读取WEB工程资源文件】第十一章

简介: 本章:主要介绍response对象详情,案例SE 和 EE 读取web工程的资源文件

1,response对象【重点】

1.1:简述&继承关系&生命周期

image.gif编辑

image.gif编辑

1.2:响应行

image.gif编辑

/**
 * 状态码
 */
public void run1(){
    HttpServletResponse response = getResponse();
    response.setStatus(404);//若不设置状态码,由服务器自动设置。正常默认状态码:200
}

image.gif

image.gif编辑

image.gif编辑

建议该方法仅发送4xx和5xx状态码

public void run2() throws IOException {
    getResponse().sendError(404,"找不到该页面,<font color='red'>呵呵</font>");
}

image.gif

image.gif编辑

1.3:响应头

image.gif编辑

/**
 * 响应头
 * @throws IOException
 */
public void run3() throws IOException {
    HttpServletResponse response = getResponse();
    //k1=v1  k2=v2   k1=v3
    //注意:若需要新值覆盖旧值,使用setHeader。 若需要保存所有值,使用addHeader
    //setHeader 设置/覆盖 响应头
    /*response.setHeader("k1","v1");
    response.setHeader("k2","v2");
    response.setHeader("k1","v3");//覆盖了k1=v1*/
    //addHeader 追加     响应头
    response.addHeader("k1","v1");
    response.addHeader("k2","v2");
    response.addHeader("k1","v3");
}

image.gif

image.gif编辑

image.gif编辑

//ajax:设置响应体:response.setCharacterEncoding
//response.setCharacterEncoding("utf-8");//设置响应体编码码表为utf-8
//非ajax传统操作:response.setContentType
//mime类型;charset=码表
//response.setContentType("text/html;charset=utf-8");

image.gif

1.4:响应体

服务器向响应体写出的内容,都会被浏览器接收。

若需要传递大量信息,把大量信息写在响应体。

字符流:

PrintWriter writer = response对象.getWriter();

writer.write("HTML代码+CSS代码+JS代码");

/**
 * 响应体
 */
public void run4() throws IOException {
    //字符流
    PrintWriter writer = getResponse().getWriter();
    writer.write("<h1 align='center' id='d'>字符流</h1><script>document.getElementById('d').innerHTML='字符流呵呵'</script>");
}

image.gif

image.gif编辑

字节流:

ServletOutputStream outputStream = getResponse().getOutputStream();

outputStream.write(字节数组);

/**
 * 响应体
 */
public void run5() throws IOException {
    ServletOutputStream outputStream = getResponse().getOutputStream();
    outputStream.write("<h1 align='center' id='d'>字节流</h1><script>document.getElementById('d').innerHTML='字节流呵呵'</script>".getBytes("utf-8"));
}

image.gif

小结:

    1. 何时使用字节流、何时使用字符流?

    文本、代码输出展示:字符流

    图片、声音等文件输出:字节流(文件下载)

        2. 流是否需要刷新和关闭?

    一般情况下,无需对响应中的流进行刷新和关闭操作。

    关闭是由tomcat来进行控制。

    字符流中,若字符数据超过8K,需要人工调用flush()进行刷新。

    注意事项:一个响应体不能同时被两种类型的流进行写出操作。(一山难容二虎)

    /**
     * 响应体被两个流操作的报错
     */
    public void run6() throws IOException {
        getResponse().getWriter();
        getResponse().getOutputStream();//java.lang.IllegalStateException: getWriter() has already been called for this response
    }

    image.gif

    JSP:特殊Servlet。   展示HTML+CSS+JS使用 字符流。

    注意:JSP因为已经调用了字符流,根据servlet的response对象特性,不能再调用字节流了。

    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <html>
    <head>
        <title>Title</title>
        <%
            ServletOutputStream outputStream = response.getOutputStream();
            outputStream.write("haha".getBytes("utf-8"));
        %>
    </head>
    <body>
    </body>
    </html>

    image.gif

    报错:java.lang.IllegalStateException: getOutputStream() has already been called for this response

    2,案例2:读取WEB工程的资源文件

    2.1:需求说明及分析

    WEB项目,java代码读取资源文件(html/css/js/jsp/servlet/jpg/avi...)。

    资源文件的有效路径。

    目标:

    通过该案例,熟练掌握getRealPath方法

    image.gif编辑

    要求分别使用JavaSE和JavaEE的技术来获取4个文件

    2.2:SE实现

    public class Demo1 {
        public static void main(String[] args) throws IOException {
            //javaSE
            //相对路径出发目录 是当前源码目录的根目录。 相对路径,最终会被拼接为绝对路径来定位资源文件
            getFile("src/1.txt");//idea执行时,会将该相对路径,拼接为绝对路径  D:/IDEA2020/class12/10web2/day07_2/src/1.txt
            getFile("web/2.txt");
            getFile("web/WEB-INF/3.txt");
            getFile("4.txt");
        }
        /**
         *根据路径读取文件的第一行内容
         */
        public static void getFile(String path) throws IOException {
            BufferedReader reader = new BufferedReader(new FileReader(new File(path)));
            System.out.println(reader.readLine());
            reader.close();
        }
    }

    image.gif

    小结:

    JavaSE写法:

    相对路径的出发目录为:源码的根目录

    在定位文件时,会将相对路径 变为带盘符的绝对路径来使用。

    2.3:EE实现【阶段重点】

    //原因:SE和EE代码的执行位置不同的,相对路径出发目录也不同
    //SE代码执行位置是:当前项目的Out执行。 相对路径出发目录:当前源码目录的根目录
    //EE代码执行位置时:tomcat的bin目录执行。 相对路径出发目录:Tomcat的bin目录
    //结论:1、SE和EE最终都需要绝对路径
    //      2、SE的相对路径出发目录是当前源码根目录,所以可以正常使用
    //         EE的相对路径的出发目录是tomcat的bin目录,不能使用。
    String absolutePath = new File("./").getAbsolutePath();
    System.out.println(absolutePath);//D:\temp\apache-tomcat-7.0.52\bin\

    image.gif

    image.gif编辑

    我们使用ServletContext的getRealPath(String path);来获取文件的真实路径path路径需要写成webapps中的路径,项目名缩写为/

    getRealPath("/"); 获取当前根目录在硬盘的绝对位置

    public void run1() throws IOException {
        //尝试使用SE方式进行WEB项目资源获取
        /*getFile("src/1.txt");//java.io.FileNotFoundException
        getFile("web/2.txt");//java.io.FileNotFoundException
        getFile("web/WEB-INF/3.txt");//java.io.FileNotFoundException
        getFile("4.txt");//java.io.FileNotFoundException*/
        //原因:SE和EE代码的执行位置不同的,相对路径出发目录也不同
        //SE代码执行位置是:当前项目的Out执行。 相对路径出发目录:当前源码目录的根目录
        //EE代码执行位置时:tomcat的bin目录执行。 相对路径出发目录:Tomcat的bin目录
        //结论:1、SE和EE最终都需要绝对路径
        //      2、SE的相对路径出发目录是当前源码根目录,所以可以正常使用
        //         EE的相对路径的出发目录是tomcat的bin目录,不能使用。
        String absolutePath = new File("./").getAbsolutePath();
        System.out.println(absolutePath);//D:\temp\apache-tomcat-7.0.52\bin\
        //获取发布目录根目录在硬盘的绝对位置
        String path = getServletContext().getRealPath("/");
        getFile(path+"/WEB-INF/classes/1.txt");
        getFile(path+"/2.txt");
        getFile(path+"/WEB-INF/3.txt");
    }

    image.gif

    最后:

          如果文章对您有帮助,就拿起小手赶紧给博主点赞💚评论❤️收藏💙 一下吧!

          愿我们在未来的日子里。熠熠生辉!!!

    相关文章
    |
    7月前
    |
    Java 数据库 网络架构
    菜鸟之路Day36一一Web开发综合案例(部门管理)
    本文详细记录了基于Spring Boot的Web开发综合案例——部门管理功能的实现过程。从环境搭建到功能开发,涵盖数据库表设计、Spring Boot项目创建、依赖引入、配置文件设置以及Mapper、Service、Controller的基础结构构建。文章重点讲解了查询、删除、新增和修改部门信息的业务逻辑实现,遵循RESTful规范设计接口,并通过统一响应结果类`Result`优化前后端交互体验。借助Spring的IoC容器管理与MyBatis的SQL映射,实现了高效的数据操作与业务处理,最终完成部门管理的全功能开发。
    227 12
    |
    6月前
    |
    XML SQL 前端开发
    菜鸟之路Day37一一Web开发综合案例(员工管理)
    本文介绍了基于Web开发的员工管理综合案例,涵盖分页查询、条件分页查询、删除员工和新增员工四大功能模块。通过前后端交互,前端传递参数(如页码、每页记录数、查询条件等),后端使用MyBatis与PageHelper插件处理数据查询与操作。代码结构清晰,包括Controller层接收请求、Service层业务逻辑处理以及Mapper层数据访问,并结合XML动态SQL实现灵活的条件查询。此外,新增与删除功能分别通过POST与DELETE请求完成,确保系统功能完整且高效。
    199 7
    |
    6月前
    |
    存储 前端开发 Java
    菜鸟之路Day38一一Web开发综合案例(三)
    本文介绍了Web开发中的文件上传与员工信息修改的综合案例,涵盖前端到后端的完整流程。重点讲解了阿里云OSS的集成,包括Bucket创建、密钥获取及SDK使用,并通过Spring Boot实现文件上传功能。同时,详细描述了员工信息查询与修改的操作逻辑,涉及Controller、Service和Mapper层代码实现。最后探讨了配置文件的优化,对比@Value与@ConfigurationProperties注解,展示了如何通过实体类批量注入配置参数,提升代码可维护性与灵活性。
    174 1
    |
    7月前
    |
    Web App开发 前端开发 JavaScript
    鸿蒙5开发宝藏案例分享---Web适配一多开发实践
    这是一份实用的鸿蒙Web多设备适配开发指南,针对开发者在不同屏幕尺寸下的布局难题提供了解决方案。文章通过三大法宝(相对单位、媒体查询和窗口监听)详细介绍如何实现智能适配,并提供了多个实战案例,如宫格布局、对话框变形和自适应轮播图等。此外,还分享了调试技巧及工具推荐,帮助开发者快速上手并优化性能。最后鼓励读者实践探索,并提示更多官方资源等待发现。
    |
    10月前
    |
    存储 JSON JavaScript
    WEB CAD插件通过上下文对象MxPluginContext修改UI界面的方法
    本文介绍了如何使用MxPluginContext动态控制MxCAD项目的UI界面。通过该上下文对象,开发者可以灵活设置UI配置,如控制操作栏显隐、编辑按钮、添加侧边栏等。具体方法包括调用`getUiConfig()`获取并修改`mxUiConfig.json`中的属性,实现界面的定制化。此外,还提供了控制命令行聚焦的功能,解决输入框焦点锁定问题。详细代码示例和效果对比图展示了具体实现步骤,帮助开发者更好地适配项目需求。
    |
    前端开发 开发者
    new操作符背后的秘密:揭开Web前端对象创建的神秘面纱!
    【8月更文挑战第23天】在Web前端开发中,`new`操作符是创建对象实例的核心。本文以`Person`构造函数为例,通过四个步骤解析`new`操作符的工作原理:创建空对象、设置新对象原型、执行构造函数并调整`this`指向、判断并返回最终对象。了解这些有助于开发者更好地理解对象实例化过程,从而编写出更规范、易维护的代码。
    145 0
    |
    Java Maven Spring
    Java Web 应用中,资源文件的位置和加载方式
    在Java Web应用中,资源文件如配置文件、静态文件等通常放置在特定目录下,如WEB-INF或classes。通过类加载器或Servlet上下文路径可实现资源的加载与访问。正确管理资源位置与加载方式对应用的稳定性和可维护性至关重要。
    365 7
    |
    前端开发 机器人 测试技术
    【RF案例】Web自动化测试弹窗处理
    在进行Web自动化测试时,常会遇到不同类型的弹窗,如ajax、iframe、新窗口及alert/Confirm等。这些弹窗可通过Selenium进行定位与处理。其中,ajax弹窗直接定位处理;iframe需先选中再操作;新窗口类似iframe处理;而alert/Confirm则需特殊方法应对。在Robot Framework中,需先定义并获取窗口后使用特定关键字处理。此外,还有部分div弹窗需在消失前快速定位。希望本文能帮助大家更好地处理各类弹窗。
    322 6
    【RF案例】Web自动化测试弹窗处理
    |
    前端开发 数据安全/隐私保护
    【前端web入门第二天】03 表单-下拉菜单 文本域 label标签 按钮 【附注册信息综合案例】
    本文档详细介绍了HTML表单的多种元素及其用法,包括下拉菜单(`&lt;select&gt;` 和 `&lt;option&gt;`)、文本域(`&lt;textarea&gt;`)、标签解释(`&lt;label&gt;`)、各类按钮(`&lt;button&gt;`)及表单重置功能、无语义布局标签(`&lt;div&gt;` 和 `&lt;span&gt;`)以及字符实体的应用。此外,还提供了一个完整的注册信息表单案例,涵盖个人信息、教育经历和工作经历等部分,展示了如何综合运用上述元素构建实用的表单。
    284 6
    【前端web入门第二天】03 表单-下拉菜单 文本域 label标签 按钮 【附注册信息综合案例】
    |
    前端开发
    【前端web入门第五天】03 清除默认样式与外边距问题【附综合案例产品卡片与新闻列表】
    本文档详细介绍了CSS中清除默认样式的方法,包括清除内外边距、列表项目符号等;探讨了外边距的合并与塌陷问题及其解决策略;讲解了行内元素垂直边距的处理技巧;并介绍了圆角与盒子阴影效果的实现方法。最后通过产品卡片和新闻列表两个综合案例,展示了所学知识的实际应用。
    336 11

    热门文章

    最新文章