源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
查看: 391|回复: 15

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

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2018-12-25 21:49:52 | 显示全部楼层 |阅读模式
这篇文章主要介绍了JSP中通过Servlet 将服务器硬盘图片并展示到浏览器的相关资料,希望通过本文大家可以实现这样的功能,需要的朋友可以参考下

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 将服务器硬盘图片并展示到浏览器的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

回复

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2022-9-20 16:42:54 | 显示全部楼层
看到这帖子真是高兴!
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

186

积分

注册会员

Rank: 2

积分
186
发表于 2023-1-8 02:15:48 | 显示全部楼层
而非为吾问无为谓娃娃
回复 支持 反对

使用道具 举报

16

主题

2万

回帖

174

积分

注册会员

Rank: 2

积分
174
发表于 2023-12-10 12:42:15 | 显示全部楼层
额UI废物iuhfujewfiewnnfen
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

69

积分

注册会员

Rank: 2

积分
69
发表于 2024-6-20 22:15:05 | 显示全部楼层
笑纳了老板
回复 支持 反对

使用道具 举报

1

主题

2万

回帖

176

积分

注册会员

Rank: 2

积分
176
发表于 2024-8-25 07:14:32 | 显示全部楼层
vcxvcxv
回复 支持 反对

使用道具 举报

1

主题

2万

回帖

155

积分

注册会员

Rank: 2

积分
155
发表于 2024-8-26 10:23:14 | 显示全部楼层
加快速度很快就撒谎
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2024-9-10 17:30:44 | 显示全部楼层
需要很久了终于找到了
回复 支持 反对

使用道具 举报

11

主题

1万

回帖

103

积分

注册会员

Rank: 2

积分
103
发表于 2024-9-25 08:48:37 | 显示全部楼层
快更新啊,我擦
回复 支持 反对

使用道具 举报

26

主题

8706

回帖

140

积分

注册会员

Rank: 2

积分
140
发表于 2024-9-26 14:11:02 | 显示全部楼层
啦啦啦啦啦德玛西亚
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2024-11-21 15:20 , Processed in 0.162625 second(s), 26 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表