文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java Servlet响应httpServletResponse过程是什么

2023-06-29 08:02

关注

本篇内容主要讲解“Java Servlet响应httpServletResponse过程是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java Servlet响应httpServletResponse过程是什么”吧!

一、核心方法

1.setStatus

设置响应状态码 如果没有调用这个方法,默认返回200状态码(前提:正常执行,没有异常) 如果出现异常,返回500

前端代码:

<body>    <h4>设置响应头</h4>    <input type="text" id="status">    <br>    <button onclick="setStatus()">提交</button></body><script>    function setStatus(){        //js中发送请求:(1)ajax(2)直接修改url        let status = document.querySelector("#status");        //后端会设置文本框输入的值为响应状态码:严格来做需要验证(省略)        window.location.href = "response?status="+status.value;    }</script>

后端代码:

@WebServlet("/response")public class ResponseStudyServlet extends HttpServlet {    @Override    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        //获取请求发送的queryString数据:status=xxx        String status = req.getParameter("status");        resp.setStatus((Integer.parseInt(status)));        resp.getWriter().write("设置响应状态码成功");    }}

前端显示:

Java Servlet响应httpServletResponse过程是什么

提交后fiddler抓包:

Java Servlet响应httpServletResponse过程是什么

2.setHeader(String name,String value)

设置响应头

响应头name键已有,会覆盖原有的键值对

前端代码:

<h4>设置响应头</h4><a href="response" rel="external nofollow" >设置</a>

后端代码:

//设置响应头的键值对,键可以是标准的http响应头的键,也可以是自定义的//响应状态码是301,302,307,响应头有Location字段,才是重定向resp.setHeader("Location","http://www.baidu.com");resp.setHeader("username","张三");

fiddler抓包结果:

Java Servlet响应httpServletResponse过程是什么

3.addHeader(String name,String value)

设置响应头

响应头name键已有,不会影响,添加一个新的

这两个了解即可

4.setContentType(String type)

设置响应头Content-Type的值,等同于setHeader(“Content-Type”,String type) 因为Content-Type是标识body的数据格式,所以还需要设置body的内容

响应一个网页

//响应html:设置响应的Content-Typeresp.setContentType("text/html; charset=utf-8");

可以返回静态和动态网页

两种方式展示:

前端代码:

<body>    <h4>返回响应正文为简单的html</h4>    <a href="html?type=1" rel="external nofollow" >查看</a>    <h4>返回响应正文为复杂的html(动态变化的)</h4>    <input type="text" id="username" placeholder="输入姓名">    <br>    <button onclick="toWelcome()">跳转</button></body><script>    function toWelcome(){        let username = document.querySelector("#username");        window.location.href = "html?type=2&username="+username.value;    }</script>

后端代码:

@WebServlet("/html")public class HTMLTypeServlet extends HttpServlet {    //html?type=...    @Override    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        //响应html:设置响应的Content-Type        resp.setContentType("text/html; charset=utf-8");        PrintWriter pw = resp.getWriter();        //获取queryString中,type的值        String type = req.getParameter("type");        if("1".equals(type)){//返回简单的html            pw.println("<h4>获取网页成功</h4>");        }else if("2".equals(type)){//返回复杂的动态html            //html?type=2&username=xxx            String username = req.getParameter("username");            pw.println("<p>");            pw.println("欢迎你,"+username);            pw.println("</p>");        }    }}

简单:

前端显示:

Java Servlet响应httpServletResponse过程是什么

点击“查看”:

Java Servlet响应httpServletResponse过程是什么

动态:

前端显式:

Java Servlet响应httpServletResponse过程是什么

点击“跳转”:

Java Servlet响应httpServletResponse过程是什么

关于动态网页:在Java的代码中,写很多html的代码

耦合性太强(两个完全不同的编程语言,放在一起来开发)、维护性、扩展性很差

解决方式:

二、响应一个网页

返回已有的一个网页

(1)重定向:

特点:url地址栏会变,发起两次请求

原理:

第一次返回301/302/307响应状态码,及响应头Location:网页的地址

第二次:浏览器自动的跳转到Location设置的地址

还是比较常用的:比如登录成功(其实也可以在js代码中跳转)后,跳转到某个首页

(2)转发:

特点:url地址栏不变,只有一次请求

原理:当次请求Servlet时,由Servlet获取到转发路径的html,把这个路径的内容设置到响应正文

前端代码:

<h4>重定向到hello.html</h4><a href="goto?type=1" rel="external nofollow" >跳转</a><h4>转发到hello.html</h4><a href="goto?type=2" rel="external nofollow" >跳转</a>

后端代码:

@WebServlet("/goto")public class GoToServlet extends HttpServlet {    @Override    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        //goto?type=xxx        String type = req.getParameter("type");        if("1".equals(type)){//重定向//            resp.setStatus(301);//            resp.setHeader("Location","hello.html");            //以上代码可以简化为sendRedirect            resp.sendRedirect("hello.html");        }else if("2".equals(type)){//转发            req.getRequestDispatcher("hello.html")                    .forward(req,resp);        }    }}

三、返回一个文件

设置一下Content-Type,然后把文件的二进制数据放在响应正文就可以

前端代码:

<h4>获取一个图片(渲染展示)</h4><img src="file?type=photo&show=1"><h4>获取一个音乐(渲染展示)</h4><audio src="file?type=music&show=1" controls></audio><h4>获取一个图片(下载)</h4><a href="file?type=photo&show=0" rel="external nofollow" >下载</a><h4>获取一个音乐(下载)</h4><audio src="file?type=music&show=0" controls></audio>

后端代码:

@WebServlet("/file")public class FileServlet extends HttpServlet {    @Override    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        //<img src="file?type=photo&show=1">        //获取响应对象的字节输出流        OutputStream os = resp.getOutputStream();        //返回的文件类型:1.图片 2.音乐        String type = req.getParameter("type");        //返回时的操作:1.渲染 2.下载        String show = req.getParameter("show");        File file = null;        byte[] data = null;        //<img src="file?type=photo&show=1">        if("photo".equals(type)){//返回图片            if("1".equals(show)){                resp.setContentType("image/jpeg");//jpg格式            }else{                //这样只是没有设置下载的文件名,有兴趣可以自行扩展完成                resp.setContentType("application/octet-stream");            }            file =new File("D:\\java\\servlet-study\\src\\main\\resources\\cui.jpg");            //<audio src="file?type=music&show=1" controls></audio>        }else if("music".equals(type)){//返回音乐            if("1".equals(show)){                resp.setContentType("audio/mp3");//mp3格式            }else{                resp.setContentType("application/octet-stream");            }            file = new File("D:\\java\\servlet-study\\src\\main\\resources\\这世界有那么多人.mp3");        }//其他格式可以自行扩展完成        //返回一个文件类型:Content-Length,body        data = Files.readAllBytes(file.toPath());        resp.setContentLength(data.length);//setHeader("Content-Length",xxx)        os.write(data);    }}

问题:图片、音乐、视频是静态文件,直接放在web应用webapp下,就可以直接访问,那还需要Servlet来返回么?是否多此一举?

如果文件总的大小非常大,放在web应用的webapp下就不合适了:打包就比较费劲,使用Servlet去读取本地其他地方的文件,来返回,就比较适合

四、返回json数据

常用于ajax请求,返回一些数据,用于动态的填充网页

前端代码:

<body>    <h4>获取ajax响应数据,动态生成网页内容</h4>    <button onclick="gen()">试试</button>    <div id="content"></div></body><script>    function gen(){        let content = document.querySelector("#content");        ajax({            url: "ajax-response",            method: "get",            callback: function(status,resp){                console.log(resp);//resp是一个字符串                //转换为json对象                let array = JSON.parse(resp);                for(json of array){//遍历                    //每一个json对象,创建一个dom来保存信息                    let p = document.createElement("p");                    p.innerHTML = json.from+" 对 "+json.to+" 说:"+json.info;                    content.appendChild(p);                }            }        });    }    function ajax(args){//var ajax = function(){}        let xhr = new XMLHttpRequest();        //设置回调函数        xhr.onreadystatechange = function(){            //4:客户端接收到响应后回调            if(xhr.readyState == 4){                // 回调函数可能需要使用响应的内容,作为传入参数                args.callback(xhr.status,xhr.responseText);            }        }        xhr.open(args.method,args.url);        // 如果args中,Content-Type属性有内容,就设置Content-Type请求头        if(args.contentType){//js中,除了判断boolean值,还可以判断字符串,对象等,有值就为true            xhr.setRequestHeader("Content-Type",args.contentType);        }        //如果args中,设置了body请求正文,调用send(body)        if(args.body){            xhr.send(args.body);        }else{//如果没有设置,调用send()            xhr.send();        }    }</script>

后端代码:

@WebServlet("/ajax-response")public class AjaxJsonServlet extends HttpServlet {    @Override    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        List<Message> messages = new ArrayList<>();        Message m1 = new Message("汪汪","喵喵","我喜欢你");        Message m2 = new Message("喵喵","汪汪","我喜欢你");        messages.add(m1);        messages.add(m2);        ObjectMapper mapper = new ObjectMapper();        //把Java对象,转换为一个json字符串,list和数组会转换为[],一个对象{成员变量名:值}        String json = mapper.writeValueAsString(messages);        //[{"from":"汪汪","to":"喵喵","info":"我喜欢你"},{"from":"喵喵","to":"汪汪","info":"我喜欢你"}]        System.out.println("转换的json字符串"+json);        //设置json可以不设置Content-Length,tomcat会设置        resp.setContentType("application/json; charset=utf-8");        resp.getWriter().println(json);    }    static class Message{        private String from;//谁        private String to;//对谁        private String info;//说了什么        public Message(String from, String to, String info) {            this.from = from;            this.to = to;            this.info = info;        }        public String getFrom() {            return from;        }        public void setFrom(String from) {            this.from = from;        }        public String getTo() {            return to;        }        public void setTo(String to) {            this.to = to;        }        public String getInfo() {            return info;        }        public void setInfo(String info) {            this.info = info;        }    }}

点击“试试”:

Java Servlet响应httpServletResponse过程是什么

Java Servlet响应httpServletResponse过程是什么

具体过程:

Java Servlet响应httpServletResponse过程是什么

对应可以使用的数据格式:

Java Servlet响应httpServletResponse过程是什么

到此,相信大家对“Java Servlet响应httpServletResponse过程是什么”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