欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關于Struts2文件上傳與自定義攔截器

 更新時間:2013年04月11日 16:28:31   作者:  
本篇文章,小編將為大家介紹關于Struts2文件上傳與自定義攔截器,有需要的朋友可以參考一下

一、訪問或添加request/session/application屬性

public String scope() throws Exception{
   ActionContext ctx = ActionContext.getContext();
   ctx.getApplication().put("app", "應用范圍");//往ServletContext里放入app
   ctx.getSession().put("ses", "session范圍");//往session里放入ses
   ctx.put("req", "request范圍");//往request里放入req
   return "scope";
}
JSP:
 <body>
    ${applicationScope.app} <br>
    ${sessionScope.ses}<br>
    ${requestScope.req}<br>
 </body>

二、獲取HttpServletRequest / HttpSession / ServletContext / HttpServletResponse對象

方法一,通過ServletActionContext.類直接獲?。?BR>public String rsa() throws Exception{
 HttpServletRequest request = ServletActionContext.getRequest();
 ServletContext servletContext = ServletActionContext.getServletContext();
 request.getSession() 
 HttpServletResponse response = ServletActionContext.getResponse();
 return "scope";
}
方法二,實現(xiàn)指定接口,由struts框架運行時注入:
public class HelloWorldAction implements ServletRequestAware, ServletResponseAware, ServletContextAware{
 private HttpServletRequest request;
 private ServletContext servletContext;
 private HttpServletResponse response;
 public void setServletRequest(HttpServletRequest req) {
  this.request=req;
 }
 public void setServletResponse(HttpServletResponse res) {
  this.response=res;
 }
 public void setServletContext(ServletContext ser) {
  this.servletContext=ser;
 }
}

三、文件上傳

第一步:在WEB-INF/lib下加入commons-fileupload-1.2.1.jar、commons-io-1.3.2.jar。這兩個文件可以從http://commons.apache.org/下載。

第二步:把form表的enctype設置為:“multipart/form-data“,如下:
<form enctype="multipart/form-data" action="${pageContext.request.contextPath}/xxx.action" method="post">
  <input  type="file" name="uploadImage">
</form>

第三步:在Action類中添加以下屬性,屬性紅色部分對應于表單中文件字段的名稱:

public class HelloWorldAction{
  private File uploadImage;//得到上傳的文件
  private String uploadImageContentType;//得到文件的類型
  private String uploadImageFileName;//得到文件的名稱
  //這里略省了屬性的getter/setter方法
  public String upload() throws Exception{
 String realpath = ServletActionContext.getServletContext().getRealPath("/images");
 File file = new File(realpath);
 if(!file.exists()) file.mkdirs();
 FileUtils.copyFile(uploadImage, new File(file, uploadImageFileName));
 return "success";
  }
}

四、多文件上傳

第一步:在WEB-INF/lib下加入commons-fileupload-1.2.1.jar、commons-io-1.3.2.jar。這兩個文件可以從http://commons.apache.org/下載。

第二步:把form表的enctype設置為:“multipart/form-data“,如下:
<form enctype="multipart/form-data" action="${pageContext.request.contextPath}/xxx.action" method="post">
  <input  type="file" name="uploadImages">
  <input  type="file" name="uploadImages">
</form>

第三步:在Action類中添加以下屬性,屬性紅色部分對應于表單中文件字段的名稱:
public class HelloWorldAction{
  private File[] uploadImages;//得到上傳的文件
  private String[] uploadImagesContentType;//得到文件的類型
  private String[] uploadImagesFileName;//得到文件的名稱
  //這里略省了屬性的getter/setter方法
  public String upload() throws Exception{
 String realpath = ServletActionContext.getServletContext().getRealPath("/images");
 File file = new File(realpath);
 if(!file.exists()) file.mkdirs();
 for(int i=0 ;i<uploadImages.length; i++){ File uploadImage = uploadImages[i];
    FileUtils.copyFile(uploadImage, new File(file, uploadImagesFileName[i]));
}
 return "success";
  }}

五、自定義攔截器

要自定義攔截器需要實現(xiàn)com.opensymphony.xwork2.interceptor.Interceptor接口:
public class PermissionInterceptor implements Interceptor {
   private static final long serialVersionUID = -5178310397732210602L;
   public void destroy() {
   }
   public void init() {
   }
   public String intercept(ActionInvocation invocation) throws Exception {
  System.out.println("進入攔截器");
 if(session里存在用戶){
  String result = invocation.invoke();
 }else{
  return “l(fā)ogon”;
 }
 //System.out.println("返回值:"+ result);
 //return result;
    }
}
<package name="csdn" namespace="/test" extends="struts-default">
 <interceptors>
           <interceptor name=“permission" class="cn.csdn.aop.PermissionInterceptor" />
           <interceptor-stack name="permissionStack">
    <interceptor-ref name="defaultStack" />
   <interceptor-ref name=" permission " />
            </interceptor-stack>
  </interceptors>
 <action name="helloworld_*" class="cn.csdn.action.HelloWorldAction" method="{1}">
  <result name="success">/WEB-INF/page/hello.jsp</result>
  <interceptor-ref name="permissionStack"/>
 </action>
