JSP学习笔记(七十七):Spring中使用JdbcTemplate访问图片

1.往数据库插入图片

 

数据库操作:

    public void setImgByte(final byte[] bytes, final int id) {
this.getJdbcTemplate().execute(
"update tbcaseadjust set content=? where id=?",
new PreparedStatementCallback() {

public Object doInPreparedStatement(PreparedStatement ps)
throws SQLException, DataAccessException {
ps.setBytes(
1, bytes);
ps.setInt(
2, id);
ps.execute();
return null;
}
});
}

前台代码:

我使用的是struts2的上传,使用struts2的上传需要commons-fileupload.1.x.jar,commons-io-1.x.jar包

这两个包下载地址:http://commons.apache.org/

UploadPage.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding
="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title></title>
</head>
<body>
<s:form enctype="multipart/form-data" theme="simple" method="post">
<s:file name="upload"></s:file>
<s:submit value="submit"></s:submit>
</s:form>
</body>
</html>

对应的Action类UploadPageAction.java

public class UploadAction extends ActionSupport {

private File upload;
private String uploadContentType;
private String uploadFileName;

@Override
public String execute() throws Exception {
if(uploadContentType!=null)
{
setImgByte(FileUtils.readFileToByteArray(upload),1
);
}
return SUCCESS;
}
public File getUpload() {
return upload;
}
public void setUpload(File upload) {
this.upload = upload;
}
public String getUploadContentType() {
return uploadContentType;
}
public void setUploadContentType(String uploadContentType) {
this.uploadContentType = uploadContentType;
}
public String getUploadFileName() {
return uploadFileName;
}
public void setUploadFileName(String uploadFileName) {
this.uploadFileName = uploadFileName;
}

 

2.从数据库取图片

数据库操作:

    public Object getImgByte(final int id) {
return this.getJdbcTemplate().execute(
"select content from tbcaseadjust where id=?",
new PreparedStatementCallback() {

public Object doInPreparedStatement(PreparedStatement ps)
throws SQLException, DataAccessException {
ps.setInt(
1, id);
ResultSet rs
= ps.executeQuery();
if (rs.next()) {
InputStream inputStream
= rs
.getBinaryStream(
"content");
try {
return IOUtils.toByteArray(inputStream);
}
catch (IOException e) {
}
}
return null;
}
});
}

前台代码:

public class UpLoadImgAction extends ActionSupport{
private InputStream inputStream;
public InputStream getInputStream() {
return inputStream;
}
public void setInputStream(InputStream inputStream) {
this.inputStream = inputStream;
}
@Override
public String execute() throws Exception {
Object[] args
=new Object[]{1};
byte[] bytes =(byte[])getImgByte(args);
inputStream
= new ByteArrayInputStream(bytes);
return "image";
}
}

返回的image类型需要在struts配置文件里配置一下:

            <result name="image" type="stream">
<param name="contentType">
application/octet-stream
</param>
<param name="inputName">inputStream</param>
<param name="bufferSize">1024</param>
</result>

 

写的很乱,将就着看吧:(

转载于:https://www.cnblogs.com/modou/articles/1326666.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值