實體更新
          Transaction trans=session.beginTransaction();   
          String hql=”update User user set user.age=20 where user.age=18”;   
          Query queryupdate=session.createQuery(hql);   
          int ret=queryupdate.executeUpdate();   
          trans.commit();
          實體刪除
          Transaction trans=session.beginTransaction();   
          String hql=”delete from User user where user.age=18”;   
          Query queryupdate=session.createQuery(hql);   
          int ret=queryupdate.executeUpdate();   
          trans.commit();
          屬性查詢
          List list=session.createQuery(“select user.name from User user ”).list();   
          for(int i=0){   System.out.println(list.get(i));   }

          一次檢索多個屬性,如下面程序:   
          List list=session.createQuery(“select user.name,user.age from User user ”).list();   for(int i=0;i<list.length();i++){   Object[] obj=(Object[])list.get(i);   System.out.println(obj[0]);   System.out.println(obj[1]);   }

          posted @ 2011-11-22 09:24 陳小東 閱讀(791) | 評論 (0)編輯 收藏

          用攔截器實現登錄驗證功能AuthorizationInterceptor
          package com.interceptor;   
            
          import com.opensymphony.xwork2.ActionInvocation;   
          import com.opensymphony.xwork2.interceptor.*;   
          import com.opensymphony.xwork2.*;   
          import java.util.*;   
          /**  
           * 
          @author http://xp9802.iteye.com/  
           
          */
            
          public class AuthorizationInterceptor extends AbstractInterceptor {   
              
          private String ignoreActions;   
            
              
          // ignoreActions屬性的getter方法   
              public String getIgnoreActios() {   
                  
          return ignoreActions;   
              }
             
            
              
          // ignoreActions屬性的setter方法   
              public void setIgnoreActions(String ignoreActions) {   
                  
          this.ignoreActions = ignoreActions;   
              }
             
            
              @Override  
              
          public String intercept(ActionInvocation invocation) throws Exception {   
                  ActionContext ctx 
          = invocation.getInvocationContext();   
            
                  Map session 
          = ctx.getSession();   
                  String user 
          = (String) session.get("username");   
            
                  
          boolean ignore = false;   
                  String currentAction 
          = invocation.getProxy().getActionName();   
                  String[] actions 
          = ignoreActions.split(",");   
            
                  
          for (String action : actions) {   
                      
          if (currentAction.matches(action.trim())) {   
                          ignore 
          = true;   
                          
          break;   
                      }
             
                  }
             
            
                  
          if (user != null || ignore == true{   
            
                      
          return invocation.invoke();   
                  }
           else {   
                      
          return Action
          <interceptors>    
              
          <interceptor name="authorization" class="com.interceptor.AuthorizationInterceptor" />    
              
          <interceptor-stack name="myStack">    
                  
          <interceptor-ref name="authorization">    
                      
          <param name="ignoreActions"> validate_code,register.*,.*login.*,upload,connector</param>    
               
          </interceptor-ref> <interceptor-ref name="defaultStack" />   
          </interceptor-stack>    
          lt;/interceptors>    
          <default-interceptor-ref name="myStack"/>  
          .LOGIN;   
                  }
             
            
              }
             
          }
            

          在struts.xml文件里面配置該攔截器:


          posted @ 2011-11-22 09:23 陳小東 閱讀(765) | 評論 (0)編輯 收藏

               摘要:   閱讀全文

          posted @ 2011-11-21 09:36 陳小東 閱讀(220) | 評論 (0)編輯 收藏

          1. BIRT Project
          BIRT報表是一款非常流行的開源報表開發工具。擁有和Dreamweaver一般的操作界面,可以像畫table一樣畫報表,生成圖片,導出Excel,html分頁樣樣齊全,樣式和script設置簡單。

          2. Pentaho
          Pentaho Report Designer是一款所見即所得的開源報表設計工具。在設計報表的時候,用戶可以隨意拖放和設置各種報表的控件,還可以快速方便地設置報表的數據來源。在報表的設計過程中,用戶可以隨時預覽報表的結果。

          3. OpenRPT
          OpenRPT支持各種平臺PostgreSQL的最佳化的圖形化界面的SQL報表撰寫。

          4. OpenReports
          OpenReports 提供基于web 的靈活報表解決方案,支持 PDF,HTML 和XLS 報表格式,基于WebWork,Hibernate 和 Velocity 開發完成,并且還提供一個整合了Tomcat 的OpenReports-Tomcat 文件下載。使用Java進行開發,JasperReports 作為報表引擎。

          5. FreeReportBuilder
          FreeReportBuilder是一個Java報表工具,可以與任何數據庫正常工作,只需要有一個JDBC驅動程序。

          6. JMagallanes
          JMagallanes是一個開源的使用Java/J2EE開發的Olap和動態報表應用程序。JMagallanes結合了靜態報表(基于JasperReports),Swing pivot表格(用于OLAP分析),和圖表(基于JFreeChart)。它可從多種數據源(如:SQL,Excel,XML和其它)讀取數據并可生成多種輸出如:PDF,XML,應用程序特殊文件用于將來報表的脫機查看。

          7. ART – A lightweight reporting solution
          ART是一個輕量級的,多平臺基于web的報表引擎。定制容易,支持圖形報表,支持通過插件把結果導出為各種格式。

          8. DataVision
          DataVision是一個用Java編寫的類似于Crystal Reports的報表工具。它支持多種數據源(JDBC, 文本文件) ,輸出格式有HTML, XML, PDF, LaTeX, 逗號或tab分隔的數據文件, 和DocBook。它讓你用一個支持拖放操作的GUI設計報表,報表描述存儲為XML。

          9. The Wabit – Open Source Reporting Tool
          Wabit 是一個跨平臺開源的報表工具,提供了一個GUI程序和可嵌入式的接口。

          10. Rlib
          RLIB是一個基于XML的報表引擎,可以生成PDF,HTML,CSV,文本格式

          11. JavaEye Reporting Tool – JERT
          JERT是一個開放源代碼的,基于web的,數據庫報表工具,它能夠讓你不需要編程而能創建各種靈活的報表。

          12. iReport
          iReport是一個能夠創建復雜報表的開源項目,并且它能調用JasperReports庫應用于任何一種java應用程序,使用純Java編寫,擁有非常豐富的圖形界面。

          posted @ 2011-11-21 09:34 陳小東 閱讀(405) | 評論 (0)編輯 收藏

               摘要:   閱讀全文

          posted @ 2011-11-19 11:54 陳小東 閱讀(176) | 評論 (0)編輯 收藏

               摘要:   閱讀全文

          posted @ 2011-11-18 15:42 陳小東 閱讀(303) | 評論 (0)編輯 收藏

          1) 在Action實現類方面的對比:Struts 1要求Action類繼承一個抽象基類;Struts 1的一個具體問題是使用抽象類編程而不是接口。Struts 2 Action類可以實現一個Action接口,也可以實現其他接口,使可選和定制的服務成為可能。Struts 2提供一個ActionSupport基類去實現常用的接口。即使Action接口不是必須實現的,只有一個包含execute方法的POJO類都可以用作Struts 2的Action。
          2) 線程模式方面的對比:Struts 1 Action是單例模式并且必須是線程安全的,因為僅有Action的一個實例來處理所有的請求。單例策略限制了Struts 1 Action能做的事,并且要在開發時特別小心。Action資源必須是線程安全的或同步的;Struts 2 Action對象為每一個請求產生一個實例,因此沒有線程安全問題。
          3) Servlet依賴方面的對比:Struts 1 Action依賴于Servlet API,因為Struts 1 Action的execute方法中有HttpServletRequest和HttpServletResponse方法。Struts 2 Action不再依賴于Servlet API,從而允許Action脫離Web容器運行,從而降低了測試Action的難度。 當然,如果Action需要直接訪問HttpServletRequest和HttpServletResponse參數,Struts 2 Action仍然可以訪問它們。但是,大部分時候,Action都無需直接訪問HttpServetRequest和HttpServletResponse,從而給開發者更多靈活的選擇。
          4) 可測性方面的對比:測試Struts 1 Action的一個主要問題是execute方法依賴于Servlet API,這使得Action的測試要依賴于Web容器。為了脫離Web容器測試Struts 1的Action,必須借助于第三方擴展:Struts TestCase,該擴展下包含了系列的Mock對象(模擬了HttpServetRequest和HttpServletResponse對象),從而可以脫離Web容器測試Struts 1的Action類。Struts 2 Action可以通過初始化、設置屬性、調用方法來測試。
          5) 封裝請求參數的對比:Struts 1使用ActionForm對象封裝用戶的請求參數,所有的ActionForm必須繼承一個基類:ActionForm。普通的JavaBean不能用作ActionForm,因此,開發者必須創建大量的ActionForm類封裝用戶請求參數。雖然Struts 1提供了動態ActionForm來簡化ActionForm的開發,但依然需要在配置文件中定義ActionForm;Struts 2直接使用Action屬性來封裝用戶請求屬性,避免了開發者需要大量開發ActionForm類的煩瑣,實際上,這些屬性還可以是包含子屬性的Rich對象類型。如果開發者依然懷念Struts 1 ActionForm的模式,Struts 2提供了ModelDriven模式,可以讓開發者使用單獨的Model對象來封裝用戶請求參數,但該Model對象無需繼承任何Struts 2基類,是一個POJO,從而降低了代碼污染。
          6) 表達式語言方面的對比:Struts 1整合了JSTL,因此可以使用JSTL表達式語言。這種表達式語言有基本對象圖遍歷,但在對集合和索引屬性的支持上則功能不強;Struts 2可以使用JSTL,但它整合了一種更強大和靈活的表達式語言:OGNL(Object Graph Notation Language),因此,Struts 2下的表達式語言功能更加強大。
          7) — 綁定值到視圖的對比:Struts 1使用標準JSP機制把對象綁定到視圖頁面;Struts 2使用“ValueStack”技術,使標簽庫能夠訪問值,而不需要把對象和視圖頁面綁定在一起。
          8) 類型轉換的對比:Struts 1 ActionForm 屬性通常都是String類型。Struts 1使用Commons-Beanutils進行類型轉換,每個類一個轉換器,轉換器是不可配置的;Struts 2使用OGNL進行類型轉換,支持基本數據類型和常用對象之間的轉換。
          9) 數據校驗的對比:Struts 1支持在ActionForm重寫validate方法中手動校驗,或者通過整合Commons alidator框架來完成數據校驗。Struts 2支持通過重寫validate方法進行校驗,也支持整合XWork校驗框架進行校驗。
          10) Action執行控制的對比:Struts 1支持每一個模塊對應一個請求處理(即生命周期的概念),但是模塊中的所有Action必須共享相同的生命周期。Struts 2支持通過攔截器堆棧(Interceptor Stacks)為每一個Action創建不同的生命周期。開發者可以根據需要創建相應堆棧,從而和不同的Action一起使用。
          11) 捕獲輸入:Struts1 使用ActionForm對象捕獲輸入。所有的ActionForm必須繼承一個基類。因為其他JavaBean不能用作ActionForm,開發者經常創建多余的類捕獲輸入。動態Bean(DynaBeans)可以作為創建傳統ActionForm的選擇,但是,開發者可能是在重新描述(創建)已經存在的JavaBean(仍然會導致有冗余的javabean)。Struts 2直接使用Action屬性作為輸入屬性,消除了對第二個輸入對象的需求。輸入屬性可能是有自己(子)屬性的rich對象類型。Action屬性能夠通過 web頁面上的taglibs訪問。Struts2也支持ActionForm模式。rich對象類型,包括業務對象,能夠用作輸入/輸出對象。這種 ModelDriven 特性簡化了taglib對POJO輸入對象的引用。

          posted @ 2011-11-17 09:14 陳小東 閱讀(57504) | 評論 (17)編輯 收藏

               摘要:   閱讀全文

          posted @ 2011-11-16 09:03 陳小東 閱讀(408) | 評論 (0)編輯 收藏

          內連接:INNER  JOIN或者JOIN,把兩個表中數據對應的數據查出來。
          外連接:OUTER  JOIN,以某個表為基礎把對應數據查出來,分為左外連接和右外連接。
          左外連接:LEFT  JOIN或者LEFT  OUTER  JOIN,以某個表為基礎把對應數據查出來。
          右外連接:RIGHT  JOIN或者RIGHT  OUTER  JOIN,以某個表為基礎把對應數據查出來。
          全連接:FULL  JOIN,以多個表為基礎

          posted @ 2011-11-15 09:22 陳小東 閱讀(141) | 評論 (0)編輯 收藏

          內連接:INNER  JOIN或者JOIN,把兩個表中數據對應的數據查出來。
          外連接:OUTER  JOIN,以某個表為基礎把對應數據查出來,分為左外連接和右外連接。
          左外連接:LEFT  JOIN或者LEFT  OUTER  JOIN,以某個表為基礎把對應數據查出來。
          右外連接:RIGHT  JOIN或者RIGHT  OUTER  JOIN,以某個表為基礎把對應數據查出來。
          全連接:FULL  JOIN,以多個表為基礎

          posted @ 2011-11-15 09:22 陳小東 閱讀(1781) | 評論 (0)編輯 收藏

          僅列出標題
          共4頁: 上一頁 1 2 3 4 下一頁 

          posts - 34, comments - 38, trackbacks - 0, articles - 0

          Copyright © 陳小東

          主站蜘蛛池模板: 鄂温| 睢宁县| 奉节县| 清水河县| 哈密市| 五华县| 伊川县| 曲松县| 盘山县| 尖扎县| 岱山县| 安康市| 朝阳区| 铁岭市| 深州市| 吉水县| 乐平市| 开化县| 章丘市| 长丰县| 东城区| 内江市| 绥德县| 苍梧县| 乐陵市| 奉贤区| 石泉县| 辉县市| 莎车县| 湖州市| 满城县| 凤冈县| 涡阳县| 通渭县| 屏南县| 荆州市| 工布江达县| 孝昌县| 佛冈县| 万源市| 阿坝|