【JavaWeb】案例:读取 WEB 工程下的资源文件、文件下载、点击切换验证码

简介: 本期主要介绍读取 WEB 工程下的资源文件、文件下载、点击切换验证码

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


2.1、需求说明


image.png

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

2.2、案例原型准备


准备代码:

image.png

2.3、案例代码实现-JavaSE


image.png

2.4、案例分析-JavaEE


因为 javaEE 项目最终部署到 tomcat 上运行,目录结构发生了改变,变为如下结构。

所以我们需要使用 JavaEE 的方式才能获取到文件正确路径。

image.png

我们使用 ServletContext 的 getRealPath(String path);来获取文件的真实路径

path 路径需要写成 webapps 中的路径,项目名缩写为 /

2.5、案例代码实现-JavaEE


image.png

3、案例 3:文件下载


3.1、需求说明


image.png

分别使用超链接和 Servlet 程序,进行网站资源的下载。

3.2、需求分析


超链接下载方式,其实就是依赖了缺省 Servlet 进行下载。

image.png

而缺省 Servlet 无法处理中文,所以我们只能自己写 Servlet 程序,来帮我们获取中文资源进行下载

3.3、案例代码实现-固定文件名


3.3.1、动态获取文件名下载


3.3.2、强制下载响应头设置


3.3.3、解决下载文件名乱码工具使用


// 必须写在 getOutputStream()之前

response.setHeader("Content-Disposition", "attachment;filename="+filename);

上传文件名乱码解决:

new String("".getBytes("iso8859-1"),"utf-8");

下载文件名中文乱码解决工具:(直接使用即可,谷歌未存在)

image.png

4、案例 4:点击切换验证码


4.1、需求说明


在访问登录页面时,需要生产验证码。从而防止用户使用程序恶意登录。

image.png

4.2、案例代码实现


login.jsp

image.png

5、知识讲解-程序跳转-重定向【重点】


javaEE 资源跳转方式有两种:

1、 重定向

2、 请求转发

今天我们来学习重定向方式进行资源跳转

image.png

浏览器立即重新确定方向,再次请求(重定向)

image.png

5.1、请求转发和重定向的区别【重点】


主要区别:

1 、 请求转发使用 request 对象,重定向使用 response 对象

2 、 请求转发使用服务器端路径,重定向使用客户端路径

3 、 请求转发不能跳转外网,重定向可以

4 、 请求转发是服务器内部的跳转,不依赖网速,跳转速度极快。

重定向是依赖浏览器的跳转,严重依赖网速,跳转速度略慢

5 、 请求转发:请求一次,响应一次。 占用资源少

重定向:重定向 N 次,响应 n+1 次。占用大量资源

6 、 请求转发可以访问受保护目录资源,重定向不能

7 、 请求转发不会改变地址栏路径,重定向会改变路径。

安全:请求转发。会隐藏后面转发程序的访问路径。

程序 BUG :由于请求转发不会更改地址,会导致用户重复访问某个 Servlet

程序。改为重定向

8 、 请求转发可以使用 request 作用域,重定向不能

何时使用请求转发。

1、 为了安全,隐藏某些程序的访问路径

2、 为了效率

3、 为了内存占用率低

4、 访问受保护目录资源

5、 使用 request 作用域

何时使用重定向:

1、 跳转外网路径

2、 改变地址栏访问路径

除了以上 7 种情况,两种跳转方式可以相互替代

image.png

image.png

请求外网,用重定向,其他所有使用请求转发即可 


