Java蜘蛛人 歡迎大家

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

          2008年3月5日

          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蜘蛛人 --鄭成橋 閱讀(4478) | 評論 (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)編輯 收藏

          1、使用JdbcTemplate的execute()方法執行SQL語句

          代碼
          1. jdbcTemplate.execute("CREATE TABLE USER (user_id integer, name varchar(100))");  

          2、如果是UPDATE或INSERT,可以用update()方法。
          代碼
          1. jdbcTemplate.update("INSERT INTO USER VALUES('"  
          2.             + user.getId() + "', '"  
          3.             + user.getName() + "', '"  
          4.             + user.getSex() + "', '"  
          5.             + user.getAge() + "')");   

          3、帶參數的更新
          代碼
          1. jdbcTemplate.update("UPDATE USER SET name = ? WHERE user_id = ?", new Object[] {name, id});  

          代碼
          1. jdbcTemplate.update("INSERT INTO USER VALUES(?, ?, ?, ?)", new Object[] {user.getId(), user.getName(), user.getSex(), user.getAge()});   

          4、使用JdbcTemplate進行查詢時,使用queryForXXX()等方法
          代碼
          1. int count = jdbcTemplate.queryForInt("SELECT COUNT(*) FROM USER");  

           

           

          代碼
          1. String name = (String) jdbcTemplate.queryForObject("SELECT name FROM USER WHERE user_id = ?", new Object[] {id}, java.lang.String.class);  

           

           

          代碼
          1. List rows = jdbcTemplate.queryForList("SELECT * FROM USER");  

           

           

          代碼
          1. List rows = jdbcTemplate.queryForList("SELECT * FROM USER");   
          2. Iterator it = rows.iterator();   
          3. while(it.hasNext()) {   
          4.      Map userMap = (Map) it.next();   
          5.      System.out.print(userMap.get("user_id") + "\t");   
          6.      System.out.print(userMap.get("name") + "\t");   
          7.      System.out.print(userMap.get("sex") + "\t");   
          8.      System.out.println(userMap.get("age") + "\t");   
          9. }   

           

          JdbcTemplate將我們使用的JDBC的流程封裝起來,包括了異常的捕捉、SQL的執行、查詢結果的轉換等等。spring大量使用Template Method模式來封裝固定流程的動作,XXXTemplate等類別都是基于這種方式的實現。
          除了大量使用Template Method來封裝一些底層的操作細節,spring也大量使用callback方式類回調相關類別的方法以提供JDBC相關類別的功能,使傳統的JDBC的使用者也能清楚了解spring所提供的相關封裝類別方法的使用。

          JDBC的PreparedStatement

          代碼
          1. final String id = user.getId();   
          2. final String name = user.getName();   
          3. final String sex = user.getSex() + "";   
          4. final int age = user.getAge();   
          5.   
          6. jdbcTemplate.update("INSERT INTO USER VALUES(?, ?, ?, ?)",   
          7.                      new PreparedStatementSetter() {   
          8.                          public void setValues(PreparedStatement ps) throws SQLException {   
          9.                               ps.setString(1, id);   
          10.                               ps.setString(2, name);             
          11.                               ps.setString(3, sex);   
          12.                               ps.setInt(4, age);   
          13.                           }   
          14.                       });   
          15.   

           

           

          代碼
          1. final User user = new User();   
          2. jdbcTemplate.query("SELECT * FROM USER WHERE user_id = ?",   
          3.                     new Object[] {id},   
          4.                     new RowCallbackHandler() {   
          5.                         public void processRow(ResultSet rs) throws SQLException {   
          6.                              user.setId(rs.getString("user_id"));   
          7.                              user.setName(rs.getString("name"));   
          8.                              user.setSex(rs.getString("sex").charAt(0));   
          9.                              user.setAge(rs.getInt("age"));   
          10.                          }   
          11.                      });   
          12.   

           

           

          代碼
          1. class UserRowMapper implements RowMapper {   
          2.     public Object mapRow(ResultSet rs, int index) throws SQLException {   
          3.          User user = new User();   
          4.   
          5.          user.setId(rs.getString("user_id"));   
          6.          user.setName(rs.getString("name"));   
          7.          user.setSex(rs.getString("sex").charAt(0));   
          8.          user.setAge(rs.getInt("age"));   
          9.   
          10.         return user;   
          11.      }   
          12. }   
          13.   
          14. public List findAllByRowMapperResultReader() {   
          15.      String sql = "SELECT * FROM USER";   
          16.     return jdbcTemplate.query(sql, new RowMapperResultReader(new UserRowMapper()));   
          17. }   
          18.   

           

          在getUser(id)里面使用UserRowMapper

          代碼
          1. public User getUser(final String id) throws DataAccessException {   
          2.      String sql = "SELECT * FROM USER WHERE user_id=?";   
          3.     final Object[] params = new Object[] { id };   
          4.      List list = jdbcTemplate.query(sql, params, new RowMapperResultReader(new UserRowMapper()));   
          5.   
          6.     return (User) list.get(0);   
          7. }   

           

          網上收集
          org.springframework.jdbc.core.PreparedStatementCreator 返回預編譯SQL 不能于Object[]一起用

          代碼
          1. public PreparedStatement createPreparedStatement(Connection con) throws SQLException {   
          2. return con.prepareStatement(sql);   
          3. }   

          1.增刪改
          org.springframework.jdbc.core.JdbcTemplate 類(必須指定數據源dataSource)
          代碼
          1. template.update("insert into web_person values(?,?,?)",Object[]);   


          代碼
          1. template.update("insert into web_person values(?,?,?)",new PreparedStatementSetter(){ 匿名內部類 只能訪問外部最終局部變量   
          2.   
          3. public void setValues(PreparedStatement ps) throws SQLException {   
          4.    ps.setInt(index++,3);   
          5. });   

          org.springframework.jdbc.core.PreparedStatementSetter 接口 處理預編譯SQL
          代碼
          1. public void setValues(PreparedStatement ps) throws SQLException {   
          2. ps.setInt(index++,3);   
          3. }   

          2.查詢JdbcTemplate.query(String,[Object[]/PreparedStatementSetter],RowMapper/RowCallbackHandler)
          org.springframework.jdbc.core.RowMapper 記錄映射接口 處理結果集
          代碼
          1. public Object mapRow(ResultSet rs, int arg1) throws SQLException {   int表當前行數   
          2.    person.setId(rs.getInt("id"));   
          3. }   
          4. List template.query("select * from web_person where id=?",Object[],RowMapper);   

          org.springframework.jdbc.core.RowCallbackHandler 記錄回調管理器接口 處理結果集
          代碼
          1. template.query("select * from web_person where id=?",Object[],new RowCallbackHandler(){   
          2. public void processRow(ResultSet rs) throws SQLException {   
          3.    person.setId(rs.getInt("id"));   
          4. });

          posted @ 2009-02-06 14:35 Java蜘蛛人 --鄭成橋 閱讀(691) | 評論 (0)編輯 收藏

          >>注意:請下載后面(9樓)的v1.1正式版。如果要優先考慮IE7中的Native XHR,請自己把附件中bajax.js文件里的bajax_object函數替換一下(修改的代碼在9樓的頁面里——不想更新附件了)。

          前一段時間寫51ditu和動易的集成,現在準備改進成Ajax的。很早以前就知道了Ajax,但一直沒有實際用過。
          網上Google了一番,看了Sajax.php……

          還是簡單點好,自己寫了個很小的封裝,測試對瀏覽器的兼容性還不錯,并且回調函數的接口比較友好。

          另:經測試,發現如果是對同一個XMLHttpReques對象進行多次open、send等操作,IE會有Cache問題,Firefox正常。但如果是每一次都是重新new一個的話,IE就支持得很好了(Firefox自然不用說)。

          用這個庫(面向用戶的其實就一個函數),不用考慮XMLHttpRequest的任何細節,就如同調用和定義普通的Js函數。

          <script language="javascript" src="bajax.js"></script>   
          <script language="javascript">   
          function callback(req, id) 
          {   
              
          if(req.readyState == 4 && req.status == 200{   
                  
          if(id)document.getElementById(id).innerHTML = req.responseText;   
                  
          //eval(req.responseText);   
              }
             
          }
             
          </script>   
          <div id="someid"></div>   
          <div onClick="bajax_send('http://xxx.net/yourscript.php?xxx', callback, 'someid')">點擊查看哦!</div>  

          var bajax_debug_enable = false;   
            
          // 主函數:   
          //(URL,回調函數,傳遞給回調函數的附加數據,方法,POST數據,是否異步)   
          function bajax_send(url, callback, fdata, method, sdata, asyn)   
          {   
              fdata 
          = (fdata === undefined)? null: fdata;   
              method 
          = method || "GET";   
              sdata 
          = (sdata === undefined)? null: sdata;   
              asyn 
          = (asyn === undefined)? true: asyn;   
            
              var X 
          = new bajax_object();   
              
          if(asyn)   
                  X.onreadystatechange 
          = function(){ callback(X, fdata); };   
              X.open(method, url, asyn);   
            
              
          if(bajax_debug_enable)   
                  bajax_debugger(callback);   
              X.send(sdata);   
            
              
          if(asyn) return X;   
              
          else callback(X, fdata);   
          }
             
            
          // 兼容IE與其它瀏覽器(From Sajax.php v0.12)   
          function bajax_object()   
          {   
              var A;   
              var _msxmlhttp 
          = new Array(   
                  
          'Msxml2.XMLHTTP.5.0',   
                  
          'Msxml2.XMLHTTP.4.0',   
                  
          'Msxml2.XMLHTTP.3.0',   
                  
          'Msxml2.XMLHTTP',   
                  
          'Microsoft.XMLHTTP');   
              
          for(var i = 0; i < _msxmlhttp.length; i++{   
                  
          try {   
                      
          if(A = new ActiveXObject(_msxmlhttp[i])) break;   
                  }
           catch (e) {   
                      A 
          = null;   
                  }
             
              }
             
              
          if(!&& typeof XMLHttpRequest != "undefined")   
                  A 
          = new XMLHttpRequest();   
              
          if(!A)   
                  alert(
          "Could not create connection object.");   
            
              
          return A;   
          }
             
            
          // Debug information   
          function bajax_debugger(func)   
          {   
              var S 
          = func.toString();   
              alert(
          '[Running] ' + S.slice(9, S.indexOf(')'10)) + ')');   
          }
            


          function callback(req, id)   
          {   
              
          if(req.readyState == 4{   
                  
          if(req.status != 200{   
                      
          // do some thing.   
                      req.onreadystatechange = null;   
                  }
          else{   
                      var _node 
          = document.getElementById(id);   
                      
          if(_node) _node.innerHTML = 'Hai ' + req.responseText;   
            
                      
          // clear the reference   
                      req.onreadystatechange = null;   
                  }
             
              }
             
          }
            
          '


          function callback(req, id) {     
               
          if(req.readyState == 4 && req.status == 200{     
                   var _node 
          = document.getElementById(id);     
                   
          if(_node) _node.innerHTML = 'Hai ' + req.responseText;     
            
          // clear the reference   
                   req.onreadystatechange = null;   
            
               }
               
           }
              

          posted @ 2008-10-23 11:47 Java蜘蛛人 --鄭成橋 閱讀(645) | 評論 (0)編輯 收藏

          首先 順序導入 spring hibernate struts

          配置applicationContet.xml
          <?xml version="1.0" encoding="UTF-8"?>
          <beans
              xmlns
          ="http://www.springframework.org/schema/beans"
              xmlns:xsi
          ="http://www.w3.org/2001/XMLSchema-instance"
              xsi:schemaLocation
          ="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">

              
          <bean id="datasource"
                   
          class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
                  
          <property name="driverClass"
                      value
          ="com.microsoft.jdbc.sqlserver.SQLServerDriver">
                  
          </property>
                  
          <property name="jdbcUrl"
                      value
          ="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=blog;SelectMethod=cursor">
                  
          </property>
                  
          <property name="user" value="sa"></property>
                  
          <property name="password" value="sa"></property>
                  
          <property name="minPoolSize" value="5"></property>
                  
          <property name="maxPoolSize" value="20"></property>
                  
          <property name="acquireIncrement" value="5"></property>
              
          </bean>
              
          <bean id="sessionFactory"
                  
          class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
                  
          <property name="dataSource">
                      
          <ref bean="datasource" />
                  
          </property>
                  
          <property name="hibernateProperties">
                      
          <props>
                          
          <prop key="hibernate.dialect">
                      org.hibernate.dialect.SQLServerDialect 
                          
          </prop>
                          
          <prop key="hibernate.show_sql">true</prop>
                      
          </props>
                  
          </property>

                  
          <property name="mappingDirectoryLocations">
                      
          <list>
                         
          <value>classpath:/com/zcq/dao</value> 
                      
          </list>
                  
          </property>
              
          </bean> 
                 
          <!--  hibernateTemplate 配置 -->
                   
          <bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
                    
          <property name="sessionFactory">
                      
          <ref bean="sessionFactory" />
                    
          </property> 
                   
          </bean>
                
          <!-- zcqbb datable -->
                   
          <bean id="daoimp" class="com.zcq.dao.Test" >
                     
          <property name="hibernateTemplate" ref="hibernateTemplate" /> 
                   
          </bean> 
           
          </beans> 

          然后寫接口


          然后實現接口
          package com.zcq.job.dao;

          import org.springframework.context.ApplicationContext;
          import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

          import com.zcq.job.I.Zcq_I;

          public class Zcq_Imp extends HibernateDaoSupport implements Zcq_I {

              
          public void show() {
                System.out.println(
          "sssssss");
              }

              
          public static Zcq_I getApplication(ApplicationContext ctx)
              
          {
                  
          return (Zcq_I)ctx.getBean("daoimp");
              }

          }


          web.xml 里加入
            <context-param>
              
          <param-name>contextConfigLocation</param-name>
              
          <param-value>/WEB-INF/applicationContext.xml</param-value>
            
          </context-param>
            
          <listener>
              
          <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
            
          </listener>
            
          <filter>
              
          <filter-name>CharacterEncodingFilter</filter-name>
              
          <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
              
          <init-param>
                
          <param-name>encoding</param-name>
                
          <param-value>gbk</param-value>
              
          </init-param>
              
          <init-param>
                
          <param-name>forceEncoding</param-name>
                
          <param-value>true</param-value>
              
          </init-param>
            
          </filter>
            
          <filter-mapping>
              
          <filter-name>CharacterEncodingFilter</filter-name>
              
          <url-pattern>/*</url-pattern>
            </filter-mapping>

          posted @ 2008-08-14 14:52 Java蜘蛛人 --鄭成橋 閱讀(208) | 評論 (0)編輯 收藏

          import  java.io.*; 
           
          public  class  FileOperate  { 
             public  FileOperate()  { 
             } 
           
             /** 
               *  新建目錄 
               *  @param  folderPath  String  如  c:/fqf 
               *  @return  boolean 
               */ 
             public  void  newFolder(String  folderPath)  { 
                 try  { 
                     String  filePath  =  folderPath; 
                     filePath  =  filePath.toString(); 
                     java.io.File  myFilePath  =  new  java.io.File(filePath); 
                     if  (!myFilePath.exists())  { 
                         myFilePath.mkdir(); 
                     } 
                 } 
                 catch  (Exception  e)  { 
                     System.out.println("新建目錄操作出錯"); 
                     e.printStackTrace(); 
                 } 
             } 
           
             /** 
               *  新建文件 
               *  @param  filePathAndName  String  文件路徑及名稱  如c:/fqf.txt 
               *  @param  fileContent  String  文件內容 
               *  @return  boolean 
               */ 
             public  void  newFile(String  filePathAndName,  String  fileContent)  { 
           
                 try  { 
                     String  filePath  =  filePathAndName; 
                     filePath  =  filePath.toString(); 
                     File  myFilePath  =  new  File(filePath); 
                     if  (!myFilePath.exists())  { 
                         myFilePath.createNewFile(); 
                     } 
                     FileWriter  resultFile  =  new  FileWriter(myFilePath); 
                     PrintWriter  myFile  =  new  PrintWriter(resultFile); 
                     String  strContent  =  fileContent; 
                     myFile.println(strContent); 
                     resultFile.close(); 
           
                 } 
                 catch  (Exception  e)  { 
                     System.out.println("新建目錄操作出錯"); 
                     e.printStackTrace(); 
           
                 } 
           
             } 
           
             /** 
               *  刪除文件 
               *  @param  filePathAndName  String  文件路徑及名稱  如c:/fqf.txt 
               *  @param  fileContent  String 
               *  @return  boolean 
               */ 
             public  void  delFile(String  filePathAndName)  { 
                 try  { 
                     String  filePath  =  filePathAndName; 
                     filePath  =  filePath.toString(); 
                     java.io.File  myDelFile  =  new  java.io.File(filePath); 
                     myDelFile.delete(); 
           
                 } 
                 catch  (Exception  e)  { 
                     System.out.println("刪除文件操作出錯"); 
                     e.printStackTrace(); 
           
                 } 
           
             } 
           
             /** 
               *  刪除文件夾 
               *  @param  filePathAndName  String  文件夾路徑及名稱  如c:/fqf 
               *  @param  fileContent  String 
               *  @return  boolean 
               */ 
             public  void  delFolder(String  folderPath)  { 
                 try  { 
                     delAllFile(folderPath);  //刪除完里面所有內容 
                     String  filePath  =  folderPath; 
                     filePath  =  filePath.toString(); 
                     java.io.File  myFilePath  =  new  java.io.File(filePath); 
                     myFilePath.delete();  //刪除空文件夾 
           
                 } 
                 catch  (Exception  e)  { 
                     System.out.println("刪除文件夾操作出錯"); 
                     e.printStackTrace(); 
           
                 } 
           
             } 
           
             /** 
               *  刪除文件夾里面的所有文件 
               *  @param  path  String  文件夾路徑  如  c:/fqf 
               */ 
             public  void  delAllFile(String  path)  { 
                 File  file  =  new  File(path); 
                 if  (!file.exists())  { 
                     return; 
                 } 
                 if  (!file.isDirectory())  { 
                     return; 
                 } 
                 String[]  tempList  =  file.list(); 
                 File  temp  =  null; 
                 for  (int  i  =  0;  i  <  tempList.length;  i++)  { 
                     if  (path.endsWith(File.separator))  { 
                         temp  =  new  File(path  +  tempList[i]); 
                     } 
                     else  { 
                         temp  =  new  File(path  +  File.separator  +  tempList[i]); 
                     } 
                     if  (temp.isFile())  { 
                         temp.delete(); 
                     } 
                     if  (temp.isDirectory())  { 
                         delAllFile(path+"/"+  tempList[i]);//先刪除文件夾里面的文件 
                         delFolder(path+"/"+  tempList[i]);//再刪除空文件夾 
                     } 
                 } 
             } 
           
             /** 
               *  復制單個文件 
               *  @param  oldPath  String  原文件路徑  如:c:/fqf.txt 
               *  @param  newPath  String  復制后路徑  如:f:/fqf.txt 
               *  @return  boolean 
               */ 
             public  void  copyFile(String  oldPath,  String  newPath)  { 
                 try  { 
                     int  bytesum  =  0; 
                     int  byteread  =  0; 
                     File  oldfile  =  new  File(oldPath); 
                     if  (oldfile.exists())  {  //文件存在時 
                         InputStream  inStream  =  new  FileInputStream(oldPath);  //讀入原文件 
                         FileOutputStream  fs  =  new  FileOutputStream(newPath); 
                         byte[]  buffer  =  new  byte[1444]; 
                         int  length; 
                         while  (  (byteread  =  inStream.read(buffer))  !=  -1)  { 
                             bytesum  +=  byteread;  //字節數  文件大小 
                             System.out.println(bytesum); 
                             fs.write(buffer,  0,  byteread); 
                         } 
                         inStream.close(); 
                     } 
                 } 
                 catch  (Exception  e)  { 
                     System.out.println("復制單個文件操作出錯"); 
                     e.printStackTrace(); 
           
                 } 
           
             } 
           
             /** 
               *  復制整個文件夾內容 
               *  @param  oldPath  String  原文件路徑  如:c:/fqf 
               *  @param  newPath  String  復制后路徑  如:f:/fqf/ff 
               *  @return  boolean 
               */ 
             public  void  copyFolder(String  oldPath,  String  newPath)  { 
           
                 try  { 
                     (new  File(newPath)).mkdirs();  //如果文件夾不存在  則建立新文件夾 
                     File  a=new  File(oldPath); 
                     String[]  file=a.list(); 
                     File  temp=null; 
                     for  (int  i  =  0;  i  <  file.length;  i++)  { 
                         if(oldPath.endsWith(File.separator)){ 
                             temp=new  File(oldPath+file[i]); 
                         } 
                         else{ 
                             temp=new  File(oldPath+File.separator+file[i]); 
                         } 
           
                         if(temp.isFile()){ 
                             FileInputStream  input  =  new  FileInputStream(temp); 
                             FileOutputStream  output  =  new  FileOutputStream(newPath  +  "/"  + 
                                     (temp.getName()).toString()); 
                             byte[]  b  =  new  byte[1024  *  5]; 
                             int  len; 
                             while  (  (len  =  input.read(b))  !=  -1)  { 
                                 output.write(b,  0,  len); 
                             } 
                             output.flush(); 
                             output.close(); 
                             input.close(); 
                         } 
                         if(temp.isDirectory()){//如果是子文件夾 
                             copyFolder(oldPath+"/"+file[i],newPath+"/"+file[i]); 
                         } 
                     } 
                 } 
                 catch  (Exception  e)  { 
                     System.out.println("復制整個文件夾內容操作出錯"); 
                     e.printStackTrace(); 
           
                 } 
           
             } 
           
             /** 
               *  移動文件到指定目錄 
               *  @param  oldPath  String  如:c:/fqf.txt 
               *  @param  newPath  String  如:d:/fqf.txt 
               */ 
             public  void  moveFile(String  oldPath,  String  newPath)  { 
                 copyFile(oldPath,  newPath); 
                 delFile(oldPath); 
           
             } 
           
             /** 
               *  移動文件到指定目錄 
               *  @param  oldPath  String  如:c:/fqf.txt 
               *  @param  newPath  String  如:d:/fqf.txt 
               */ 
             public  void  moveFolder(String  oldPath,  String  newPath)  { 
                 copyFolder(oldPath,  newPath); 
                 delFolder(oldPath); 
           
             } 
          }

          posted @ 2008-07-01 16:51 Java蜘蛛人 --鄭成橋 閱讀(2783) | 評論 (0)編輯 收藏

               摘要: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  <head>  <html&g...  閱讀全文

          posted @ 2008-03-13 19:54 Java蜘蛛人 --鄭成橋 閱讀(954) | 評論 (1)編輯 收藏

          <?xml version="1.0" encoding="UTF-8"?>
          <beans
              xmlns
          ="http://www.springframework.org/schema/beans"
              xmlns:xsi
          ="http://www.w3.org/2001/XMLSchema-instance"
              xsi:schemaLocation
          ="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">



          <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
          <property name="basename" value="messages"></property>

           
          </bean>

          </beans>
          import java.util.Date;
          import java.util.Locale;

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

          public class TestBean {
              
              
          public static void main(String[] args) {
                  
                  ApplicationContext context
          =null;
                  
                  context
          =new ClassPathXmlApplicationContext("guojihua.xml");
                  Object[] a
          =new Object[]{"鄭成橋",new Date()};
              System.out.println(context.getMessage(
          "user", a,Locale.SIMPLIFIED_CHINESE));
                  
              }

          }


          上面Object[] 里面的user 是國際化里的配置的
          user=\u6B22\u8FCE{0},\u7684\u5230\u6765\u73B0\u5728\u662F{1}

          如果看不懂 ,  就直接加我的 QQ 問吧...

          posted @ 2008-03-05 18:09 Java蜘蛛人 --鄭成橋 閱讀(1337) | 評論 (1)編輯 收藏

          主站蜘蛛池模板: 车致| 香格里拉县| 琼海市| 宜兴市| 巴塘县| 玉溪市| 平定县| 杭州市| 磐安县| 苍山县| 栾川县| 西峡县| 嘉善县| 宁晋县| 嘉黎县| 长汀县| 邢台市| 茌平县| 望江县| 延川县| 监利县| 高清| 克什克腾旗| 缙云县| 特克斯县| 厦门市| 仙桃市| 安塞县| 林口县| 四川省| 紫金县| 习水县| 贡嘎县| 博白县| 永善县| 星子县| 当涂县| 博客| 巴中市| 安化县| 垣曲县|