溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

java開發(fā)中spring webflow怎么實現(xiàn)上傳單個文件及多個文件功能

發(fā)布時間:2022-05-11 11:04:50 來源:億速云 閱讀:132 作者:iii 欄目:大數(shù)據(jù)

本文小編為大家詳細介紹“java開發(fā)中spring webflow怎么實現(xiàn)上傳單個文件及多個文件功能”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當(dāng),希望這篇“java開發(fā)中spring webflow怎么實現(xiàn)上傳單個文件及多個文件功能”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

上傳單個文件

準(zhǔn)備

1. 如果你項目中使用了spring security的話,參考上一篇文章,使用上篇的第二種方法,并去掉MultipartFilter(如果有配置的話),否則得不到文件

2. 流程中的變量(如用var標(biāo)簽定義的變量),都需要實現(xiàn)Serializable接口。

實現(xiàn)過程

在pom.xml文件中加入下列依賴:

<!-- 支持文件上傳 -->
  <dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.2.1</version>
  </dependency>
  <dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.4</version>
  </dependency>

在spring-servlet.xml(Spring MVC的配置文件)中加入文件上傳解析器:

<!-- 文件上傳解析器-->
   <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <!-- one of the properties available; the maximum file size in bytes -->
    <property name="maxUploadSize" value="10485760"/>
  </bean>

實體類,記住要實現(xiàn)Serializable接口,屬性類型是MultipartFile:

@Component
public class GoodsEntity implements Serializable{
  private static final long serialVersionUID = 1L;
  private MultipartFile images;
  public MultipartFile getImages() {
    return images;
  }
  public void setImages(MultipartFile images) {
    this.images = images;
  }
}

流程定義代碼,沒什么特別的:

<?xml version="1.0" encoding="UTF-8"?>
<flow xmlns="http://www.springframework.org/schema/webflow"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://www.springframework.org/schema/webflow
   http://www.springframework.org/schema/webflow/spring-webflow-2.0.xsd">
     <var name="goods" class="com.huanle.model.entity.GoodsEntity"/>
     <view-state id="viewfirst" view="/views/user/releasegoods/release_first.jsp" model="goods">
      <transition on="submit" to="viewsecond"></transition>
     </view-state>
     <view-state id="viewsecond" view="/views/user/releasegoods/second.jsp" model="goods">
      <transition on="submit" to="performReleaseGoodsAction"></transition>
     </view-state>
     <action-state id="performReleaseGoodsAction" >
       <evaluate expression="goodsService.save(goods)"></evaluate>
       <transition to="returntouserindex"></transition>
     </action-state>
     <end-state id="returntouserindex" view="/views/user/seller/index.jsp"></end-state>
     <global-transitions>
      <transition on="cancel" to="returntouserindex"></transition>
     </global-transitions>
</flow>

上傳表單代碼,無需特別配置:

<form:form action="${flowExecutionUrl}&_eventId=submit&${_csrf.parameterName}=${_csrf.token}" method="post" commandName="goods" enctype="multipart/form-data">
  <input type="hidden" name="_flowExecutionKey" value="${flowExecutionKey}"/>
 商品圖片:<form:input id="images" path="images" type="file" multiple="multiple" />
 <input type="submit" >
</form:form>

就這樣就可以了

上傳多個文件

上傳單個文件可在前面上傳單個文件基礎(chǔ)上稍作修改就可以實現(xiàn)了。

實現(xiàn)

首先,實體類要修改,使用List來存儲多個文件:

@Component
public class GoodsEntity implements Serializable{
  private static final long serialVersionUID = 1L;
  private List<MultipartFile> images;
  public List<MultipartFile> getImages() {
    return images;
  }
  public void setImages(List<MultipartFile> images) {
    this.images = images;
  }
}

上傳表單也要修改:

<form:form action="${flowExecutionUrl}&_eventId=submit&${_csrf.parameterName}=${_csrf.token}" method="post" commandName="goods" enctype="multipart/form-data">
  <input type="hidden" name="_flowExecutionKey" value="${flowExecutionKey}"/>
商品圖片:<form:input path="images" type="file" multiple="multiple"/>
<input type="submit" value="提交">
</form:form>

增加一個multiple="multiple"屬性即可。

讀到這里,這篇“java開發(fā)中spring webflow怎么實現(xiàn)上傳單個文件及多個文件功能”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI