【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

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


相关文章
|
8月前
|
Java 数据库 网络架构
菜鸟之路Day36一一Web开发综合案例(部门管理)
本文详细记录了基于Spring Boot的Web开发综合案例——部门管理功能的实现过程。从环境搭建到功能开发,涵盖数据库表设计、Spring Boot项目创建、依赖引入、配置文件设置以及Mapper、Service、Controller的基础结构构建。文章重点讲解了查询、删除、新增和修改部门信息的业务逻辑实现,遵循RESTful规范设计接口,并通过统一响应结果类`Result`优化前后端交互体验。借助Spring的IoC容器管理与MyBatis的SQL映射,实现了高效的数据操作与业务处理,最终完成部门管理的全功能开发。
304 12
|
7月前
|
XML SQL 前端开发
菜鸟之路Day37一一Web开发综合案例(员工管理)
本文介绍了基于Web开发的员工管理综合案例,涵盖分页查询、条件分页查询、删除员工和新增员工四大功能模块。通过前后端交互,前端传递参数(如页码、每页记录数、查询条件等),后端使用MyBatis与PageHelper插件处理数据查询与操作。代码结构清晰,包括Controller层接收请求、Service层业务逻辑处理以及Mapper层数据访问,并结合XML动态SQL实现灵活的条件查询。此外,新增与删除功能分别通过POST与DELETE请求完成,确保系统功能完整且高效。
246 7
|
7月前
|
存储 前端开发 Java
菜鸟之路Day38一一Web开发综合案例(三)
本文介绍了Web开发中的文件上传与员工信息修改的综合案例,涵盖前端到后端的完整流程。重点讲解了阿里云OSS的集成,包括Bucket创建、密钥获取及SDK使用,并通过Spring Boot实现文件上传功能。同时,详细描述了员工信息查询与修改的操作逻辑,涉及Controller、Service和Mapper层代码实现。最后探讨了配置文件的优化,对比@Value与@ConfigurationProperties注解,展示了如何通过实体类批量注入配置参数,提升代码可维护性与灵活性。
219 1
|
8月前
|
Web App开发 前端开发 JavaScript
鸿蒙5开发宝藏案例分享---Web适配一多开发实践
这是一份实用的鸿蒙Web多设备适配开发指南,针对开发者在不同屏幕尺寸下的布局难题提供了解决方案。文章通过三大法宝(相对单位、媒体查询和窗口监听)详细介绍如何实现智能适配,并提供了多个实战案例,如宫格布局、对话框变形和自适应轮播图等。此外,还分享了调试技巧及工具推荐,帮助开发者快速上手并优化性能。最后鼓励读者实践探索,并提示更多官方资源等待发现。
|
Java Maven Spring
Java Web 应用中,资源文件的位置和加载方式
在Java Web应用中,资源文件如配置文件、静态文件等通常放置在特定目录下,如WEB-INF或classes。通过类加载器或Servlet上下文路径可实现资源的加载与访问。正确管理资源位置与加载方式对应用的稳定性和可维护性至关重要。
405 7
|
前端开发 机器人 测试技术
【RF案例】Web自动化测试弹窗处理
在进行Web自动化测试时,常会遇到不同类型的弹窗,如ajax、iframe、新窗口及alert/Confirm等。这些弹窗可通过Selenium进行定位与处理。其中,ajax弹窗直接定位处理;iframe需先选中再操作;新窗口类似iframe处理;而alert/Confirm则需特殊方法应对。在Robot Framework中,需先定义并获取窗口后使用特定关键字处理。此外,还有部分div弹窗需在消失前快速定位。希望本文能帮助大家更好地处理各类弹窗。
383 6
【RF案例】Web自动化测试弹窗处理
|
前端开发 数据安全/隐私保护
【前端web入门第二天】03 表单-下拉菜单 文本域 label标签 按钮 【附注册信息综合案例】
本文档详细介绍了HTML表单的多种元素及其用法,包括下拉菜单(`<select>` 和 `<option>`)、文本域(`<textarea>`)、标签解释(`<label>`)、各类按钮(`<button>`)及表单重置功能、无语义布局标签(`<div>` 和 `<span>`)以及字符实体的应用。此外,还提供了一个完整的注册信息表单案例,涵盖个人信息、教育经历和工作经历等部分,展示了如何综合运用上述元素构建实用的表单。
324 6
【前端web入门第二天】03 表单-下拉菜单 文本域 label标签 按钮 【附注册信息综合案例】
|
数据采集 自然语言处理 API
Python反爬案例——验证码的识别
Python反爬案例——验证码的识别
501 2
|
存储 前端开发 Java
验证码案例 —— Kaptcha 插件介绍 后端生成验证码,前端展示并进行session验证(带完整前后端源码)
本文介绍了使用Kaptcha插件在SpringBoot项目中实现验证码的生成和验证,包括后端生成验证码、前端展示以及通过session进行验证码校验的完整前后端代码和配置过程。
2749 0
验证码案例 —— Kaptcha 插件介绍 后端生成验证码,前端展示并进行session验证(带完整前后端源码)
|
前端开发
【前端web入门第五天】03 清除默认样式与外边距问题【附综合案例产品卡片与新闻列表】
本文档详细介绍了CSS中清除默认样式的方法,包括清除内外边距、列表项目符号等;探讨了外边距的合并与塌陷问题及其解决策略;讲解了行内元素垂直边距的处理技巧;并介绍了圆角与盒子阴影效果的实现方法。最后通过产品卡片和新闻列表两个综合案例,展示了所学知识的实际应用。
379 11