HttpServletResponse ServletResponse 返回响应 设置响应头设置响应正文体 重定向 常用方法 如何重定向 响应编码 响应乱码

原文地址:HttpServletResponse ServletResponse 返回响应 设置响应头设置响应正文体 重定向 常用方法 如何重定向 响应编码 响应乱码

HttpServletResponse  和 ServletResponse  都是接口

具体的类型对象是由Servlet容器传递过来


ServletResponse对象的功能分为以下四种:

?        设置响应头信息;

?        发送状态码;

?        设置响应正文;

?        重定向;


设置响应头信息

HttpServletResponse 中 (ServletResponse 中没有的)

void setHeader(String var1, String var2);

使用该方法设置的响应头最终会发送给客户端浏览器

示例:

response.setHeader(“content-type”, “text/html;charset=utf-8”);

设置content-type响应头,该头的作用是:

  1. 告诉浏览器响应内容为html类型,编码为utf-8。
  2. 而且同时会设置response的字符流编码为utf-8,即response.setCharaceterEncoding(“utf-8”);

自动跳转

response.setHeader("Refresh","5; URL=http://www.baidu.com");

5秒后自动跳转到百度。


发送状态码以及类型

response.setContentType("text/html;charset=utf-8");

//等同与调用response.setHeader(“content-type”, “text/html;charset=utf-8”);

response.setCharacterEncoding(“utf-8”);//设置字符响应流的字符编码为utf-8;

response.setStatus(200);//设置状态码;

response.sendError(404, “您要查找的资源不存在”);//当发送错误状态码时,Tomcat会跳转到固定的错误页面去,但可以显示错误信息。

比如:

response.sendError(404, "您要查找的资源不存在了哈");


设置响应正文


ServletResponse是响应对象,向客户端输出响应正文(响应体)可以使用ServletResponse的响应流

repsonse一共提供了两个响应流对象:

?        PrintWriter out = response.getWriter():获取字符流;

?        ServletOutputStream out = response.getOutputStream():获取字节流;

两个方法都是ServletResponse的 HttpServletResponse继承而得到

注意:

  1. 当然,如果响应正文内容为字符,那么使用response.getWriter()
  2. 如果响应内容是字节,那么可以使用response.getOutputStream()  例如下载时

在一个请求中,不能同时使用这两个流!

也就是说,要么你使用repsonse.getWriter(),要么使用response.getOutputStream(),但不能同时使用这两个流。

不然会抛出IllegalStateException异常。

字符编码


在使用response.getWriter()时需要注意默认字符编码为ISO-8859-1,

如果希望设置字符流的字符编码为utf-8

可以使用

response.setCharaceterEncoding(“utf-8”)来设置。

这样可以保证输出给客户端的字符都是使用UTF-8编码的!

但客户端浏览器并不知道响应数据是什么编码的!

如果希望通知客户端使用UTF-8来解读响应数据,那么还是使用

response.setContentType("text/html;charset=utf-8")方法比较好

因为这个方法不只会调用response.setCharaceterEncoding(“utf-8”),还会设置content-type响应头

客户端浏览器会使用content-type头来解读响应数据。

缓冲区

response.getWriter()是PrintWriter类型,所以它有缓冲区,缓冲区的默认大小为8KB。

也就是说,在响应数据没有输出8KB之前,数据都是存放在缓冲区中,而不会立刻发送到客户端。

当Servlet执行结束后,服务器才会去刷新流,使缓冲区中的数据发送到客户端。

如果希望响应数据马上发送给客户端:

向流中写入大于8KB的数据;

调用response.flushBuffer()方法来手动刷新缓冲区;


重定向

当你访问A网址时,你会发现浏览器地址栏URL变成了B ,这就是重定向

所谓重定向,就是服务器重新定位你的方向,告诉你去别的地方

是再次的发出了请求,全程总共有两个请求

第一步就是设置响应码为302。

响应码为200表示响应成功,而响应码为302表示重定向,你需要告诉浏览器需要重定向

第二步设置重定向的URL

因为重定向是通知浏览器再第二个请求,所以浏览器需要知道第二个请求的URL

所以完成重定向的第二步是设置Location头,指定第二个请求的URL地址。


response.setStatus(302);

response.setHeader("Location", "https://www.cnblogs.com/noteless/");

你会发现地址栏立刻进行了跳转

重定向的简化方式:



response.sendRedirect("https://www.cnblogs.com/noteless/");

如果是在同一台服务器上也可以用相对路径


response.sendRedirect("/servlet/ServletB");

效果同上

重定向注意点:

?        重定向是两次请求;

?        重定向的URL可以是其他应用,不局限于当前应用;

