上传图片并保存到数据库
来源:互联网 发布:淘宝关闭店铺 编辑:程序博客网 时间:2024/04/27 23:38
上传图片并保存到数据库
seam给我们提供了 s:fileUpload 标签以完成文件上传功能.使用该标签时,要在web.xml中声明一个Seam的过滤器:
- <filter>
- <filter-name>Seam Filter</filter-name>
- <filter-class>org.jboss.seam.servlet.SeamFilter</filter-class>
- </filter>
- <filter-mapping>
- <filter-name>Seam Filter</filter-name>
- <url-pattern>/*</url-pattern>
- </filter-mapping>
s:fileUpload 标签主要属性:
- data: 需绑定一个byte[] 数组,用来接收上传的二进制数据.
- fileName: 上传文件的文件名
- accept: 允许上传的文件类型,可取 "images/png", "images/jpg".
用法示例:
- <h:form enctype="multipart/form-data" id="upload-form">
- <s:fileUpload data="#{memberHome.instance.avator}" fileName="#{memberHome.fileName}" />
- <h:commandButton value="上传照片" action="#{memberHome.update()}"
- styleClass="btn btn-primary btn-small">
- </h:commandButton>
- </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查询方法如下:
- private DataSource getDS() throws NamingException {
- Context context = new InitialContext();
- return (DataSource) context.lookup("zhiduiDatasource");
- }
lookup()中要传递你要查询的对象的名称,即在persistence.xml中<jta-data-source>节点所声明的数据源.有关JNDI的详细说明,参见Oracle官方指南:http://docs.oracle.com/javase/7/docs/technotes/guides/jndi/
之后就可以从数据库中读出图片数据了:
- private void getImageByte() {
- DataSource ds = null;
- Connection conn = null;
- try {
- ds = getDS();
- conn = ds.getConnection();
- Statement stat = conn.createStatement();
- ResultSet res = stat.executeQuery("select * from member where id='" + memberId + "'");
- while(res.next()) {
- imageByte = res.getBytes("avator_file");
- }
- } catch(SQLException ex) {
- ex.printStackTrace();
- } catch(NamingException ex) {
- ex.printStackTrace();
- } finally {
- try {
- conn.close();
- } catch(SQLException ex) {
- ex.printStackTrace();
- }
- }
- }
最后在doGet()方法中将读出的byte[]数据返回:
- @Override
- protected void doGet(HttpServletRequest req, HttpServletResponse resp)
- throws ServletException, IOException {
- String parm = req.getParameter("memberId");
- memberId = Integer.parseInt(parm);
- getImageByte();
- resp.getOutputStream().write(imageByte, 0, imageByte.length);
- }
别忘了在web.xml中声明你的ImageServer并配置URL映射:
- <servlet>
- <servlet-name>Image Servlet</servlet-name>
- <servlet-class>cn.edu.sudt.zhidui.servlet.ImageServlet</servlet-class>
- </servlet>
- <servlet-mapping>
- <servlet-name>Image Servlet</servlet-name>
- <url-pattern>*.showimg</url-pattern>
- </servlet-mapping>
这时使用<img>标签就能成功地将图片显示到页面中了.
- <img src="asd.showimg?memberId=#{memberHome.instance.id}" />
0 0
- 上传图片并保存到数据库
- spring上传图片并保存到数据库
- 图片上传并保存到数据库以及显示图片
- 上传图片到数据库并保存成Image格式
- php上传图片的代码并保存到数据库
- php上传图片的代码并保存到数据库
- php上传图片的代码并保存到数据库
- angularjs上传图片并转换成base64保存到数据库
- ASP.NET利用.FileUpload上传图片并将图片名称保存到数据库
- 把图片上传保存到数据库
- 上传图片保存到MySql数据库
- php 上传图片保存到数据库例子
- php 上传图片保存到数据库例子
- php 上传图片保存到数据库例子
- 用Seam实现:图片上传 + 保存到数据库 + 从数据库读出图片并显示到页面中
- 用Seam实现:图片上传 + 保存到数据库 + 从数据库读出图片并显示到页面中
- vb 图片分割并保存到数据库
- 图片生成缩略图并保存到数据库
- 红黑树插入算法的实现
- VMWare虚拟机中CentOS安装gcc与g++
- Ubuntu下修改DNS重启也能用的方法
- 求助C#程序报错解决方案
- hibernate4.3中的load方法在web项目中的java.lang.ClassCastException:错误,
- 上传图片并保存到数据库
- Android incorrect AVA format
- 学习 javascript 模板引擎开发
- 对排列组合的理解
- 自动在/dev/下创建设备文件
- casperJs爬虫程序[1]
- VS2010开发 使用线程的环境设置
- 第一章 开篇
- Ubuntu Apache 虚拟主机 反向代理