自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

在Struts框架下使用時(shí)間類(lèi)型

開(kāi)發(fā) 后端
本文向您介紹在Struts框架下使用時(shí)間類(lèi)型,同時(shí)講解Struts是怎么把form里的請(qǐng)求參數(shù)populate到ActionForm里。

使用時(shí)間類(lèi)型?這誰(shuí)不會(huì),不就是java.util下的幾個(gè)類(lèi)嗎,在不加上java.sql和java.text下的幾個(gè)類(lèi),這會(huì)有什么問(wèn)題嗎?Struts要是連時(shí)間類(lèi)型都處理不了,那還能干嘛?  在實(shí)際應(yīng)用中,我就發(fā)現(xiàn)Struts確實(shí)連有些簡(jiǎn)單的時(shí)間類(lèi)型都處理不了(不知是我使用的方法不對(duì)還是Struts確實(shí)沒(méi)有考慮到)。順便你也能了解Struts是怎么把form里的請(qǐng)求參數(shù)populate到ActionForm里面的。
  
今天下午同事告訴我把有java.util.Date類(lèi)型屬性的類(lèi)存入數(shù)據(jù)庫(kù)時(shí)出錯(cuò),把這個(gè)屬性刪除就沒(méi)有問(wèn)題了。當(dāng)時(shí)我就想到是RequestProcessor在processPopulate()時(shí)出錯(cuò)了,因此在它的這個(gè)方法設(shè)了斷點(diǎn)并跟蹤了進(jìn)去。當(dāng)然,它最先要調(diào)用ActionForm的reset()方法,然后調(diào)用實(shí)際處理populate(將請(qǐng)求參數(shù)傳給ActionForm)的RequestUtils.populate()方法。RequestUtils的這個(gè)靜態(tài)方法最先是處理Multipart的(即文件上傳等多部分)的方法,然后將所有的請(qǐng)求都放在叫properties的HashMap里并循環(huán)處理它:

  1. names = request.getParameterNames();  
  2.       while (names.hasMoreElements()) {  
  3.         String name = (String) names.nextElement();  
  4.         String stripped = name;  
  5.         if (prefix != null) {  
  6.           if (!stripped.startsWith(prefix)) {  
  7.             continue;  
  8.           }  
  9.           stripped = stripped.substring(prefix.length());  
  10.         }  
  11.         if (suffix != null) {  
  12.           if (!stripped.endsWith(suffix)) {  
  13.             continue;  
  14.           }  
  15.           stripped = stripped.substring(0, stripped.length() - suffix.length());  
  16.         }  
  17.         if (isMultipart) {  
  18.           properties.put(stripped, multipartParameters.get(name));  
  19.         } else {  
  20.           properties.put(stripped, request.getParameterValues(name));  
  21.         }  
  22.       }  

實(shí)際處理它們的是下面的:BeanUtils.populate(bean, properties); 其中bean就是接受數(shù)據(jù)的ActionForm,而properties里面則是所有的請(qǐng)求的鍵-值對(duì)(鍵和值都是字符串,http協(xié)議的特點(diǎn))。
  
再看看BeanUtils的靜態(tài)(類(lèi))方法populate是怎么處理的:

  1. // Loop through the property name/value pairs to be set  
  2.       Iterator names = properties.keySet().iterator();  
  3.       while (names.hasNext()) {  
  4.     
  5.         // Identify the property name and value(s) to be assigned  
  6.         String name = (String) names.next();  
  7.         if (name == null) {  
  8.           continue;  
  9.         }  
  10.         Object value = properties.get(name);  
  11.     
  12.         // Perform the assignment for this property  
  13.         setProperty(bean, name, value);  
  14.     
  15.       }  

它是循環(huán)所有的請(qǐng)求參數(shù),把實(shí)際的工作又交給了setProperty方法。呵呵,弄了半天,這幫人原來(lái)都是代理。
  
