如果要存数据库的话,数据库存图片字段用blob形式的(照片:zp为例)。
而且不能直接存,在存之前zp字段先插入一个empty.BLOB(),
然后select ZP from 表 for update。再用输入流的形式写进去。
// 先检索出来字段,必须使用oracle的类:oracle.sql.BLOB
oracle.sql.BLOB blob = null;
if (rs.next())
{
blob = (oracle.sql.BLOB) rs.getBlob("ZP");
// 到数据库的输出流
OutputStream outStream = blob.getBinaryOutputStream();
// 将输入流写到输出流
byte[] b = new byte[blob.getBufferSize()];
int len = 0;
while ((len = is.read(b)) != -1)
{
outStream.write(b, 0, len);
// blob.putBytes(1,b);
}
is.close();
outStream.flush();
outStream.close();
}
以上的回答,回答得不是很全,所以我没看明白 要返回的图片类型呢,在页面展示的具体代表应该怎样写呢 求指导啊
这些代码都是需要在JSP中写的?
追答不是jsp, 是servlet
追问啊 ? 我只有JAVA类,SQLMAP和JSP啊 我是打算在JAVA里处理好了,到时候往页面展示的时候直接传个参数就OK啦,这样不能实现吗?
追答你就建个servlet呗, jsp输出二进制我还没试过, 要看看jsp的out对象有没有输出byte数组的方法了, 有的话应该没问题.
jsp的out是没有写二进制的方法的了, 看来只能用servlet, 建个servlet, 然后在web.xml配置一下路径就成了, servlet还不是java类?
那页面接收的时候怎样接收啊
追答敲个网址就接收了啊..跟jsp一样
追问不是不是那个意思啦 我的意思是如果用HttpServletResponse,那么接收的时候request.getAttribute("") 但是我不晓得这个参数名称到底是哪个
request.setCharacterEncoding("UTF-8");
response.setContentType("image/jpeg");
response.getOutputStream().write(bytes);
我是这样传过去的 在前台接收流的形式是怎样的 参数是什么