?        重定向的响应头为302,并且必须要有Location响应头;

?        重定向就不要再使用response.getWriter()或response.getOutputStream()输出数据,不然可能会出现异常;

原文地址:https://www.cnblogs.com/xiang--liu/p/11505721.html

时间: 2024-07-31 08:13:12

HttpServletResponse ServletResponse 返回响应 设置响应头设置响应正文体 重定向 常用方法 如何重定向 响应编码 响应乱码的相关文章

HttpServletResponse ServletResponse 返回响应 设置响应头设置响应正文体 重定向 常用方法 如何重定向 响应编码 响应乱码

HttpServletResponse  和 ServletResponse  都是接口 具体的类型对象是由Servlet容器传递过来 ServletResponse对象的功能分为以下四种: ?        设置响应头信息: ?        发送状态码: ?        设置响应正文: ?        重定向: 设置响应头信息 HttpServletResponse 中 (ServletResponse 中没有的) void setHeader(String var1, String v

接口测试——HttpClient工具的https请求、代理设置、请求头设置、获取状态码和响应头

转自:https://www.cnblogs.com/hong-fithing/p/7617855.html https请求 https协议(Secure Hypertext Transfer Protocol) : 安全超文本传输协议, HTTPS以保密为目标研发, 简单讲HTTPS协议是由SSL+HTTP协议构建的可进行加密传输. 身份认证的网络协议, 其安全基础是SSL协议, 因此加密的详细内容请看SSL. 全称Hypertext Transfer Protocol overSecure

最全 HTTP 安全响应头设置指南

销售“安全记分卡”的公司正在崛起,并已开始成为企业销售的一个因素.这些公司组合使用 HTTP 安全报头和 IP 信誉来进行评级.不过,在很大程度上,公司的得分取决于对外开放网站上设置的安全响应报头.本文介绍了常用的安全响应报头及对应的推荐安全值,并给出了示例. 销售“安全记分卡”的公司正在崛起,并已开始成为企业销售的一个因素.我从客户那里了解到,他们对从评级低的供应商那里的采购很不放心,至少有案例表明,他们依据最初的评级改变了采购决策. 我调查了这些评级公司是如何计算公司安全性得分的,结果发现他

设置请求头信息的不同方式

原文:http://blog.csdn.net/magiclr/article/details/49643277 在AngularJs中有三种方式可以设置请求头信息: 1.在http服务的在服务端发送请求时,也就是调用http()方法时,在config对象中设置请求头信息: $http.post('/somePath' , someData , { headers : {'Authorization' : authToken} }).success(function(data, status,

设置请求头解决浏览器同源问题

思想: 添加过滤器 设置请求头 代码如下 package com.deppon.vas.common.framework.cors; import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servl

利用volley进行http设置请求头、超时及请求参数设置(post)

这里以post请求说明,get请求相似设置请求头及超时. 1.自定义request,继承com.android.volley.Request 2.构造方法实现(basecallback,为自定义的监听,实现Response.Listener,ErrorListener接口)--post请求 public BaseRequest(String url,String params, BaseCallback<T> callback)      {   super(Method.POST, url,

header头设置解决 “已拦截跨源请求:同源策略禁止读取位于 http://47.104.128.87/back/test/test 的远程资源。(原因:CORS 头缺少 &#39;Access-Control-Allow-Origin&#39;)。”

跨域请求错误提示如下图: 解决方法在请求的php页面添加header头: 代码如下: public function test() { //支持全域名访问,不安全,部署后需要固定限制为客户端网址 header('Access-Control-Allow-Origin:*'); //支持的http 动作 header('Access-Control-Allow-Methods:POST,GET,OPTIONS,DELETE'); //响应头 请按照自己需求添加. header('Access-Co

PHP使用CURL设置header头传参以及设置Content-Type: application/json类型的后台数据接收

CURL函数 public function CurlRequest($url,$data=null,$header=null){ //初始化浏览器 $ch = curl_init(); //设置浏览器,把参数url传到浏览器的设置当中 curl_setopt($ch, CURLOPT_URL, $url); //以字符串形式返回到浏览器当中 curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); //禁止https协议验证域名,0就是禁止验证域名且兼容p

ajax中的setRequestHeader设置请求头

1.问题引发点: 前不久发现一个问题: 前端并没有设置请求头信息里面的Accept-Encoding:gzip...但是在请求头中可以明显的看到Accept-Encoding:gzip, deflate, sdch,并且我尝试修改这个请求头,发现 不 生 效: 2.XMLHttpRequest对象提供了一个设置请求头的方法:setRequestHeader,对应的jQuery可以再beforeSend回调里面设置请求头: $.ajax({ type: "GET", url: "