jsf上传图片

总结下图片上传:所用的开发工具版本如下:jsf1.2+ejb3.0+jboss4.2.3

准备工作:导入有关三个文件传输的jar包:commons-io-1.3.2.jar  commons-fileupload-1.2.1.jar   tomahawk12-1.1.14.jar,注意此时不要添加myfaces-extension.jar包,否则会冲突。

在web.xml写好配置:在<web-app>添加一个filter结点:

 <filter>
<filter-name>extensionsFilter</filter-name>
<filter-class>org.apache.myfaces.webapp.filter.ExtensionsFilter</filter-class>
<init-param>
<description>Set the size limit for uploaded files.
Format: 10 - 10 bytes
10k - 10 KB
10m - 10 MB
1g - 1 GB</description>
<param-name>uploadMaxFileSize</param-name>
<param-value>10m</param-value>
</init-param>
<init-param>
<description>Set the threshold size - files
below this limit are stored in memory, files above
this limit are stored on disk.

Format: 10 - 10 bytes
10k - 10 KB
10m - 10 MB
1g - 1 GB</description>
<param-name>uploadThresholdSize</param-name>
<param-value>1k</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>extensionsFilter</filter-name>
<url-pattern>/faces/*</url-pattern>
</filter-mapping>


第一步:在jsp页面开始出导入标签:<%@ taglib prefix="t" uri="http://myfaces.apache.org/tomahawk" %>。

并在form表单设定enctype="multipart/form-data",因为上传文件必须设定mime的值为multipart/form-data。比如我的jsp页面是这样写的:<h:form id="inputnewgoods" enctype="multipart/form-data">.关于mime和enctype的选择可以参考:为什么上传文件的表单里要加个属性enctype

然后是表单里面写上上传文件的组建:<t:inputFileUpload id="uploadfile" value="#{backingbean.upFile }"  
    required="true" οnchange="previewImage(this)" storage="file">,关于t:inputFileUpload的其他属性及含义可以参考官网介绍t:inputFileUpload:http://myfaces.apache.org/tomahawk-project/tomahawk12/tagdoc/t_inputFileUpload.html 

注意上面的οnchange="previewImage(this)"中previewImage(this)是文件预览功能,用到了html5的文件API。

提交表单:<h:commandButton id="submitbutton" value="提交" action="#{backingbean.upload}"/>

第二步:建一个backing bean 我设置的backingbean的范围是session,网上有些博客说要设置成request,但是我的表单中还有级联菜单,实现级联菜单必须要用到session范围内的backingbean否则会出现异常。

代码大致如下:

......

import org.apache.myfaces.custom.fileupload.UploadedFile;

......

public class backingbean{

...

private UploadedFile upFile;

...

...

public UploadedFile getUpFile() {
return upFile;
}
public void setUpFile(UploadedFile upFile) {
this.upFile = upFile;
}

...

...

public String upload(){

 try {
           InputStream in = new BufferedInputStream(upFile.getInputStream());
           try {                
               byte[] buffer = new byte[(int)upFile.getSize()];                             
               //取得文件名
                        String name = upFile.getName();

                      //存路径
                String trace = "D:\\images\\" +name;//本地测试
    
               FileOutputStream fileOutputStream = 
                   new FileOutputStream(trace); //这里可以把上传的文件写服务器目录,或者数据库中 ,或者赋值给name用于文件名显示


               while (in.read(buffer) > 0) {
                   fileOutputStream.write(buffer);
               }
           } catch (Exception x) {
               System.out.print("出错啦!!!");
               FacesMessage message = 
                   new FacesMessage(FacesMessage.SEVERITY_FATAL, 
                                    x.getClass().getName(), x.getMessage());
               FacesContext.getCurrentInstance().addMessage(null, message);                
           }
           finally {
               in.close();
               FacesContext facesContext = FacesContext.getCurrentInstance();
               facesContext.getExternalContext().getApplicationMap().put("fileupload_bytes",                                                                          upFile.getBytes());
               facesContext.getExternalContext().getApplicationMap().put("fileupload_type", 
                                                                        upFile.getContentType());
           }
           System.out.println("End");


       } catch (Exception x) {
        System.out.print("出错啦!!!22222");
           FacesMessage message = 
               new FacesMessage(FacesMessage.SEVERITY_FATAL, 
                                x.getClass().getName(), x.getMessage());
           FacesContext.getCurrentInstance().addMessage(null, message);
       }

              return null;

}

}

最后注意在face-config里面设置这个backingbean。


  • 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、付费专栏及课程。

余额充值