李李的技術(shù)博客

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            13 隨筆 :: 0 文章 :: 61 評(píng)論 :: 0 Trackbacks

          2006年1月21日 #

          為了降低侵入性,更好的被引用,對(duì)bba96核心部分進(jìn)行了大量重構(gòu),去除了冗贅的層次與不必要的接口,并借助jdk5.0范型進(jìn)行了代碼精簡(jiǎn)。發(fā)布了bba96 tiger beta2,這個(gè)版本已經(jīng)是比較穩(wěn)定的版本,具體的改動(dòng)如下

          • 去除所有的接口依賴,可直接在任何項(xiàng)目中直接調(diào)用
          • service的兩層合并為一層且去除service層的接口,但DAO曾仍保留接口以備擴(kuò)展更多的orm實(shí)現(xiàn)
          • 增加sql execute的方法
          • 增強(qiáng)源自view的直接查詢能力
          • 參數(shù)名由原來(lái)難看的oriNames, oriOperators, oriStringValues改為直觀的searchName, searchOperator, searchValue
          • 增加了對(duì)QueryParam的toString功能,可打出對(duì)應(yīng)的sql,便于調(diào)試,參見(jiàn)com.bba96.tiger.util.QueryWebUtils的main函數(shù)

          下載頁(yè)面地址:https://bba96.dev.java.net/servlets/ProjectDocumentList?folderID=4149&expandFolder=4149&folderID=0

          如果你使用spring+hibernate,而又不喜歡hibernate criteria的麻煩,不妨嘗試一下bba96,你可以把主要精力放到業(yè)務(wù)方面。DefaultEntityManager提供了很多單層邏輯的便利方法給你使用,其中也包括執(zhí)行hsql或者sql查詢/更新的方法,如果你要多層次邏輯的條件查詢可以自己組裝QueryObject,參見(jiàn)com.bba96.tiger.util.QueryWebUtils的main函數(shù)。bba96還提供給你在view層自由增加查詢的能力。

          tiger版本僅提供了dao/service部分,所以如果你希望在view 查詢的安全性方面得到加強(qiáng),可參考bba96 2.0其中的webwork view部分,權(quán)限部分也沒(méi)有包含在tiger中,希望盡快把包括例子的權(quán)限部分遷移過(guò)來(lái),但還需要一點(diǎn)時(shí)間,最近在忙一個(gè)CMS的產(chǎn)品,時(shí)間不夠用啊……

          SpringSide項(xiàng)目中webwork MVC部分應(yīng)用到bba96 tiger對(duì)view部分的查詢,有興趣可以看看,這里也要推薦一下SpringSide,確實(shí)有很多很好的經(jīng)驗(yàn)在里面可以借鑒。

          posted @ 2006-06-10 19:16 李李 閱讀(1588) | 評(píng)論 (2)編輯 收藏

          bba96 CHANGELOG
          ==========================
          http://bba96.dev.java.net

          Changes in version 2.0 alpha3 (2006.4.3)
          *fix action query parameters bug -- [XXX:...]
          *fix distinct bug (discard Criteria.DISTINCT_ROOT_ENTITY)
          *some minor improvement

          Changes in version 2.0 alpha2.2 (2006.3.16)
          *update webwork's jar for fixing example bug in weblogic
          *remove all contentType setting in example

          Changes in version 2.0 alpha2.1 (2006.3.8)
          *fix example bug
          *update readme.txt

          Changes in version 2.0 alpha1 (2006.3.7)
          *webwork 2.2 support
          *hibernate 3.x support, then support native sql
          *fix some bug
          *add aop security module
          *add action query parameters validation
          *enhance action query parameters management
          *support more logic in action query
          *support multi orderby property


          Changes in version 1.0 (2005.09.23)
          *release first


          源碼下載(包含兩個(gè)快速開(kāi)發(fā)的例子。)
          https://bba96.dev.java.net/servlets/ProjectDocumentList?folderID=4149&expandFolder=4149&folderID=0

          簡(jiǎn)介參見(jiàn)http://www.aygfsteel.com/scorpio_leon/archive/2005/11/09/18878.aspx

          posted @ 2006-03-08 01:24 李李 閱讀(1051) | 評(píng)論 (0)編輯 收藏

          很容易找到getText實(shí)際的操作類是LocalizedTextUtil,方法public static String findText(Class aClass, String aTextName, Locale locale, String defaultMessage, Object[] args, OgnlValueStack valueStack);

          java doc 如下

          Finds a localized text message for the given key, aTextName. Both the key and the message itself is evaluated as required. The following algorithm is used to find the requested message:

          1. Look for message in aClass' class hierarchy.
            1. Look for the message in a resource bundle for aClass
            2. If not found, look for the message in a resource bundle for any implemented interface
            3. If not found, traverse up the Class' hierarchy and repeat from the first sub-step
          2. If not found and aClass is a ModelDriven Action, then look for message in the model's class hierarchy (repeat sub-steps listed above).
          3. If not found, look for message in child property. This is determined by evaluating the message key as an OGNL expression. For example, if the key is user.address.state, then it will attempt to see if "user" can be resolved into an object. If so, repeat the entire process fromthe beginning with the object's class as aClass and "address.state" as the message key.
          4. If not found, look for the message in aClass' package hierarchy.
          5. If still not found, look for the message in the default resource bundles.
          6. Return defaultMessage

          主要就是查找resource bundle,下面說(shuō)明一下
          1. 先查找該class(一般我們是在action調(diào)用,就是該action對(duì)應(yīng)的class了)對(duì)應(yīng)的properties文件,找不到再去找對(duì)應(yīng)的接口,找不到再去從該class的繼承樹(shù)上去重復(fù)前面的步驟。
          2. 如果是ModelDriver,以上找不到再以model的class去重復(fù)1的步驟
          3.繼續(xù)找,如果key是符合ognl表達(dá)式還以ognl表達(dá)式去解析類,如果能找到類,還以以上的步驟去查找
          4. 還找不到,就從根據(jù)package以及package的繼承樹(shù)去找,這還包括了該class的繼承樹(shù)所有的class的package樹(shù)(這一步存在了太多的重復(fù)查找工作,因?yàn)楹芏鄍ackage都是相同的)
          5 使用默認(rèn)的resource bundle

          java.util.ResourceBundle雖然有cache,但是ww為了減少調(diào)用getResourceBundle方法,也維護(hù)了一個(gè)miss的hashset,找不到的bundle name就丟進(jìn)去,那么每一次查找都同步了這個(gè)miss,如果很多次查找,開(kāi)銷也是很大的。

          我就舉一個(gè)例子,就說(shuō)第四步查找package樹(shù)好了

                  // nothing still? alright, search the package hierarchy now
                  for (Class clazz = aClass;
                       (clazz 
          != null&& !clazz.equals(Object.class);
                       clazz 
          = clazz.getSuperclass()) {

                      String basePackageName 
          = clazz.getName();
                      
          while (basePackageName.lastIndexOf('.'!= -1) {
                          basePackageName 
          = basePackageName.substring(0, basePackageName.lastIndexOf('.'));
                          String packageName 
          = basePackageName + ".package";
                          msg 
          = getMessage(packageName, locale, aTextName, valueStack, args);

                          
          if (msg != null) {
                              
          return msg;
                          }

                          
          if (indexedTextName != null) {
                              msg 
          = getMessage(packageName, locale, indexedTextName, valueStack, args);

                              
          if (msg != null) {
                                  
          return msg;
                              }
                          }
                      }
                  }

          假設(shè)你的action繼承樹(shù)是這樣
          com.bba96.core.webwork.actions.DefaultActionSupport
          com.xxxx.web.actions.XXXActionSupport
          com.xxxx.web.user.actions.UserAction
          com.xxxx.web.user.ViewUserAction
          且不說(shuō)ww沒(méi)有判斷是否是com.opensymphony.xwork.ActionSupport或者ww的接口就停止,光是自己的繼承樹(shù),就是4+3+3+3=13次,再加上往上的繼承樹(shù)以及對(duì)應(yīng)的接口,com.opensymphony.xwork.ActionSupport以及Action, Validateable, ValidationAware, TextProvider, LocaleProvider, Serializable, ContinuableObject的接口,查找次數(shù)超過(guò)30次甚至更多,這里的每一次都有一個(gè)同步miss的過(guò)程,開(kāi)銷相當(dāng)大。

          如果你的key所在的resource bundle沒(méi)有對(duì)應(yīng)到合適的class或package時(shí),例如說(shuō)放在了default bundle中,ww會(huì)浪費(fèi)很多時(shí)間。這種情況下,我在沒(méi)有并發(fā)的時(shí)候測(cè)了一下,一次getText大概耗時(shí)40ms左右

          所以在實(shí)際應(yīng)用我們應(yīng)該避免這種情況出現(xiàn),要不讓resource bundle一一對(duì)應(yīng)class,要不就自己實(shí)現(xiàn)一個(gè)簡(jiǎn)單的getText,其實(shí)要是ww的ActionSupport的textProvider允許改變就最好了。

          posted @ 2006-01-21 13:26 李李 閱讀(1633) | 評(píng)論 (0)編輯 收藏

          主站蜘蛛池模板: 盐源县| 通城县| 缙云县| 剑阁县| 平果县| 新竹县| 庆云县| 吴旗县| 枝江市| 贵港市| 周至县| 陆良县| 丰镇市| 桐柏县| 临沂市| 赤壁市| 佛冈县| 老河口市| 汕头市| 衡阳市| 芜湖县| 任丘市| 云林县| 出国| 达州市| 垦利县| 高平市| 玛曲县| 封丘县| 厦门市| 安西县| 方城县| 阿拉尔市| 海晏县| 凤台县| 江陵县| 台东县| 辽阳县| 南陵县| 临安市| 淮滨县|