</package>

因為struts2中如文件上傳,數(shù)據(jù)驗證,封裝請求參數(shù)到action等功能都是由系統(tǒng)默認的defaultStack中的攔截器實現(xiàn)的,所以我們定義的攔截器需要引用系統(tǒng)默認的defaultStack,這樣應用才可以使用struts2框架提供的眾多功能。

如果希望包下的所有action都使用自定義的攔截器,可以通過<default-interceptor-ref name=“permissionStack”/>把攔截器定義為默認攔截器。注意:每個包只能指定一個默認攔截器。另外,一旦我們?yōu)樵摪械哪硞€action顯式指定了某個攔截器,則默認攔截器不會起作用。

六、輸入校驗

在struts2中,我們可以實現(xiàn)對action的所有方法進行校驗或者對action的指定方法進行校驗。
對于輸入校驗struts2提供了兩種實現(xiàn)方法:
1. 采用手工編寫代碼實現(xiàn)。
2. 基于XML配置方式實現(xiàn)。

七、手工編寫代碼實現(xiàn)對action中所有方法輸入校驗

通過重寫validate() 方法實現(xiàn), validate()方法會校驗action中所有與execute方法簽名相同的方法。當某個數(shù)據(jù)校驗失敗時,我們應該調用addFieldError()方法往系統(tǒng)的fieldErrors添加校驗失敗信息(為了使用addFieldError()方法,action可以繼承ActionSupport ),如果系統(tǒng)的fieldErrors包含失敗信息,struts2會將請求轉發(fā)到名為input的result。在input視圖中可以通過<s:fielderror/>顯示失敗信息。
validate()使用例子:
public void validate() {
       if(this.mobile==null || "".equals(this.mobile.trim())){  this.addFieldError("username", "手機號不能為空");
        }else{  if(!Pattern.compile("^1[358]\\d{9}").matcher(this.mobile.trim()).matches()){
  this.addFieldError(“mobile", "手機號的格式不正確"); }
       }
}

驗證失敗后,請求轉發(fā)至input視圖:

<result name="input">/WEB-INF/page/addUser.jsp</result>
在addUser.jsp頁面中使用<s:fielderror/>顯示失敗信息。
通過validateXxx()方法實現(xiàn), validateXxx()只會校驗action中方法名為Xxx的方法。其中Xxx的第一個字母要大寫。當某個數(shù)據(jù)校驗失敗時,我們應該調用addFieldError()方法往系統(tǒng)的fieldErrors添加校驗失敗信息(為了使用addFieldError()方法,action可以繼承ActionSupport ),如果系統(tǒng)的fieldErrors包含失敗信息,struts2會將請求轉發(fā)到名為input的result。在input視圖中可以通過<s:fielderror/>顯示失敗信息。

validateXxx()方法使用例子:
public String add() throws Exception{  return "success";}
public void validateAdd(){
          if(username==null && "".equals(username.trim()))  this.addFieldError("username", "用戶名不能為空");
}

驗證失敗后,請求轉發(fā)至input視圖:

<result name="input">/WEB-INF/page/addUser.jsp</result>
在addUser.jsp頁面中使用<s:fielderror/>顯示失敗信息。

八、輸入校驗的流程

1、類型轉換器對請求參數(shù)執(zhí)行類型轉換,并把轉換后的值賦給action中的屬性。
2、如果在執(zhí)行類型轉換的過程中出現(xiàn)異常,系統(tǒng)會將異常信息保存到ActionContext,conversionError攔截器將異常信息添加到fieldErrors里。不管類型轉換是否出現(xiàn)異常,都會進入第3步。
3、系統(tǒng)通過反射技術先調用action中的validateXxx()方法,Xxx為方法名。
4、再調用action中的validate()方法。
5、經過上面4步,如果系統(tǒng)中的fieldErrors存在錯誤信息(即存放錯誤信息的集合的size大于0),系統(tǒng)自動將請求轉發(fā)至名稱為input的視圖。如果系統(tǒng)中的fieldErrors沒有任何錯誤信息,系統(tǒng)將執(zhí)行action中的處理方法。

九、基于XML配置方式實現(xiàn)對action的所有方法進行輸入校驗

使用基于XML配置方式實現(xiàn)輸入校驗時,Action也需要繼承ActionSupport,并且提供校驗文件,校驗文件和action類放在同一個包下,文件的取名格式為:ActionClassName-validation.xml,其中ActionClassName為action的簡單類名,-validation為固定寫法。如果Action類為cn.csdn.UserAction,那么該文件的取名應為:UserAction-validation.xml。下面是校驗文件的模版:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.3//EN" "http://www.opensymphony.com/xwork/xwork-validator-1.0.3.dtd">

<validators>
    <field name="username">
        <field-validator type="requiredstring">
            <param name="trim">true</param>
            <message>用戶名不能為空!</message>
        </field-validator>
    </field>
</validators>

<field>指定action中要校驗的屬性,<field-validator>指定校驗器,上面指定的校驗器requiredstring是由系統(tǒng)提供的,系統(tǒng)提供了能滿足大部分驗證需求的校驗器,這些校驗器的定義可以在xwork-2.x.jar中的com.opensymphony.xwork2.validator.validators下的default.xml中找到。
<message>為校驗失敗后的提示信息,如果需要國際化,可以為message指定key屬性,key的值為資源文件中的key。
在這個校驗文件中,對action中字符串類型的username屬性進行驗證,首先要求調用trim()方法去掉空格,然后判斷用戶名是否為空。
編寫校驗文件時,不能出現(xiàn)幫助信息
在編寫ActionClassName-validation.xml校驗文件時,如果出現(xiàn)不了幫助信息,可以按下面方式解決:
windwos->preferences->myeclipse->files and editors->xml->xmlcatalog
點“add”,在出現(xiàn)的窗口中的location中選“File system”,然后在xwork-2.1.2解壓目錄的src\java目錄中選擇xwork-validator-1.0.3.dtd,回到設置窗口的時候不要急著關閉窗口,應把窗口中的Key Type改為URI 。Key改為http://www.opensymphony.com/xwork/xwork-validator-1.0.3.dtd

相關文章

  • 解析Tars-Java客戶端源碼

    解析Tars-Java客戶端源碼

    Tars是基于名字服務使用Tars協(xié)議的高性能RPC開發(fā)框架,同時配套一體化的服務治理平臺,幫助個人或者企業(yè)快速的以微服務的方式構建自己穩(wěn)定可靠的分布式應用
    2021-06-06
  • jvm垃圾回收算法詳細解析

    jvm垃圾回收算法詳細解析

    這篇文章主要介紹了jvm垃圾回收算法詳細解析,JVM有一套完整的垃圾回收算法,可以對程序運行時產生的垃圾對象進行及時的回收,以便釋放JVM相應區(qū)域的內存空間,確保程序穩(wěn)定高效的運行,但在真正了解垃圾回收算法之前,有必要對JVM的對象的引用做一個簡單的鋪墊
    2022-07-07
  • SpringCloud Finchley+Spring Boot 2.0 集成Consul的方法示例(1.2版本)

    SpringCloud Finchley+Spring Boot 2.0 集成Consul的方法示例(1.2版本)

    這篇文章主要介紹了SpringCloud Finchley+Spring Boot 2.0 集成Consul的方法示例(1.2版本),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • Spring MVC 關于controller的字符編碼問題

    Spring MVC 關于controller的字符編碼問題

    在使用springMVC框架構建web應用,客戶端常會請求字符串、整型、json等格式的數(shù)據(jù),通常使用@ResponseBody注解使 controller回應相應的數(shù)據(jù)而不是去渲染某個頁面。
    2017-03-03
  • java并發(fā)編程之深入理解Synchronized的使用

    java并發(fā)編程之深入理解Synchronized的使用

    文詳細講述了線程、進程的關系及在操作系統(tǒng)中的表現(xiàn),這是多線程學習必須了解的基礎。本文將接著講一下Java線程同步中的一個重要的概念synchronized,希望能夠給你有所幫助
    2021-06-06
  • Java中的HashMap集合深度解析

    Java中的HashMap集合深度解析

    這篇文章主要介紹了Java中的HashMap集合深度解析, HashMap可以說是Java中最常用的集合類框架之一,是Java語言中非常典型的數(shù)據(jù)結構,我們總會在不經意間用到它,很大程度上方便了我們日常開發(fā),需要的朋友可以參考下
    2023-09-09
  • java實現(xiàn)超大文件的讀寫功能

    java實現(xiàn)超大文件的讀寫功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)超大文件的讀寫功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • spring集成httpclient配置的詳細過程

    spring集成httpclient配置的詳細過程

    spring框架是一個非常強大的框架這里就不多說了,那么主要是介紹spring與httpclient的整合集成過程,感興趣的朋友跟隨小編一起看看吧
    2021-07-07
  • Java如何利用return結束方法調用

    Java如何利用return結束方法調用

    這篇文章主要介紹了Java如何利用return結束方法調用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02
  • Java之Jackson使用案例詳解

    Java之Jackson使用案例詳解

    這篇文章主要介紹了Java之Jackson使用案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-07-07

最新評論