這個(gè)方法還是代理嗎?計(jì)算了一下它有180行的代碼。這么長(zhǎng)應(yīng)該是個(gè)實(shí)干家了吧,錯(cuò)!千萬(wàn)不要被有些人的外表欺騙了!有些人一天上班16個(gè)小時(shí),可夠敬業(yè)的,可有8小時(shí)在打CS。這個(gè)類(lèi)就是:一上來(lái)20多行都在一個(gè)if (log.isTraceEnabled()){}里面。
  
log在這說(shuō)明一下。Struts中使用的是Jakarta Commons Logging的包,它使用的優(yōu)先級(jí)是:Log4j(4念four好像比較有意義,大概是Logger For Java的意思,我聽(tīng)有的人年Log si J,感覺(jué)很別扭,呵呵),Java 1.4 Logging API,Simple Logging。功能是依次減弱。
  
建議在寫(xiě)Action 的execute()或被execute()調(diào)用的業(yè)務(wù)方法中使用Commons Logging 來(lái)代替System.out.println()--當(dāng)要你把成百上千的System.out.println()去掉的時(shí)候你就會(huì)覺(jué)得Commons Logging是個(gè)多好的東東了。它的用法是:

import org.apache.commons.logging.Log;

import org.apache.commons.logging.LogFactory;

private/protected static Log log = LogFactory.getLog(DispatchAction.class);

如果你用的是DispatchAction,那你就不要自己定義Log的實(shí)例了,因?yàn)樗呀?jīng)有一個(gè)protected的Log實(shí)例,直接使用即可。
  
使用方法是:

      if (log.isInfoEnabled()) {
         log.Info("some information.");
      }

Logging把消息分為6種級(jí)別,debug,error,fatal,info,trace,warn。比如,你想記錄一條消息,它只是為了給用戶(hù)一個(gè)警告,則可以使用warn。為什么在每個(gè)log.Info()前做一次判斷呢?難道如果log級(jí)別不允許Info,log.Info()仍然能Info嗎?當(dāng)然不是。在Struts中使用它的作用是提高效率。
  
比如有個(gè)消息是計(jì)算前一萬(wàn)個(gè)自然數(shù)的和(這種消息可能少見(jiàn))。用直接log.Info()

  int sum=0;
      for(int i=0;i<10000;i++){
       sum+=i;
      }
      log.Info("the sum of form 1 to 10000 is : "_sum);

如果log.Info是不允許的,那求10000個(gè)數(shù)的和就白求的。當(dāng)然如果你的計(jì)算機(jī)很快或和高斯一樣聰明,直接log.Info()也每什么問(wèn)題。
     
閑話少說(shuō),回到180多行的BeanUtils.setProperty()方法。這個(gè)方法先是處理nested屬性,也就是xxx.xxx的請(qǐng)求參數(shù)。我們只看看處理簡(jiǎn)單屬性的必須過(guò)程。下面這端代碼有點(diǎn)長(zhǎng),但它只做了一件事:將字符串的請(qǐng)求參數(shù)轉(zhuǎn)成ActionForm的類(lèi)型。比如:你在ActionForm里有個(gè)Integer userAge;然后HTTP請(qǐng)求參數(shù)里可能會(huì)有http://localhost:8080/xxx.do?userAge=21。傳人的是字符串,目標(biāo)是專(zhuān)程Integer。
  
