日期:2014-05-18  浏览次数:20611 次

table中显示数据库中的取出的图片
在jsp中的一个table的多个cell中想要动态显示从数据库中读出来的binary   data类型的图片.
是不是可以用
<td> <img   src=...> </td>
如果是这样的话,src应该指向什么呢?而且每个图片都有专门的id,来说明要取数据库中的哪条记录.  
我不知道应该怎么作.   是不是可以用src来指向一个servlet,但是怎么给它传参数呢?  
新手敬请各位高手前来执教.多谢了.


------解决方案--------------------


import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
import java.util.*;
import com.sun.image.codec.jpeg.*;
import java.awt.*;
import com.sun.image.codec.jpeg.*;
import java.awt.image.BufferedImage;
import java.awt.image.DataBuffer;
import java.awt.geom.GeneralPath;
import javax.swing.*;
import java.math.*;
public class Servlet1
extends HttpServlet {
//Process the HTTP Get request
public void doGet(HttpServletRequest request, HttpServletResponse response) throws
ServletException, IOException {
response.setContentType(CONTENT_TYPE);
response.setContentType( "image/jpeg "); //必须设置ContentType为image/jpeg
int length = 4; //设置默认生成4个数字
Date d = new Date();
long lseed = d.getTime();
java.util.Random r = new Random(lseed); //设置随机种子
if (request.getParameter( "length ") != null) {
try {
length = Integer.parseInt(request.getParameter( "length "));
}
catch (NumberFormatException e) {
}
}
StringBuffer str = new StringBuffer();
for (int i = 0; i <length; i++) {
str.append(r.nextInt(9)); //生成随机数字
}
//可以在此加入保存验证码的代码
//创建内存图像
BufferedImage bi = new BufferedImage(40, 16, BufferedImage.TYPE_INT_RGB);
Graphics2D g = bi.createGraphics();
g.clearRect(0, 0, 16, 40);
g.setColor(Color.green.CYAN);
g.drawString(str.toString(), 4, 12);
try {
//使用JPEG编码,输出到response的输出流
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(response.
getOutputStream());
JPEGEncodeParam param = encoder.getDefaultJPEGEncodeParam(bi);
param.setQuality(1.0f, false);
encoder.setJPEGEncodeParam(param);
encoder.encode(bi);
}
catch (Exception ex) {

}
}
}
然后在需求显示验证码的加入以下代码就可以了
<img alt= " " src= "/WebModule1/servlet1 " width= "40 " height= "16 "/>


这是一个用来生成随机数的代码,不过我觉得你在数据库里面可以存图片的路径path然后直接src=path就可以了