Java蜘蛛人 歡迎大家

          歡迎大家 來到我的blog , 如果我身邊的朋友 有什么不懂可以直接來問我 我會細心的幫助你的. 如果網絡上的朋友有什么不懂的 可以加我Java蜘蛛人 QQ48187537
          posts - 54, comments - 192, trackbacks - 0, articles - 1

          2009年2月12日

          java 整合PHP 論壇。 最近公司有個項目需要整合一個論壇,于是就找到了PHP的discuz 論壇,但是以前沒整合過,所以網上找了很多資料,也走了不少彎路。 呵呵。自己改寫了一封之后 寫成了文檔,不懂問我.

          http://download.csdn.net/source/17351292


          DISCUZ  7    整合  java

          DISCUZ x1    整合   java

          目前也整合成功,并且是免激活的。   有需要幫忙的朋友聯系我。

          QQ48187537

          目前暫時不能錄制視頻,手頭項目緊啊,回家已經很累了。   但是如果大家遇到小問題, 可以問我。 10分鐘能解決的就幫你們。

          posted @ 2009-10-11 12:00 Java蜘蛛人 --鄭成橋 閱讀(4260) | 評論 (40)編輯 收藏

                各位項目中應該很多地方用到權限管理對吧??  那為什么不試試acegi。。  

           今天我錄制了一個視頻就是 Spring +Acegi的視頻,如果已經會了的人 可以不用下載 因為很大,大小100MB。
                           
                 下載地址:        http://ajava.org/video/spring/12425.html

           主講人: 鄭成橋

          posted @ 2009-07-21 11:02 Java蜘蛛人 --鄭成橋 閱讀(5665) | 評論 (14)編輯 收藏

            把所有的人頁面,以及數據庫設置成為utf-8  然后修改如下東西:

          打開 cmd

          輸入
            java -help "D:\ProgramFiles\MyEclipse 6.5\eclipse\eclipse.exe" -vm "d:\ProgramFiles\MyEclipse 6.5\jre\bin\javaw.exe" -Vmargs -Dfile.encoding=UTF-8 -Xms256m -Xmx1024m -XX:PermSize=256M -XX:MaxPermSize=512M

          以上東西 根據自己目錄改變

          然后打開 D:\ProgramFiles\MyEclipse 6.5\eclipse\eclipse.ini    結尾加上
          -Vmargs -Dfile.encoding=UTF-8



          重啟下 就可以。


              順便告訴大家 我的JBPM 視頻已經在錄制中了。。。  大家過段時間就可以再我的博客上下載了。 謝謝大家對我的支持



          大家如果想自學的話 可以看看:http://zhangym.javaeye.com/category/38399

          posted @ 2009-07-09 14:59 Java蜘蛛人 --鄭成橋 閱讀(2689) | 評論 (4)編輯 收藏

           

           利用spring的mock類進行單元測試:
          spring框架提供了大量測試的mock類,包括與jndi,porlet,web應用相關的mock類。尤其是web應用相關的mock類,可以大大提高web組件測試的方便性。

          打開spring的下載包的mock文件夾(路徑...mock\org\springframework\mock\web),就發覺有如下幾個文件:

          MockHttpServletRequest:是HttpServletRequest接口的mock實現,用來模擬客戶端的HTTP請求,很常用的一個類。

          MockHttpServletResponse:是HttpServletResponse接口的mock實現,用于模擬服務器對客戶端的響應。

          MockHttpSession:是對HttpSession接口的mock實現。

          DelegatingServletInputStream:是對ServletInputStream接口的mock實現。

          DelegatingServletOutputStream:ServletOutputStream的mock實現。需要攔截和分析服務器的輸出的流的內容,可以使用該類。

          其他的,例如MockFilterConfig,MockPageContext(可以測試預編譯的JSP),MockRequestDispatcher,MockServletConfig看名稱就知道大概是mock什么的。
          舉一個例子:
              MockHttpServletRequest request =  new MockHttpServletRequest("POST","/index.do");  
              request.addParameter("username","name");  
              request.addParameter("password","word"); 

          利用spring來進行集成測試
          1、AbstractSpringContextTests類[1],該類全部方法是protected的,通常不使用這個類,而使用它的子類們。

          2、AbstractDependencyInjectionSpringContextTests類[2]:繼承于類[1]:名字N長的。如果僅僅使用Spring依賴注入功能可以讓測試用例繼承該類。

          3、AbstractTransactionalSpringContextTests類[3]:繼承于類[2],繼承該類的測試用例在spring管理的事務中進行,測試完后對數據庫的記錄不會造成任何影響。你對數據庫進行一些操作后,它會自動把數據庫回滾,這樣就保證了你的測試對于環境沒有任何影響

          4、AbstractTransactionalDataSourceSpringContextTests繼承于類[3],功能更強大,用于測試持久層組件,看其源代碼,有一行"protected JdbcTemplate jdbcTemplate;",提供了一個JdbcTemplate的變量,通過該對象可以直接操作數據庫。

          http://lighter.javaeye.com/blog/41733 還提供了兩個用spring來進行集成測試(對數據庫操作進行測試),業務測試(對業務層進行測試)的例子供下載。

          ***如何在你的TestCase Class里取得spring context (注意路徑問題)?***

          你的TestCase Class必須繼承的是上述四個AbstractXXXSpringContextTests中的其中一個,那么就必須實現下面這個方法來取得spring context

             protected abstract String[] getConfigLocations();

          例如:

           public String[] getConfigLocations() {
              String[] configLocations = { "applicationContext.xml","hibernate-context.xml" };
              return configLocations;
           }


          請 注意要加載的context xml file的路徑問題:上述的代碼是基于classpath,因此applicationContext.xml和hibernate- context.xml必須放在classpath里(方法一是把xml files放到WEB-INF/classes目錄下,另一種方法就是在project properties里把xml files的路徑加到classpath里)

          那么如果你一定要把context xml files放到WEB-INF目錄下,也是可以的,那么應該基于file(基于file的相對路徑是相對于project root folder),代碼如下:

           public String[] getConfigLocations() {
              String[] configLocations = { "file:WebContent/WEB-INF/applicationContext.xml"};
              return configLocations;
           }

          AbstractXXXSpringContextTests就會根據根據getConfigLocations方法返回的context xml位置的數組來加載并且對加載的Context提供緩存。 這是非常重要的,因為如果你在從事一個大項目時,啟動時間可能成為一個問題--這不是Spring自身的開銷,而是被Spring容器實例化的對象在實例 化自身時所需要的時間。例如,一個包括50-100個Hibernate映射文件的項目可能需要10-20秒的時間來加載上述的映射文件,如果在運行每個 測試fixture里的每個測試案例前都有這樣的開銷,將導致整個測試工作的延時,最終有可能(實際上很可能)降低效率。

          在某種極偶然的情況下,某個測試可能“弄臟”了配置場所,并要求重新加載--例如改變一個bean的定義或者一個應用對象的狀態--你可以調用 AbstractDependencyInjectionSpringContextTests 上的 setDirty() 方法來重新加載配置并在執行下一個測試案例前重建application context

           

          當類 AbstractDependencyInjectionSpringContextTests(及其子類)裝載你的Application Context時,你可以通過Setter方法來注入你想要的來自context的bean,而不需要顯式的調用applicationContext.getBean(XXX)。因為AbstractDependencyInjectionSpringContextTests會從getConfigLocations()方法指定的配置文件中幫你自動注入

          下面的例子就是通過setter方法來獲得context里的ProductManager bean:

          public class MyTest extends AbstractDependencyInjectionSpringContextTests {
              ProductManager productManager;

              public String[] getConfigLocations() {
                  String[] configLocations = { "file:WebContent/WEB-INF/applicationContext.xml" };
                  return configLocations;
              }

              public void testGetProduct() {
                 assertEquals("tomson",productManager.getProductByName("tomson").getName());
              }
             

              //通過setter方法自動從context里注入productManager bean,而不用顯示調用applicationContext.getBean(XXX)
              public void setProductManager(ProductManager productManager) {
                 this.productManager = productManager;
              }
          }

          但是如 果context里有多個bean都定義為一個類型(例如有多個bean都是ProductManager class類型的),那么對這些bean就無法通過setter方法來自動依賴注入(因為有多個bean同一個類型,不知要自動注入哪個)。在這種情況下 你需要顯示的調用applicationContext.getBean(XXX)來注入。如:

          public class MyTest extends AbstractDependencyInjectionSpringContextTests {
             ProductManager productManager;

             public String[] getConfigLocations() {
                String[] configLocations = { "file:WebContent/WEB-INF/applicationContext.xml" };
                return configLocations;
             }

             public void onSetUp() {
                 productManager = (ProductManager) applicationContext.getBean("productManager");
             }

             public void testGetProduct() {
                 assertEquals("tomson",productManager.getProductByName("tomson").getName());
             }
           
          }

          如果你的TestCase不使用依賴注入,只要不定義任何setters方法即可或者你可以繼承 AbstractSpringContextTests --這個 org.springframework.test 包中的根類,而不是繼承AbstractDependencyInjectionSpringContextTests(及其子類)。這是因為AbstractSpringContextTests 只包括用來加載Spring Context的便利方法但沒有自動依賴注入的功能。

          posted @ 2009-06-04 16:39 Java蜘蛛人 --鄭成橋 閱讀(4479) | 評論 (2)編輯 收藏

          webservice 視頻教程 Spring+xfire 整合

           載地址:   http://ajava.org/video/other/8030.html

          馬上會推出 webservice 第二講。


             謝謝大家對我的支持   

            有什么問題聯系 zhengchengqiaobusiness@gmail.com





          -------------------  2009.08.31 修改這篇文章。(以上是原文) 我暫時不打算講第二期。 因為webservice 該入門講的 我都講了。如果要深入點就請看書。查資料。 第二期 等我們項目做完了 我直接講 webservice實戰一點的東西。

          posted @ 2009-05-28 17:26 Java蜘蛛人 --鄭成橋 閱讀(6867) | 評論 (23)編輯 收藏

          Struts2+JPA+Spring視頻教程(上) 主講人:鄭成橋
          http://ajava.org/video/SSH/6193.html
           

          Struts2+JPA+Spring視頻教程(下) 主講人:鄭成橋
          http://ajava.org/video/SSH/6194.html
          這個網站的標題弄錯了,反正進去記住2集都下下來就可以了。


           

          posted @ 2009-05-13 23:41 Java蜘蛛人 --鄭成橋 閱讀(2376) | 評論 (2)編輯 收藏

          你做過博客系統嗎? 如果沒有做過,我今天錄制了一個視頻是講博客怎么實現的


          視頻講座地址:
          http://www.qupan.com/down/zcq87642231_3259021.html


          posted @ 2009-05-06 21:45 Java蜘蛛人 --鄭成橋 閱讀(1396) | 評論 (1)編輯 收藏

               摘要: Normal 0 7.8 磅 0 2 false false false EN-US ZH-CN X-NONE MicrosoftInternetExplorer4 ...  閱讀全文

          posted @ 2009-04-22 15:49 Java蜘蛛人 --鄭成橋 閱讀(4113) | 評論 (8)編輯 收藏

          各位這是我今天講的視頻  Freemarker  已經發到網站上去了。大家可以放心下載了


          下載地址:http://ajava.org/video/other/4684.html
           



          Email:zhengchengqiaobusiness@gmail.com

          群號
          AJava-IBM核心技術㈠ 24969552
          AJava-IBM核心技術㈡ 83070128
          AJava-IBM核心技術㈢ 23063942
          AJava-IBM核心技術㈣ 24276855
          AJava-IBM核心技術㈤ 29066658
          AJava-IBM核心技術㈥ 39301145


                                                      _你們的群主:鄭成橋

          posted @ 2009-04-06 23:03 Java蜘蛛人 --鄭成橋 閱讀(2830) | 評論 (4)編輯 收藏

          這個是我今天講的Ext視頻 下載地址
          Ext 視(上)
          http://ajava.org/video/ajax/4330.html
          Ext視頻(中)
          http://ajava.org/video/ajax/4331.html
          Ext視頻(下)
          http://ajava.org/video/ajax/4332.html
          視頻代碼:
          http://ajava.org/video/ajax/4333.html

          轉載說明出處


          謝謝大家。 如果視頻下載不了 或者,解壓的問題。  請聯系我。zhengchengqiaobusiness@gmail.com

          posted @ 2009-03-22 19:44 Java蜘蛛人 --鄭成橋 閱讀(2833) | 評論 (14)編輯 收藏

          test.js
          Ext.onReady(function(){
              
              Person 
          = function(name)
              {
                  
          this.name= name;
                  
          this.addEvents("walk","eat","sleep");
              }
              
              
              
              Person2 
          = function(name)
              {
                  
          this.name= name;
                  
          this.addEvents("aa","bb","cc");
              }
              
              
              
                  
              Ext.extend(Person2,Ext.util.Observable,{
                  info:
          function(event)
                  {
                      
          return this.name+"is"+event+"ing.";
                  }
              });
              
              
              
              Ext.extend(Person,Ext.util.Observable,{
                  info:
          function(event)
                  {
                      
          return this.name+"is"+event+"ing.";
                  }
              });
              
              
              
              
                  
          var person2 = new Person2("鄭成橋");
              
                  person2.on('aa',
          function (){
                      Ext.Msg.alert(
          "event",this.name+"哈哈");            
                  });
                  
                  person2.on(
          "bb",function(frunt,shuiguo){
                      Ext.Msg.alert(
          "event",this.name+"面包:"+frunt+"葡萄"+shuiguo);
                  });
                  person2.on(
          "cc",function(time){
                      Ext.Msg.alert(
          "event",this.name+"老子要從"+time.format("h")+"呵呵");
                  });
              
              
              
              
              
          var person = new Person("zcq");
              
                  person.on('walk',
          function (){
                      Ext.Msg.alert(
          "event",this.name+"走撒");            
                  });
                  
                  person.on(
          "eat",function(frunt,shuiguo){
                      Ext.Msg.alert(
          "event",this.name+"要吃:"+frunt+""+shuiguo);
                  });
                  person.on(
          "sleep",function(time){
                      Ext.Msg.alert(
          "event",this.name+"要從"+time.format("h")+"開始睡覺");
                  });
                  
              
                  
                  
                  
                  Ext.get(
          "walk").on("click",function(){
              
                  person2.fireEvent(
          "aa");
              });
              
              Ext.get(
          "eat").on("click",function(){
                  person2.fireEvent(
          "bb","蘋果","woman");
              });
              
              Ext.get(
          "sleep").on("click",function(){
                  person2.fireEvent(
          "cc",new Date());
              });
                  
                  
                  
                  
              Ext.get(
          "walk").on("click",function(){
              
                  person.fireEvent(
          "walk");
              });
              
              Ext.get(
          "eat").on("click",function(){
                  person.fireEvent(
          "eat","蘋果","女人");
              });
              
              Ext.get(
          "sleep").on("click",function(){
                  person.fireEvent(
          "sleep",new Date());
              });
              
              
               
              
              Ext.get(
          "capture1").on("click",function(){
                    Ext.util.Observable.releaseCapture(person);
              });
              
              Ext.get(
          "capture2").on("click",function(){
                  Ext.util.Observable.capture(person,
          function(){
                      
          return false;
                  });
              });
                
          });

          index1.jsp
          <%@ page language="java" import="java.util.*" pageEncoding="gbk"%>
           
          <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
          <html>
            
          <head>
              
              
          <title>My JSP 'index.jsp' starting page</title>
              
          <meta http-equiv="pragma" content="no-cache">
              
          <meta http-equiv="cache-control" content="no-cache">
              
          <meta http-equiv="expires" content="0">    
              
          <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
              
          <meta http-equiv="description" content="This is my page">
              
          <!--
              
          <link rel="stylesheet" type="text/css" href="styles.css">
              
          -->
              
               
          <script type="text/javascript" src="js/adapter/ext/ext-base.js"></script>  
              
          <script type="text/javascript" src="js/ext-all.js"></script>  
               
          <link rel="stylesheet" type="text/css" href="js/resources/css/ext-all.css" />  
                
          <script type="text/javascript" src="js/js.js" ></script>
                
          <script type="text/javascript" src="js/test1.js" ></script>
                  
          <link rel="stylesheet" type="text/css" href="js/examples.css" />
                  
          <script type="text/javascript" src="js/examples.js" ></script>
            
          </head>
               
          <style type="text/css">
                  .x
          -window-dlg .ext-mb-download {
                      background:transparent url(images
          /download.gif) no-repeat top left;
                      height:46px;
                  }
              
          </style>
            
            
          <body>
              
          <input type="button" id="walk"  value="walk" />
              
          <input type="button" id="eat"  value="eat" />
              
          <input type="button" id="sleep"  value="sleep" />
              
          <br>
               
          <button id="capture1">事件切換1</button>
               
          <button id="capture2">事件切換2</button>
            
          </body>
          </html>


          posted @ 2009-03-14 15:33 Java蜘蛛人 --鄭成橋 閱讀(755) | 評論 (0)編輯 收藏

          Eclipse開發Javascript環境配置,有三種Javascript編輯器可供選擇:

          1. JSDT, JavaScript Development Toolkit 
          WPT(Web Tools Platform)自帶的插件,只要裝了WTP就不用單獨安裝JSDT。

          2. JSEclipse,可以通過Eclipse自動更新功能從 http://download.macromedia.com/pub/labs/jseclipse/autoinstall 安裝JSEclipse。

          3. Spket,通過Eclipse自動更新從 http://www.spket.com/update/ 安裝插件。


          Eclipse開發JQuery環境設置(Spket):

          首先需要安裝Spket,如上。 之后進行JQuery的配置:

          1.從JQuery.com下載開發用的Javascript文件,如下圖,一定要選擇紅框里面的選項



          2.配置Eclipse里面的Spket Javascript Profiles,如下圖:
           

          1) 從window->Preferences...進去

          2) 如上圖選擇Spket -> Javascript Profiles

          3) 點擊New...輸入JQuery建立新的profile

          4) 點擊Add Library,并選擇JQuery,建立新的Library

          5) 點擊Add File, 選擇剛下載的JQuery文件

          6) 如果想讓JQuery成為缺省的Javascript Profile,則點擊Default。

          然后新建Js文件,就可以使用JQuery的代碼提示功能了:



          --------------------------------------------------------------------------------------------------------------------------------------
          另:

          Aptana是一個非常強大,開源,專注于JavaScript的Ajax開發IDE。它的特性包括: *JavaScript,JavaScript函數,HTML,CSS語言的Code Assist功能。 *Outliner(大綱):顯示JavaScript,HTML和CSS的代碼結構。
          *支持JavaScript,HTML,CSS代碼提示,包括JavaScript 自定函數
          *代碼語法錯誤提示。
          *支持Aptana UI自定義和擴展。
          *支持跨平臺。
          *支持FTP/SFTP
          *調試JavaScript
          *支持流行AJAX框架的Code Assist功能:
          AFLAX,Dojo,JQuery,MochiKit,Prototype,Rico,script.aculo.us,Yahoo UI,Ext。
          *Adobe AIR與iPhone開發工具

          Aptana 也可以通過Eclipse自動更新從 http://update.aptana.com/update/3.2安裝插件。

          Aptana還可以知道瀏覽器是否支持對象的某個屬性/方法,很強。。!如下圖:

           

          posted @ 2009-02-19 21:19 Java蜘蛛人 --鄭成橋 閱讀(5329) | 評論 (0)編輯 收藏


          很很常用的before ,After ........等等


          返回參數的通知全套代碼:
          package com.zcq.dao;

          public interface Person {
              
              
          public String getName(String name,String pass);

          }



          package com.zcq.dao;

          public class PersonImp implements Person {

              
          public String getName(String name, String pass) {
                  System.out.println(
          "hehe");
                  String bb 
          ="aa";
                  
                  
          return bb;
              }


          }



          package com.zcq.dao;

          import org.aspectj.lang.JoinPoint;

          public class AspectClass {
              
              
              
          public String getName(JoinPoint joinPoint,String bb)
              
          {
                   
                  System.out.println(bb);
                  
          return  null;
              }


          }



          <?xml version="1.0" encoding="UTF-8"?>
           
          <beans xmlns="http://www.springframework.org/schema/beans"
                  xmlns:xsi
          ="http://www.w3.org/2001/XMLSchema-instance"
                  xmlns:aop
          ="http://www.springframework.org/schema/aop"
                  xmlns:tx
          ="http://www.springframework.org/schema/tx"
                  xsi:schemaLocation
          ="
                      http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
                      http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
                      http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
                      
                      
                      
          <bean id="aspectClass" class="com.zcq.dao.AspectClass"></bean>
                      
          <bean  id="personimp" class="com.zcq.dao.PersonImp"></bean>
                      
                      
          <aop:config>
                        
          <aop:aspect id="addAllMethod" ref="aspectClass">
                          
          <aop:pointcut id="addpointcut" expression="execution(public * get*(..))" />
                        
          <aop:after-returning  pointcut-ref="addpointcut" method="getName"  returning="bb" />
                         
          <!--    <aop:after-throwing pointcut-ref="addpointcut" method="getName" throwing="tx"  />  --> 
                        
          </aop:aspect>            
                      
          </aop:config>
          </beans>


          package com.zcq.dao;

          import org.springframework.context.ApplicationContext;
          import org.springframework.context.support.ClassPathXmlApplicationContext;

          public class Test {

              
          /**
               * 
          @param args
               
          */

              
          public static void main(String[] args) {
                  
                  
                  ApplicationContext ctx
          = null;
                  
                  ctx
          = new ClassPathXmlApplicationContext("applicationContext.xml");
                  
                  Person p  
          = (Person)ctx.getBean("personimp");
                  
                  p.getName(
          "name""pass");

                   
              }


          }

          posted @ 2009-02-13 12:25 Java蜘蛛人 --鄭成橋 閱讀(1125) | 評論 (0)編輯 收藏

               摘要:   關鍵字: spring 事務 (1)配置:     Spring的事務管理是通過AOP代理實現的,其中的事務通知由元數據驅動。代理對象與事務元數據結合產生一個AOP代理,它使用一個PlatformTransactionManager實現,配合TransactionInterceptor,在方法調用前后實施事務。 Java代碼 ...  閱讀全文

          posted @ 2009-02-12 15:30 Java蜘蛛人 --鄭成橋 閱讀(1002) | 評論 (0)編輯 收藏

            Log4j是Apache的一個開放源代碼項目,通過使用Log4j,我們可以控制日志信息輸送的目的地是控制臺、文件、GUI組件、甚至是套接口服務器、NT的事件記錄器、UNIX Syslog守護進程等;我們也可以控制每一條日志的輸出格式;通過定義每一條日志信息的級別,我們能夠更加細致地控制日志的生成過程。最令人感興趣的就是,這些可以通過一個配置文件來靈活地進行配置,而不需要修改應用的代碼。

               如此強大的優越性,實際上手并不難,尤其在spring框架下,使用log4j更是容易,下面介紹一下spring下的log4j應用。
              當然先要下載相應的jar包(log4j.jar)
          首先是web.xml的配置,在web.xml中加入如下配置
             <context-param>
                <param-name>log4jConfigLocation</param-name>
                <param-value>/WEB-INF/props/log4j.properties</param-value>
             </context-param>
             <context-param>
                <param-name>log4jRefreshInterval</param-name>
                <param-value>6000</param-value>
             </context-param>
              <listener>
                <listener-class>
                  org.springframework.web.util.Log4jConfigListener
                </listener-class>
             </listener>

          說明:在上文的配置里,在上文的配置里,Log4jConfigListener會去WEB-INF/props/log4j.propeties 讀取配置文件;開一條watchdog線程每60秒掃描一下配置文件的變化(這樣在web服務啟動后再去修改配置文件也不用重新啟動web服務了);并把web目錄的路徑壓入一個叫webapp.root的系統變量(webapp.root將在log4j.properties文件中使用)。

          接下來是log4j.properties配置文件了,把它放在WEB-INF/props下,具體配置如下:

          #log4j.rootLogger = [ level ] , appenderName, appenderName, ...
          log4j.rootLogger = INFO, console, R
          #level=INFO,all can be output
          #console is set to be a ConsoleAppender
          log4j.appender.console = org.apache.log4j.ConsoleAppender
          #console have four patterns
          #org.apache.log4j.HTMLLayout
          #org.apache.log4j.PatternLayout
          #org.apache.log4j.SimpleLayout
          #org.apache.log4j.TTCCLayout

          log4j.appender.console.layout = org.apache.log4j.PatternLayout
          #define the output type
          log4j.appender.console.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
          #file is set to output to a extra file
          log4j.appender.R = org.apache.log4j.RollingFileAppender
          #the absolute route of the log4j file
          log4j.appender.R.File = /log.txt
          #the size
          log4j.appender.R.MaxFileSize = 500KB
          #back up a file
          log4j.appender.R.MaxBackupIndex = 1
          log4j.appender.R.layout = org.apache.log4j.PatternLayout
          log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] - %m%n

          上面的配置文件說明log信息將以兩種方式輸出(文件和控制臺),表示應用的根目錄下(例如本應用名稱為ABC,則log.txt的位置為tomact\webapp\ABC下)

          最后在程序中想要輸出log的地方加入log4j的支持

          (1)引入   import org.apache.log4j.Logger

          (2)聲明一個logger

          private static Logger logger = Logger.getLogger(ClassName.class);

          (3)在程序中的相應位置加入輸出信息

          logger.info("用戶登錄:"+user.getAccount());

          ok,完成了,當有登錄時會在控制臺和文件中同時輸出log信息如下

          2007-01-10 16:02:54 [com.my.web.UserAction]-[INFO] 用戶登錄:yangsq

          附注(轉):
          以下是配置文件(log4j.properties)的一些重要的語法
          定義配置文件

          其實您也可以完全不使用配置文件,而是在代碼中配置Log4j環境。但是,使用配置文件將使您的應用程序更加靈活。

          Log4j支持兩種配置文件格式,一種是XML格式的文件,一種是Java特性文件(鍵=值)。下面我們介紹使用Java特性文件做為配置文件的方法:

          配置根Logger,其語法為:

          log4j.rootLogger = [ level ] , appenderName, appenderName, …
          其中,level 是日志記錄的優先級,分為OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定義的級別。Log4j建議只使用四個級別,優先級從高到低分別是ERROR、WARN、INFO、DEBUG。通過在這里定義的級別,您可以控制到應用程序中相應級別的日志信息的開關。比如在這里定義了INFO級別,則應用程序中所有DEBUG級別的日志信息將不被打印出來。
          appenderName就是指定日志信息輸出到哪個地方。您可以同時指定多個輸出目的地。

          配置日志信息輸出目的地Appender,其語法為

          log4j.appender.appenderName = fully.qualified.name.of.appender.class
          log4j.appender.appenderName.option1 = value1

          log4j.appender.appenderName.option = valueN
          其中,Log4j提供的appender有以下幾種:
          org.apache.log4j.ConsoleAppender(控制臺),
          org.apache.log4j.FileAppender(文件),
          org.apache.log4j.DailyRollingFileAppender(每天產生一個日志文件),org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件),
          org.apache.log4j.WriterAppender(將日志信息以流格式發送到任意指定的地方)

          配置日志信息的格式(布局),其語法為:

          log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
          log4j.appender.appenderName.layout.option1 = value1

          log4j.appender.appenderName.layout.option = valueN
          其中,Log4j提供的layout有以下幾種:
          org.apache.log4j.HTMLLayout(以HTML表格形式布局),
          org.apache.log4j.PatternLayout(可以靈活地指定布局模式),
          org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串),
          org.apache.log4j.TTCCLayout(包含日志產生的時間、線程、類別等等信息)

          posted @ 2009-02-12 15:16 Java蜘蛛人 --鄭成橋 閱讀(21004) | 評論 (0)編輯 收藏

           

              <bean id="transactionProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"

                  abstract="true">

                 <property name="transactionManager" ref="transactionManager"/>

                 <property name="transactionAttributes">

                     <props>

                        <prop key="insert*">PROPAGATION_REQUIRED</prop>

                        <prop key="update*">PROPAGATION_REQUIRED</prop>

                        <prop key="delete*">PROPAGATION_REQUIRED</prop>

                        <prop key="change*">PROPAGATION_REQUIRED</prop>

                        <prop key="*">PROPAGATION_REQUIRED,readOnly</prop>

                     </props>

                 </property>

              </bean>

          1

          一旦你決定要用 AOP 來做 SERVICE 內部每個方法的事務處理,那么在 DAO 層內部最好不要從自己去 catch 異常,因為在 SERVICE 里面可能多次調用 DAO ,一旦多次調用,你其中一個方法捕獲了異常就沒有辦法保證事務回滾,所以即使你捕獲異常為了調試,一定要在 CATCH 方法中一定還要拋出一個異常來,否則無法保證事務

          2

          一旦決定要用 spring aop 方式來處理事務,一定要不采用 JDOtemplate ,或者 HIBERNATE TEMPALATE 內部類的方式,因為那樣他們自己去管理事務,一旦在內部類中事務回滾,無法保證其他的 DAO 中事務回滾

          3

          1、 PROPAGATION_REQUIRED -- 支持當前的事務,如果不存在就創建一個新的。這是最常用的選擇。
          2 、 PROPAGATION_SUPPORTS -- 支持當前的事務,如果不存在就不使用事務。
          3 、 PROPAGATION_MANDATORY -- 支持當前的事務,如果不存在就拋出異常。
          4 、 PROPAGATION_REQUIRES_NEW -- 創建一個新的事務,并暫停當前的事務(如果存在)。
          5 、 PROPAGATION_NOT_SUPPORTED -- 不使用事務,并暫停當前的事務(如果存在)。
          6 PROPAGATION_NEVER -- 不使用事務,如果當前存在事務就拋出異常。
          7 、 PROPAGATION_NESTED -- 如果當前存在事務就作為嵌入事務執行,否則與 PROPAGATION_REQUIRED 類似。

          4 < prop key="change*">PROPAGATION_REQUIRED</prop>

            你可以在 PROPAGATION_REQUIRE 之后指定拋出什么樣的異常事務才回滾,或者事務的隔離方式是什么等等都可以配置如 <prop key="change*">PROPAGATION_REQUIRED,readOnly,-PetClinicException</prop>

          posted @ 2009-02-12 11:44 Java蜘蛛人 --鄭成橋 閱讀(670) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 策勒县| 大连市| 紫阳县| 吕梁市| 花莲市| 乌什县| 冀州市| 屯昌县| 米林县| 广东省| 汝城县| 衡东县| 吉林省| 绥江县| 汤阴县| 江华| 图们市| 开鲁县| 长白| 闵行区| 潞西市| 新野县| 竹北市| 松桃| 迁安市| 五大连池市| 临安市| 大姚县| 佛学| 集贤县| 吉林省| 承德市| 西丰县| 安国市| 呼和浩特市| 阿拉善盟| 麟游县| 怀集县| 阳江市| 连平县| 阿拉善左旗|