jsf上传图片之图片预览、图片存储、图片获取

1、图片预览:

  图片上传预览是一种在图片上传之前对图片进行本地预览的技术。使用户选择图片后能立即查看图片,而不需上传服务器,提高用户体验。但随着浏览器安全性的提高,要实现图片上传预览也越来越困难。所以经常会出现上传的文件获得的路径是c:\fakepath\....,当然可以通过浏览器设置显示正确的文件路径,但是我们总不会期望用户在上传图片之前都设置下浏览器吧,而且用户不关心这些路径,只有开发人员才会关心。那么怎么实现图片上传时候的预览呢?这里有一个比较全的资料可以参考:javascript实现图片上传预览

  通过html5的文件API也可以实现图片预览功能。参考代码为:

jsf代码

<!--图片预览框-->

<div id="uploadimage">
<div id="preview">
<img id="imghead" width="200px" height="150px" border=0 src=''>
</div>

<t:inputFileUpload id="uploadfile" value="#{inputNewGoodsBean.upFile }"  
    required="true" οnchange="previewImage(this)" accept="image/*" storage="file">
    </t:inputFileUpload>

previewImage(this)实现了图片预览功能

//图片预览   
function previewImage(file)
{
  var MAXWIDTH  = 200;
  var MAXHEIGHT = 150;
  var div = document.getElementById('preview');//获得div
  if (file.files && file.files[0])
  {
  div.innerHTML = '<img id=imghead>';
  var img = document.getElementById('imghead');
  img.onload = function(){
   var rect = clacImgZoomParam(MAXWIDTH, MAXHEIGHT, img.offsetWidth, img.offsetHeight);
   img.width = rect.width;
   img.height = rect.height;
   img.style.marginLeft = rect.left+'px';
   img.style.marginTop = rect.top+'px';
  };
  var reader = new FileReader();
  reader.onload = function(evt){img.src = evt.target.result;};
  reader.readAsDataURL(file.files[0]);
  }
  else
  {
    var sFilter='filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale,src="';
    file.select();
    var src = document.selection.createRange().text;
    div.innerHTML = '<img id=imghead>';
    var img = document.getElementById('imghead');
    img.filters.item('DXImageTransform.Microsoft.AlphaImageLoader').src = src;
    var rect = clacImgZoomParam(MAXWIDTH, MAXHEIGHT, img.offsetWidth, img.offsetHeight);
    status =('rect:'+rect.top+','+rect.left+','+rect.width+','+rect.height);
    div.innerHTML = "<div id=divhead style='width:"+rect.width+"px;height:"+rect.height+"px;margin-top:"+rect.top+"px;margin-left:"+rect.left+"px;"+sFilter+src+"\"'></div>";
  }
}
function clacImgZoomParam( maxWidth, maxHeight, width, height ){
var param = {top:0, left:0, width:width, height:height};
if( width>maxWidth || height>maxHeight )
{
rateWidth = width / maxWidth;
rateHeight = height / maxHeight;

if( rateWidth > rateHeight )
{
param.width =  maxWidth;
param.height = Math.round(height / rateWidth);
}else
{
param.width = Math.round(width / rateHeight);
param.height = maxHeight;
}
}
param.left = Math.round((maxWidth - param.width) / 2);
param.top = Math.round((maxHeight - param.height) / 2);
return param;
}

以上代码尚未作出分析。但功能已经实现。日后再做分析

2、关于图片存储:

将图片放到哪里呢?以怎样的形式存储呢?

图片一般是上传到服务器,我的JBOSS装在F盘的某个文档下,那么可以把JBOSS安装目录当做服务器。那数据库中该放些什么,可以把文件放在数据库,那样做的前提是文件不大,不是很多,但是文件一多且总量大的话把文件存储在数据库就显得不是很合理了,这种情况我们可以把文件路径存放在数据库中。

  刚才提到文件是放在JBOSS安装目录下,那怎么获得JBOSS服务器路径呢?我在网上找到一段代码,是在backingbean中获得JBOSS服务器端路径:HttpSession session = (HttpSession) FacesContext.getCurrentInstance().getExternalContext().getSession(true);
String rootpath = session.getServletContext().getRealPath("GoodsPic");那个GoodsPic是我在JBOSS服务端获得的建的文件夹,用来存放图片,这段代码获得的rootpath是这样的 F:\J2EE\software\jboss-4.2.3.GA\server\default\.\tmp\deploy\tmp6596605204279877901MyiBuyWeb-exp.war\GoodsPic,上传图片时可以把这个结果当做上传路径。但是问题出现了,当你重新启动JBOSS时,或者重新部署时发现图片不翼而飞了,没了(TOMCAT据说不会出现这种问题)!这时发现将文件上传至服务器安装目录下行不通,那怎么办?这时就把自己的电脑当服务器呗,文件上传后可以放在其他磁盘中,那怎么和服务器关联上呢?JBOSS的虚拟路径帮助我解决了这个问题,目前感觉虚拟路径在文件获得时起了比较大的作用,至于还有什么大作用有待学习。

  JBOSS配置虚拟路径 参考网站:JBOSS5.0以前的版本和JBOSS5.0虚拟路径配置

我用的JBOSS是4.2.3的,所以配置比较简单,只要在server.xml的host结点下添加如下代码:

<Context docBase="D:\\images" path="/pamuk/img" crossContext="true" />这时JBOSS就可以通过/pamuk/img找到D:\images路径了

现在图片存储的问题解决那么就讨论第三点

