• JSP 服务器响应


    Response响应对象主要将JSP容器处理后的结果传回到客户端。可以通过response变量设置HTTP的状态和向客户端发送数据,如Cookie、HTTP文件头信息等。

    一个典型的响应看起来就像下面这样:

    HTTP/1.1 200 OK
    Content-Type: text/html
    Header2: ...
    ...
    HeaderN: ...
      (Blank Line)
    <!doctype ...>
    <html>
    <head>...</head>
    <body>
    ...
    </body>
    </html>
    

    状态行包含HTTP版本信息,比如HTTP/1.1,一个状态码,比如200,还有一个非常短的信息对应着状态码,比如OK。

    下表摘要出了HTTP1.1响应头中最有用的部分,在网络编程中您将会经常见到它们:

    响应头描述
    Allow 指定服务器支持的request方法(GET,POST等等)
    Cache-Control 指定响应文档能够被安全缓存的情况。通常取值为 publicprivate 或no-cache 等等。 Public意味着文档可缓存,Private意味着文档只为单用户服务并且只能使用私有缓存。No-cache 意味着文档不被缓存。
    Connection 命令浏览器是否要使用持久的HTTP连接。close 命令浏览器不使用持久HTTP连接,而keep-alive 意味着使用持久化连接。
    Content-Disposition 让浏览器要求用户将响应以给定的名称存储在磁盘中
    Content-Encoding 指定传输时页面的编码规则
    Content-Language 表述文档所使用的语言,比如en, en-us,,ru等等
    Content-Length 表明响应的字节数。只有在浏览器使用持久化 (keep-alive) HTTP 连接时才有用
    Content-Type 表明文档使用的MIME类型
    Expires 指明啥时候过期并从缓存中移除
    Last-Modified 指明文档最后修改时间。客户端可以 缓存文档并且在后续的请求中提供一个 If-Modified-Since请求头
    Location 在300秒内,包含所有的有一个状态码的响应地址,浏览器会自动重连然后检索新文档
    Refresh 指明浏览器每隔多久请求更新一次页面。
    Retry-After 与503 (Service Unavailable)一起使用来告诉用户多久后请求将会得到响应
    Set-Cookie 指明当前页面对应的cookie

    HttpServletResponse类

    response对象是javax.servlet.http.HttpServletRequest类的一个实例。就像服务器会创建request对象一样,它也会创建一个客户端响应。

    response对象定义了处理创建HTTP信息头的接口。通过使用这个对象,开发者们可以添加新的cookie或时间戳,还有HTTP状态吗等等。

    下表列出了用来设置HTTP响应头的方法,这些方法由HttpServletResponse 类提供:

    S.N.方法 & 描述
    1 String encodeRedirectURL(String url) 对sendRedirect()方法使用的URL进行编码
    2 String encodeURL(String url) 将URL编码,回传包含Session ID的URL
    3 boolean containsHeader(String name) 返回指定的响应头是否存在
    4 boolean isCommitted() 返回响应是否已经提交到客户端
    5 void addCookie(Cookie cookie) 添加指定的cookie至响应中
    6 void addDateHeader(String name, long date) 添加指定名称的响应头和日期值
    7 void addHeader(String name, String value) 添加指定名称的响应头和值
    8 void addIntHeader(String name, int value) 添加指定名称的响应头和int值
    9 void flushBuffer() 将任何缓存中的内容写入客户端
    10 void reset() 清除任何缓存中的任何数据,包括状态码和各种响应头
    11 void resetBuffer() 清除基本的缓存数据,不包括响应头和状态码
    12 void sendError(int sc) 使用指定的状态码向客户端发送一个出错响应,然后清除缓存
    13 void sendError(int sc, String msg) 使用指定的状态码和消息向客户端发送一个出错响应
    14 void sendRedirect(String location) 使用指定的URL向客户端发送一个临时的间接响应
    15 void setBufferSize(int size) 设置响应体的缓存区大小
    16 void setCharacterEncoding(String charset) 指定响应的编码集(MIME字符集),例如UTF-8
    17 void setContentLength(int len) 指定HTTP servlets中响应的内容的长度,此方法用来设置 HTTP Content-Length 信息头
    18 void setContentType(String type) 设置响应的内容的类型,如果响应还未被提交的话
    19 void setDateHeader(String name, long date) 使用指定名称和值设置响应头的名称和内容
    20 void setHeader(String name, String value) 使用指定名称和值设置响应头的名称和内容
    21 void setIntHeader(String name, int value) 使用指定名称和值设置响应头的名称和内容
    22 void setLocale(Locale loc) 设置响应的语言环境,如果响应尚未被提交的话
    23 void setStatus(int sc) 设置响应的状态码

    HTTP响应头程序示例

    接下来的例子使用setIntHeader()方法和setRefreshHeader()方法来模拟一个数字时钟:

    <%@ page import="java.io.*,java.util.*" %>
    <html>
    <head>
    <title>Auto Refresh Header Example</title>
    </head>
    <body>
    <center>
    <h2>Auto Refresh Header Example</h2>
    <%
       // 设置每隔5秒自动刷新
       response.setIntHeader("Refresh", 5);
       // 获取当前时间
       Calendar calendar = new GregorianCalendar();
       String am_pm;
       int hour = calendar.get(Calendar.HOUR);
       int minute = calendar.get(Calendar.MINUTE);
       int second = calendar.get(Calendar.SECOND);
       if(calendar.get(Calendar.AM_PM) == 0)
          am_pm = "AM";
       else
          am_pm = "PM";
       String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
       out.println("Current Time is: " + CT + "
    ");
    %>
    </center>
    </body>
    </html>

    将以上代码保存为main.jsp,然后通过浏览器访问它。它将会每隔5秒显示一下系统当前时间。

    运行结果如下:

    Auto Refresh Header Example
    Current Time is: 9:44:50 PM
    

    您也可以自己动手修改以上代码,试试使用其他的方法,将能得到更深的体会。

     
  • 相关阅读:
    Unity HOME
    Unity Document
    css3动画的性能优化_针对移动端卡顿问题
    前端工程师分享几个CSS技巧
    什么是前端? web1.0、web2.0时代的网页制作,前端开发都有哪些内容等
    前端工程之CDN部署_前端为什么非要动静分离?说一下CDN托管的意义
    JSON API免费接口_ 免费的天气预报、地图、IP、手机信息查询、翻译、新闻等api接口
    利用伪元素:before和:after插入图标
    CSS中的三大特性_继承性、层叠性、优先级
    WEB专用服务器的安全设置的实战技巧----IIS设置
  • 原文地址:https://www.cnblogs.com/benbenduo/p/4077856.html
Copyright © 2020-2023  润新知