JavaWeb ——servlet学习4之HttpServletRequest、HttpServletResponse和资源下载

本文主要是介绍JavaWeb ——servlet学习4之HttpServletRequest、HttpServletResponse和资源下载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JavaWeb ——servlet学习4之HttpServletRequest、HttpServletResponse和资源下载

Web 服务器收到客户端的 http 请求,会针对每一次请求,分别创建一个用于 代表请求的 request 对象和 代表响应的 response 对象。request 和 response 对象代表请求和响应:获取客户端数据,需要通过request 对象; 向客户端输出数据,需要通过 response 对象。HttpServletResponse 的主要功能用于服务器对客户端的请求进行响应,将Web 服务器处理后的结果返回给客户端。service()方法中形参接收的是HttpServletResponse 接口的实例化对象,这个对象中封装了向客户端发送数据、发送响应头,发送响应状态码的方法。

HttpServletRequest

获取客户端的信息

获取客户端信息

getRequestURL:返回客户端发出请求时的完整URL。

getRequestURI:返回请求行中的资源名部分。

getQueryString :返回请求行中的参数部分。

getPathInfo:返回请求URL中的额外路径信息。额外路径信息是请求URL中的位

于Servlet的路径之后和查询参数之前的内容,它以“/”开头。

getRemoteAddr:返回发出请求的客户机的IP地址。

getRemoteHost:返回发出请求的客户机的完整主机名。

getRemotePort:返回客户机所使用的网络端口号。

getLocalAddr:返回WEB服务器的IP地址。

getLocalName:返回WEB服务器的主机名。

获得客户请求头

getHeader(string name):String getHeaders(String name):Enumeration getHeaderNames()方法

获得客户机请求参数(客户端提交的数据)

  • getParameter(String) (常用)

  • getParameterValues(String name)(常用)

若出现乱码问题,需要进行处理

  • get请求处理乱码:

//get请求过来的数据,在url地址栏上就已经经过编码了,所以我们取到的就是乱码,
//tomcat收到了这批数据,getParameter 默认使用ISO-8859-1去解码//先让文字回到ISO-8859-1对应的字节数组 , 然后再按utf-8组拼字符串
username = new String(username.getBytes("ISO-8859-1") , "UTF-8");
System.out.println("userName="+username+"==password="+password);直接在tomcat里面做配置,以后get请求过来的数据永远都是用UTF-8编码。
在tomcat里面做设置处理 conf/server.xml 加上URIEncoding="utf-8"
<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8"/>
  • Post请求处理乱码:

在getParameter之前,进行格式配置request.setCharacterEncoding("UTF-8");

HttpServletResponse

HttpServletResponse四类功能:

  1. 设置响应头信息;addHeader(“reFresh”, “5;URL=xxxx”);

  2. 发送状态码;sendError(404);

  3. *设置响应正文;getWriter().print(“fdsfdsa”);*

  4. *重定向:sendRedirect(“path”);*

设置正文:

//以字符流的方式写数据	
response.getWriter().print("3秒后跳转到注册页面");  //3秒后跳转到1.html页面
response.setHeader("reFresh", "3;URL=/request_demo5/1.html");//以字节流的方式写数据 
response.getOutputStream().write("hello response2222...".getBytes());

设置状态码,一般不需要我们自己设置,这是由tomcat来分析的

response.setStatus(404);

设置响应头

Date date = new Date(0);
response.setHeader("name", "xuefu");
response.addIntHeader("age", 18);
response.addDateHeader("birthday",date.getTime());
response.addHeader("name", "xueli");
response.setIntHeader("age", 20);

设置重定向

//没有响应,告知客户端重定向到servlet2
//1设置状态码
response.setStatus(302);
//2.设置响应头Location
response.setHeader("Location", "/WEBpro/servlet2");

处理乱码问题

设置编码,如果响应类型为文本,我们需要设置响应编码和文本编码

response.setContentType("text/html;charset=UTF-8") :设置响应类型和编码
response.setCharacterEncoding("UTF-8"):    设置文本编码

资源下载

tomcat默认下载servlet

以超链接的方式下载,不写任何代码。 也能够下载东西下来。

<a href="download/aa.jpg">aa.jpg</a><br>
<a href="download/bb.txt">bb.txt</a><br>
<a href="download/cc.rar">cc.rar</a><br>

原因是tomcat里面有一个默认的Servlet -- DefaultServlet 。这个DefaultServlet 专门用于处理放在tomcat服务器上的静态资源。

自己设置下载

//1. 获取要下载的文件名字 aa.jpg  --- inputStream
String fileName = request.getParameter("filename");//2. 获取这个文件在tomcat里面的绝对路径地址
String path = getServletContext().getRealPath("download/"+fileName);//让浏览器收到这份资源的时候, 以下载的方式提醒用户,而不是直接展示。 
response.setHeader("Content-Disposition", "attachment; filename="+fileName);response.sendRedirect("login_success.html");//3. 转化成输入流
InputStream is = new FileInputStream(path);
OutputStream os = response.getOutputStream();int len = 0 ;
byte[]buffer = new byte[1024];
while( (len = is.read(buffer)) != -1){os.write(buffer, 0, len);
}os.close();
is.close();

文件名字中带有中文处理

IE、Google用URLEncoding编码

FireFox使用Base64编码

String clientType = request.getHeader("UserAgent");
if(clientType = "firefox"){filename = DownLoadUtil.Base64EncodingFileName(filename)
}
filename = URLEncoding.encode(filename,"UTF-8");

重定向与请求转发

// 重定向:
response.setStatus(302);
response.setHeader("Location", "login_success.html");
//重定向写法: 重新定位方向 参数即跳转的位置
response.sendRedirect("login_success.html");// 请求转发
request.getRequestDispatcher("login_success.html").forward(request, response);

异同:

重定向:

  1. 地址上显示的是最后的那个资源的路径地址

  2. 请求次数最少有两次, 服务器在第一次请求后,会返回302 以及一个地址, 浏览器在根据这个地址,执行第二次访问

  3. 可以跳转到任意路径。 不是自己的工程也可以跳

  4. 效率稍微低一点, 执行两次请求。

  5. 后续的请求,没法使用上一次的request存储的数据,或者 没法使用上一次的request对象,因为这是两次不同的请求

请求转发:

  1. 地址上显示的是请求servlet的地址。 返回200 ok

  2. 请求次数只有一次, 因为是服务器内部帮客户端执行了后续的工作。

  3. 只能跳转自己项目的资源路径 。

  4. 效率上稍微高一点,因为只执行一次请求。

  5. 可以使用上一次的request对象。

 

 

 

 

 

 

 

 

 

 

 

 

 

这篇关于JavaWeb ——servlet学习4之HttpServletRequest、HttpServletResponse和资源下载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1045630

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06