相关文章
|
16天前
|
前端开发 机器人 测试技术
【RF案例】Web自动化测试弹窗处理
在进行Web自动化测试时,常会遇到不同类型的弹窗,如ajax、iframe、新窗口及alert/Confirm等。这些弹窗可通过Selenium进行定位与处理。其中,ajax弹窗直接定位处理;iframe需先选中再操作;新窗口类似iframe处理;而alert/Confirm则需特殊方法应对。在Robot Framework中,需先定义并获取窗口后使用特定关键字处理。此外,还有部分div弹窗需在消失前快速定位。希望本文能帮助大家更好地处理各类弹窗。
22 6
【RF案例】Web自动化测试弹窗处理
|
16天前
|
前端开发 数据安全/隐私保护
【前端web入门第二天】03 表单-下拉菜单 文本域 label标签 按钮 【附注册信息综合案例】
本文档详细介绍了HTML表单的多种元素及其用法,包括下拉菜单(`<select>` 和 `<option>`)、文本域(`<textarea>`)、标签解释(`<label>`)、各类按钮(`<button>`)及表单重置功能、无语义布局标签(`<div>` 和 `<span>`)以及字符实体的应用。此外,还提供了一个完整的注册信息表单案例,涵盖个人信息、教育经历和工作经历等部分,展示了如何综合运用上述元素构建实用的表单。
【前端web入门第二天】03 表单-下拉菜单 文本域 label标签 按钮 【附注册信息综合案例】
|
8天前
|
安全 关系型数据库 MySQL
Web安全-任意文件下载漏洞
Web安全-任意文件下载漏洞
27 5
|
16天前
|
前端开发
【前端web入门第五天】03 清除默认样式与外边距问题【附综合案例产品卡片与新闻列表】
本文档详细介绍了CSS中清除默认样式的方法,包括清除内外边距、列表项目符号等;探讨了外边距的合并与塌陷问题及其解决策略;讲解了行内元素垂直边距的处理技巧;并介绍了圆角与盒子阴影效果的实现方法。最后通过产品卡片和新闻列表两个综合案例,展示了所学知识的实际应用。
27 11
|
16天前
|
前端开发
前端web入门第四天】03 显示模式+综合案例热词与banner效果
本文档介绍了HTML中标签的三种显示模式:块级元素、行内元素与行内块元素,并详细解释了各自的特性和应用场景。块级元素独占一行,宽度默认为父级100%,可设置宽高;行内元素在同一行显示,尺寸由内容决定,设置宽高无效;行内块元素在同一行显示,尺寸由内容决定,可设置宽高。此外,还提供了两个综合案例,包括热词展示和banner效果实现,帮助读者更好地理解和应用这些显示模式。
|
18天前
|
JavaScript 前端开发
【前端web入门第一天】03 综合案例 个人简介与vue简介
该网页采用“从上到下,先整体再局部”的制作思路,逐步分析并编写代码实现个人简介页面。内容涵盖尤雨溪的背景、学习经历及主要成就,同时介绍其开发的Vue.js框架特点。代码结构清晰,注重细节处理,如使用快捷键提高效率,预留超链接位置等,确保最终效果符合预期。
|
27天前
|
C# 开发者 Windows
WPF遇上Office:一场关于Word与Excel自动化操作的技术盛宴,从环境搭建到代码实战,看WPF如何玩转文档处理的那些事儿
【8月更文挑战第31天】Windows Presentation Foundation (WPF) 是 .NET Framework 的重要组件,以其强大的图形界面和灵活的数据绑定功能著称。本文通过具体示例代码,介绍如何在 WPF 应用中实现 Word 和 Excel 文档的自动化操作,包括文档的读取、编辑和保存等。首先创建 WPF 项目并设计用户界面,然后在 `MainWindow.xaml.cs` 中编写逻辑代码,利用 `Microsoft.Office.Interop` 命名空间实现 Office 文档的自动化处理。文章还提供了注意事项,帮助开发者避免常见问题。
98 0
|
27天前
|
UED
JSF文件下载:解锁终极文件传输秘籍,让你的Web应用瞬间高大上!
【8月更文挑战第31天】掌握JSF文件下载功能对构建全面的Web应用至关重要。本文通过具体代码示例,详细介绍如何在JSF中实现文件下载。关键在于后端Bean中的文件读取与响应设置。示例展示了从创建实体类到使用`<h:commandLink>`触发下载的全过程,并通过正确设置响应头和处理文件流,确保文件能被顺利下载。这将显著提升Web应用的实用性与用户体验。
45 0
|
28天前
|
Java 前端开发 Apache
Apache Wicket与Spring MVC等Java Web框架大PK,究竟谁才是你的最佳拍档?点击揭秘!
【8月更文挑战第31天】在Java Web开发领域,众多框架各具特色。Apache Wicket以组件化开发和易用性脱颖而出,提高了代码的可维护性和可读性。相比之下,Spring MVC拥有强大的生态系统,但学习曲线较陡;JSF与Java EE紧密集成,但在性能和灵活性上略逊一筹;Struts2虽成熟,但在RESTful API支持上不足。选择框架时还需考虑社区支持和文档完善程度。希望本文能帮助开发者找到最适合自己的框架。
30 0
|
28天前
|
UED 存储 自然语言处理
【语言无界·体验无疆】解锁Vaadin应用全球化秘籍:从代码到文化,让你的应用畅游世界每一个角落!
【8月更文挑战第31天】《国际化与本地化实战:构建多语言支持的Vaadin应用》详细介绍了如何使用Vaadin框架实现应用的国际化和本地化,提升用户体验和市场竞争力。文章涵盖资源文件的创建与管理、消息绑定与动态加载、日期和数字格式化及文化敏感性处理等方面,通过具体示例代码和最佳实践,帮助开发者构建适应不同语言和地区设置的Vaadin应用。通过这些步骤,您的应用将更加灵活,满足全球用户需求。
32 0