JSP中通过Servlet 将服务器硬盘图片并展示到浏览器

发布时间 - 2026-01-11 02:53:45    点击率:

JSP中通过Servlet 将服务器硬盘图片并展示到浏览器

其实这个实例非常简单,但是今天有人问我了,而且我也写了个小例子,就顺便发上来吧! 

在浏览器显示一张图片,使用标签

<img src=""> 

img 元素向网页中嵌入一幅图像。

请注意,从技术上讲,<img> 标签并不会在网页中插入图像,而是从网页上链接图像。<img> 标签创建的是被引用图像的占位空间。

<img> 标签有两个必需的属性:src 属性 和 alt 属性。 

HTML 与 XHTML 之间的差异
在 HTML 中,<img> 标签没有结束标签。
在 XHTML 中,<img> 标签必须被正确地关闭。
在 HTML 4.01 中,不推荐使用 image 元素的 "align"、"border"、"hspace" 以及 "vspace" 属性。
在 XHTML 1.0 Strict DTD 中,不支持 image 元素的 "align"、"border"、"hspace" 以及 "vspace" 属性。 

SRC的路径有很多:

指向其他站点(比如 src="http://www.******.com/***.jpg")

指向站点内的文件(比如 src="/i/image.gif")

许多新手忽略了一点是,其实IMG只是告诉浏览器这里要现实图片,而浏览器通过路径去获得图片的数据流然后进行显示

简单来说,SRC其实就是浏览器走了一个请求,然后这个请求返回图片的数据流给浏览器而已

所以,SRC同样可以是请求,可以是Servlet也可以是Action,这里我们用Servlet来做一个简单示例 

JSP页面:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> 
<% 
String path = request.getContextPath(); 
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; 
%> 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
<html> 
 <head> 
  <base href="<%=basePath%>" rel="external nofollow" > 
  <title>图片显示</title> 
 </head> 
 <body> 
  <img src="<%=basePath %>servlet/ImageShowServlet"> 
 </body> 
</html> 

 Web.xml配置:

<?xml version="1.0" encoding="UTF-8"?> 
<web-app version="2.5"  
  xmlns="http://java.sun.com/xml/ns/javaee"  
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee  
  http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> 
 <servlet> 
  <servlet-name>ImageShowServlet</servlet-name> 
  <servlet-class>servlet.ImageShowServlet</servlet-class> 
 </servlet> 
 <servlet-mapping> 
  <servlet-name>ImageShowServlet</servlet-name> 
  <url-pattern>/servlet/ImageShowServlet</url-pattern> 
 </servlet-mapping> 
 <welcome-file-list> 
  <welcome-file>index.jsp</welcome-file> 
 </welcome-file-list> 
</web-app> 
 

Servlet非常简单:

package servlet; 
 
import java.io.ByteArrayOutputStream; 
import java.io.File; 
import java.io.FileInputStream; 
import java.io.IOException; 
import java.io.InputStream; 
import java.io.OutputStream; 
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
 
/** 
 * @说明 该Servlet将本地硬盘的图片输入管道中 
 * @author cuisuqiang 
 * @version 1.0 
 * @since 
 */ 
@SuppressWarnings("serial") 
public class ImageShowServlet extends HttpServlet { 
 
  @Override 
  protected void service(HttpServletRequest request, HttpServletResponse response) 
      throws ServletException, IOException { 
    OutputStream os = response.getOutputStream(); 
    File file = new File("C:\\abc.jpg"); 
    FileInputStream fips = new FileInputStream(file); 
    byte[] btImg = readStream(fips); 
    os.write(btImg); 
    os.flush(); 
  } 
   
  /** 
   * 读取管道中的流数据 
   */ 
  public byte[] readStream(InputStream inStream) { 
    ByteArrayOutputStream bops = new ByteArrayOutputStream(); 
    int data = -1; 
    try { 
      while((data = inStream.read()) != -1){ 
        bops.write(data); 
      } 
      return bops.toByteArray(); 
    }catch(Exception e){ 
      return null; 
    } 
  } 
} 
 

就是获取本地硬盘的文件的字节流,然后写入到管道中而已!

 以上就是JSP中通过Servlet 将服务器硬盘图片并展示到浏览器的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# JSP中通过Servlet  # 将服务器硬盘图片并展示到浏览器  # Servlet  # 将服务器硬盘图片显示  # Java  # JSP  # Servlet获取当前工程路径(绝对路径)问题解析  # JSP 开发之THE SERVLET NAME ALREADY EXISTS.解决方法  # Jsp+Servlet实现购物车功能  # JSP 开发之Servlet解决网页缓存问题  # 浅谈Servlet转发到JSP页面的路径问题(必看)  # JSP 开发之servlet中调用注入spring管理的dao  # JSP开发Servlet重写init()方法实例详解  # JSP 中Servlet的自己实现  # 道中  # 的是  # 我也  # 走了  # 有很多  # 如有  # 推荐使用  # 会在  # 是从  # 希望能  # 我了  # 写了  # 一幅  # 请注意  # 不支持  # 来吧  # 来做  # 谢谢大家  # 上讲  # 正确地 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】  郑州企业网站制作公司,郑州招聘网站有哪些?  Java类加载基本过程详细介绍  Bootstrap整体框架之CSS12栅格系统  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  如何打造高效商业网站?建站目的决定转化率  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  微信小程序 require机制详解及实例代码  Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践  如何快速上传自定义模板至建站之星?  如何快速搭建高效香港服务器网站?  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】  Thinkphp 中 distinct 的用法解析  Laravel中间件如何使用_Laravel自定义中间件实现权限控制  Laravel如何创建自定义中间件?(Middleware代码示例)  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  jquery插件bootstrapValidator表单验证详解  php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】  Google浏览器为什么这么卡 Google浏览器提速优化设置步骤【方法】  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  如何用花生壳三步快速搭建专属网站?  如何用免费手机建站系统零基础打造专业网站?  如何在IIS7中新建站点?详细步骤解析  Python文本处理实践_日志清洗解析【指导】  香港服务器WordPress建站指南:SEO优化与高效部署策略  Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  javascript如何操作浏览器历史记录_怎样实现无刷新导航  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  手机软键盘弹出时影响布局的解决方法  网站制作报价单模板图片,小松挖机官方网站报价?  Python制作简易注册登录系统  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  如何彻底删除建站之星生成的Banner?  Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  Linux安全能力提升路径_长期防护思维说明【指导】  微信小程序 canvas开发实例及注意事项