首先它當(dāng)然會(huì)根據(jù)userAge這個(gè)字符串查找相應(yīng)的ActionForm,如果這個(gè)ActionForm有個(gè)屬性也叫userAge,然后就會(huì)把這個(gè)userAge的時(shí)間類(lèi)型存到type里,type的定義是:Class type = null; 得到type的代碼很長(zhǎng),這是因?yàn)橐紤]很多情況,例如

  1. DynaActionForm。  
  2.      // Convert the specified value to the required type  
  3.       Object newValue = null;  
  4.       if (type.isArray() && (index < 0)) { // Scalar value into array  
  5.         if (value == null) {  
  6.           String values[] = new String[1];  
  7.           values[0] = (String) value;  
  8.           newValue = ConvertUtils.convert((String[]) values, type);  
  9.         } else if (value instanceof String) {  
  10.           String values[] = new String[1];  
  11.           values[0] = (String) value;  
  12.           newValue = ConvertUtils.convert((String[]) values, type);  
  13.         } else if (value instanceof String[]) {  
  14.           newValue = ConvertUtils.convert((String[]) value, type);  
  15.         } else {  
  16.           newValue = value;  
  17.         }  
  18.       } else if (type.isArray()) {     // Indexed value into array  
  19.         if (value instanceof String) {  
  20.           newValue = ConvertUtils.convert((String) value,  
  21.                           type.getComponentType());  
  22.         } else if (value instanceof String[]) {  
  23.           newValue = ConvertUtils.convert(((String[]) value)[0],  
  24.                           type.getComponentType());  
  25.         } else {  
  26.           newValue = value;  
  27.         }  
  28.       } else {               // Value into scalar  
  29.         if ((value instanceof String) || (value == null)) {  
  30.           newValue = ConvertUtils.convert((String) value, type);  
  31.         } else if (value instanceof String[]) {  
  32.           newValue = ConvertUtils.convert(((String[]) value)[0],  
  33.                           type);  
  34.         } else if (ConvertUtils.lookup(value.getClass()) != null) {  
  35.           newValue = ConvertUtils.convert(value.toString(), type);// Here is my program's break point  
  36.         } else {  
  37.           newValue = value;  
  38.         }  
  39.       }  

最后是:Struts調(diào)用PropertyUtils的一些方法設(shè)置值。下面代碼的第一種情況是有索引的,即你在請(qǐng)求參數(shù)里傳了field[0]=123之類(lèi)的參數(shù),第二種是Map時(shí)間類(lèi)型的,傳的是map(key)=value之類(lèi)的參數(shù),最一般的就是調(diào)用第三個(gè)方法。

if (index >= 0) {
   PropertyUtils.setIndexedProperty(target, propName,
   index, newValue);
        } else if (key != null) {
   PropertyUtils.setMappedProperty(target, propName}

 

【編輯推薦】

  1. Spring AOP的一些概念
  2. acegi到Spring security的轉(zhuǎn)換方式
  3. Spring Framework的理解
  4. 解決Spring2.0向spring2.5遷移的問(wèn)題
  5. Spring框架人氣暴漲
責(zé)任編輯:佚名 來(lái)源: 網(wǎng)絡(luò)轉(zhuǎn)載
相關(guān)推薦

2020-06-10 16:10:35

ActivityWat屏幕使用時(shí)間Linux

2016-06-29 09:53:15

云計(jì)算

2021-01-06 08:14:21

時(shí)間序列數(shù)據(jù)庫(kù)數(shù)據(jù)庫(kù)

2012-03-30 15:15:49

筆記本評(píng)測(cè)

2023-01-28 16:13:08

InfluxData開(kāi)源

2011-07-01 11:02:30

EnyowebOShello world

2010-06-21 17:08:10

Java框架ScalaSpring

2011-07-01 10:52:59

EnyowebOS 3.0 S

2011-06-16 16:41:20

Qt MeeGo SDK

2021-09-02 00:11:19

電腦緩存捆綁

2010-10-15 09:52:00

XephyrMeeGoQt

2022-11-15 12:04:54

手機(jī)數(shù)據(jù)監(jiān)控

2022-11-11 10:56:37

2009-09-29 11:03:07

SaveNewOrdeStruts框架

2009-06-25 15:37:12

Struts2教程Validation框

2011-03-30 09:03:57

struts2

2009-06-01 10:47:32

jboss seam例jboss seam開(kāi)jboss seam

2010-04-20 09:14:33

Struts

2009-02-04 13:13:03

2011-04-22 11:24:13

mootools
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)