3、文件的获取

以图片来说,假如要获取已经存入到磁盘中的图片,该怎么做呢,结合刚才的虚拟路径,可以通过下面的方式获得

比如<h:graphicImage url="http://localhost:8080/pamuk/img/yourpic"/>注意8080是JBOSS的端口号。

问题解决了


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
依赖的文件: tomahawk-1.1.3.jar commons-fileupload-1.2.jar commons-io-1.3.1.jar Tomahawk.tld 把这个三个包放在/WEB_INF/lib目录下面。Jsf依赖的包也放在这个目录下面 Tomahawk.tld放在/WEB-INF目录下。Jsf标签也放在这个目录下面。 这个主要讲jsf文件,因此只罗列了上文件用到的包和标签。 Web-xml文件如下: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <web-app> <context-param> <param-name>javax.faces.STATE_SAVING_METHOD</param-name> <param-value>client</param-value> </context-param> <!-- Context Listener creates and sets the application handler --> <!-- Faces Servlet --> <servlet> <servlet-name>Faces Servlet</servlet-name> <servlet-class>javax.faces.webapp.FacesServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <!-- Faces Servlet Mapping --> <servlet-mapping> <servlet-name>Faces Servlet</servlet-name> <url-pattern>*.jsf</url-pattern> </servlet-mapping> <filter> <filter-name>ExtensionsFilter</filter-name> <filter-class> org.apache.myfaces.component.html.util.ExtensionsFilter </filter-class> <init-param> <param-name>uploadMaxFileSize</param-name> <param-value>10m</param-value> </init-param> <init-param> <param-name>uploadThresholdSize</param-name> <param-value>100k</param-value> </init-param> </filter> <filter-mapping> <filter-name>ExtensionsFilter</filter-name> <!—要和<servlet-mapping>中的<servlet-name>一致--> <servlet-name>Faces Servlet</servlet-name> </filter-mapping> <welcome-file-list> <welcome-file>index.html</welcome-file> </welcome-file-list> </web-app> 上文件的页面如下: <%@ include file="tags.jsp"%> <f:view> <h:form id="MyForm" enctype="multipart/form-data" > <h:messages globalOnly="true" styleClass="message"/> <h:panelGrid columns="3" border="0" cellspacing="5"> <h:outputLabel for="myFileId" value="File: "/> <x:inputFileUpload id="myFileId" value="#{myBean.myFile}" storage="file" required="true"/> <h:message for="myFileId"/> <h:outputLabel for="myParamId" value="Param: "/> <h:selectOneMenu id="myParamId" value="#{myBean.myParam}" required="true"> <f:selectItem itemLabel="" itemValue=""/> <f:selectItem itemLabel="MD5" itemValue="MD5"/> <f:selectItem itemLabel="SHA-1" itemValue="SHA-1"/> <f:selectItem itemLabel="SHA-256" itemValue="SHA-256"/> <f:selectItem itemLabel="SHA-384" itemValue="SHA-384"/> <f:selectItem itemLabel="SHA-512" itemValue="SHA-512"/> </h:selectOneMenu> <h:message for="myParamId"/> <h:outputText value=" "/> <h:commandButton value="Submit" action="#{myBean.processMyFile}"/> <h:outputText value=" "/> </h:panelGrid> </h:form> </f:view> 其中tags.jsp文件如下: <%@ page language="java" pageEncoding="GB18030"%> <%@ page contentType="text/html" %> <%@ taglib uri="http://java.sun.com/jsf/html" prefix="h" %> <%@ taglib uri="http://java.sun.com/jsf/core" prefix="f" %> <%@ taglib uri="http://java.sun.com/jstl/core" prefix="c" %> <%@ taglib uri="http://myfaces.apache.org/tomahawk" prefix="x"%> Faces-config.xml文件如下: <faces-config> <managed-bean> <managed-bean-name>myBean</managed-bean-name> <managed-bean-class> fileupload.MyBean </managed-bean-class> <managed-bean-scope>request</managed-bean-scope> </managed-bean> </faces-config> MyBean如下: package com.dhc; import java.io.BufferedInputStream; import java.io.FileOutputStream; import java.io.InputStream; import javax.faces.application.FacesMessage; import javax.faces.context.FacesContext; import org.apache.myfaces.custom.fileupload.UploadedFile; public class oaMailMainForm { private UploadedFile myFile; public UploadedFile getMyFile() { return myFile; } public void setMyFile(UploadedFile myFile) { this.myFile = myFile; } public String uploadedfile() { System.out.println("Entry"); try { InputStream in = new BufferedInputStream(myFile.getInputStream()); try { byte[] buffer = new byte[64 * 1024]; FileOutputStream fileOutputStream = new FileOutputStream( "C:\\My Files\\tst.jpg");// 这里可以把上的文件写服务器目录,或者数据库中 while (in.read(buffer) > 0) { fileOutputStream.write(buffer); } } finally { in.close(); } System.out.println("End"); return "success"; } catch (Exception x) { System.out.print("Exception"); FacesMessage message = new FacesMessage( FacesMessage.SEVERITY_FATAL, x.getClass().getName(), x .getMessage()); FacesContext.getCurrentInstance().addMessage(null, message); return null; } } } 参考文献:http://www.blogjava.net/cooky/archive/2007/10/02/150176.html http://blog.csdn.net/meteorlWJ/archive/2008/01/09/2032505.aspx http://tml808.javaeye.com/blog/166853

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值