上传图片并保存到数据库

上传图片并保存到数据库

seam给我们提供了 s:fileUpload 标签以完成文件上传功能.使用该标签时,要在web.xml中声明一个Seam的过滤器:
[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. <filter>  
  2.   <filter-name>Seam Filter</filter-name>  
  3.   <filter-class>org.jboss.seam.servlet.SeamFilter</filter-class>  
  4. </filter>  
  5.   
  6. <filter-mapping>  
  7.   <filter-name>Seam Filter</filter-name>  
  8.   <url-pattern>/*</url-pattern>  
  9. </filter-mapping>  

s:fileUpload 标签主要属性:
  • data: 需绑定一个byte[] 数组,用来接收上传的二进制数据.
  • fileName: 上传文件的文件名
  • accept: 允许上传的文件类型,可取 "images/png", "images/jpg".
用法示例:
[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. <h:form enctype="multipart/form-data" id="upload-form">  
  2.                                 <s:fileUpload data="#{memberHome.instance.avator}" fileName="#{memberHome.fileName}" />  
  3.                                 <h:commandButton value="上传照片" action="#{memberHome.update()}"  
  4.                                     styleClass="btn btn-primary btn-small">  
  5.                                 </h:commandButton>  
  6.                             </h:form>  

这里 avator 是一个byte[]数组,fileName是一个String对象. 注意必须在form中使用 "multipart/form-data" 的编码类型.
当用户选择好图片,点击"上传照片"后,图片数据会首先被保存到Member实体Bean中的avator属性中,随后memberHome的update()方法被调用,JPA会把avator中的数据持久化到数据库中.

从数据库中读出图片并在页面中显示

要显示图片,可以使用<img>标签.但由于图片是保存在数据库中的,所以无法用将img的src属性设置为图片路径的方式来显示图片.这时候我们可以使用Servlet来完成这一功能.即将src指向一个Servlet,由这个Servlet负责把图片从数据库中取出并返回.

要在Servlet中访问数据数,可以先通过JNDI查询返回一个DataSource(数据源),通过DataSource的getConnection()方法来建立与数据库的连接,即使用JDBC访问数据库.
JNDI查询方法如下:
[java]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. private DataSource getDS() throws NamingException {  
  2.         Context context = new InitialContext();  
  3.         return (DataSource) context.lookup("zhiduiDatasource");  
  4.     }  

lookup()中要传递你要查询的对象的名称,即在persistence.xml中<jta-data-source>节点所声明的数据源.有关JNDI的详细说明,参见Oracle官方指南: http://docs.oracle.com/javase/7/docs/technotes/guides/jndi/

之后就可以从数据库中读出图片数据了:
[java]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. private void getImageByte() {  
  2.         DataSource ds = null;  
  3.         Connection conn = null;  
  4.           
  5.         try {  
  6.             ds = getDS();  
  7.             conn = ds.getConnection();  
  8.             Statement stat = conn.createStatement();  
  9.             ResultSet res = stat.executeQuery("select * from member where id='" + memberId + "'");  
  10.               
  11.             while(res.next()) {  
  12.                 imageByte = res.getBytes("avator_file");  
  13.             }  
  14.   
  15.         } catch(SQLException ex) {  
  16.             ex.printStackTrace();  
  17.         } catch(NamingException ex) {  
  18.             ex.printStackTrace();  
  19.         } finally {  
  20.             try {  
  21.                 conn.close();  
  22.             } catch(SQLException ex) {  
  23.                 ex.printStackTrace();  
  24.             }  
  25.         }  
  26.   
  27.     }  

最后在doGet()方法中将读出的byte[]数据返回:
[java]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. @Override  
  2.     protected void doGet(HttpServletRequest req, HttpServletResponse resp)  
  3.             throws ServletException, IOException {  
  4.         String parm = req.getParameter("memberId");  
  5.         memberId = Integer.parseInt(parm);  
  6.           
  7.         getImageByte();       
  8.         resp.getOutputStream().write(imageByte, 0, imageByte.length);  
  9.     }  

别忘了在web.xml中声明你的ImageServer并配置URL映射:
[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. <servlet>  
  2.         <servlet-name>Image Servlet</servlet-name>  
  3.         <servlet-class>cn.edu.sudt.zhidui.servlet.ImageServlet</servlet-class>  
  4.     </servlet>  
  5.       
  6.     <servlet-mapping>  
  7.         <servlet-name>Image Servlet</servlet-name>  
  8.         <url-pattern>*.showimg</url-pattern>  
  9.     </servlet-mapping>  

这时使用<img>标签就能成功地将图片显示到页面中了.
[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. <img src="asd.showimg?memberId=#{memberHome.instance.id}" />  

### 回答1: SSM是指Spring+SpringMVC+Mybatis的开发框架,下面以这个开发框架为基础介绍如何实现图片上传保存数据库。 首先,需要在SpringMVC中配置文件上传的解析器。在SpringMVC的配置文件中添加以下代码: ```xml <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="52428800"/> <!-- 设置最大上传大小为50MB --> </bean> ``` 然后,在前端页面中添加一个文件选择的表单项: ```html <form action="uploadImage" method="post" enctype="multipart/form-data"> <input type="file" name="image"/> <input type="submit" value="上传图片"/> </form> ``` 接下来,在SpringMVC的控制器中添加对应的请求处理方法: ```java @RequestMapping(value = "/uploadImage", method = RequestMethod.POST) public String uploadImage(@RequestParam("image") MultipartFile file, Model model) { if (!file.isEmpty()) { try { // 保存图片到服务器目录 String path = "/path/to/save/image"; // 指定保存的路径 String filename = file.getOriginalFilename(); File savedFile = new File(path, filename); file.transferTo(savedFile); // 将图片信息保存数据库 ImageEntity imageEntity = new ImageEntity(); imageEntity.setFilename(filename); imageEntity.setPath(path); imageService.saveImage(imageEntity); // 返回成功信息 model.addAttribute("message", "图片上传成功"); } catch (IOException e) { // 返回错误信息 model.addAttribute("message", "图片上传失败"); } } else { // 返回错误信息 model.addAttribute("message", "图片不能为空"); } return "upload_result"; // 返回结果页面 } ``` 最后,在Mybatis的Mapper文件中编写相应的SQL语句,实现将图片信息保存数据库中。 以上就是使用SSM实现图片上传保存数据库的简单示例。需要注意的是,保存图片的路径需要根据实际情况进行配置,且要确保服务器目录有写入权限。 ### 回答2: 在SSM框架中上传图片保存数据库,需要进行以下步骤: 1. 在前端页面中使用HTML的表单元素,添加一个文件选择框(type="file")用于选择要上传图片文件,设置一个提交按钮(type="submit")来触发文件上传操作。 2. 在后端的Controller类中,使用@RequestParam注解获取前端页面提交的图片文件,将其保存到服务器的临时文件夹中。 3. 创建一个Service类来处理上传图片文件,将其保存数据库中。首先,需要定义一个Model类来映射数据库中的表结构,包括一个字段来存储图片的二进制数据。同时,在Model类中添加一个字段来保存图片的文件名。然后,在Service类中,通过读取临时文件夹中的图片文件,将其转换为字节数组,保存到Model类中的二进制字段中,同时保存图片的文件名到Model类中的文件名字段中。 4. 调用DAO层的方法将保存图片二进制数据和文件名的Model类对象插入到数据库中。 5. 完成保存操作后,可以选择将临时文件夹中的图片文件删除,以节省磁盘空间。 综上所述,通过以上步骤,在SSM框架中实现了图片上传保存数据库的功能。 ### 回答3: 实现使用SSM框架上传图片保存数据库的步骤如下: 1. 前端页面部分: 在HTML表单中添加一个文件上传的输入框,用于用户选择要上传图片文件。设置form的enctype属性为"multipart/form-data",这样可以支持文件上传。 ```html <form method="post" action="/upload" enctype="multipart/form-data"> <input type="file" name="imageFile"> <input type="submit" value="上传"> </form> ``` 2. 控制器部分: 在后端的控制器中添加方法来处理图片上传的请求,上传图片保存数据库中。 ```java @RequestMapping(value = "/upload", method = RequestMethod.POST) public String uploadImage(@RequestParam("imageFile") MultipartFile imageFile) { // 判断文件不为空且为图片 if (!imageFile.isEmpty() && imageFile.getContentType().startsWith("image")) { try { // 将图片文件保存数据库中 byte[] imageBytes = imageFile.getBytes(); // 进行数据库保存操作,具体操作根据自己的数据库配置来实现 // ... return "上传成功"; } catch (IOException e) { e.printStackTrace(); } } return "上传失败"; } ``` 3. 配置文件部分: 在Spring的配置文件中添加MultipartResolver bean来支持文件上传。 ```xml <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="2097152"/> <!-- 设置文件上传大小限制,单位为字节 --> </bean> ``` 以上是使用SSM框架实现上传图片保存数据库的简单示例,具体代码实现需根据自己的业务需求进行更改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值