<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 22,comments - 35,trackbacks - 0


        String root = getServletContext().getRealPath("/");
        String path 
    = request.getParameter("path");
        String name 
    = request.getParameter("name");


        response.setContentType(
    "unknown");
        response.addHeader(
    "Content-Disposition""filename=\"" + name + "\"");


        
    try
        
    {
            java.io.OutputStream    os  
    = response.getOutputStream();
            java.io.FileInputStream fis 
    = new java.io.FileInputStream(root + path + name);


            
    byte[] b = new byte[1024];
            
    int    i = 0;


            
    while ( (i = fis.read(b)) > 0 ) 
            
    {
                os.write(b, 
    0, i);
            }



            fis.close();
            os.flush();
            os.close();
        }

        
    catch ( Exception e )
        
    {
        }
    posted @ 2006-02-16 12:21 kelven 閱讀(1981) | 評論 (1)編輯 收藏
    諾基亞手機限制碼-1234
      保密碼 -12345
      *#06#:看手機序列號?! ?BR>  *#2820# :看蘭牙版本信息,需要先將藍牙設置為打開狀態。
      *#92702689# :這個也是大家常用的一條命令,用來查看系統信息。
      *#335738#:刪除Email, GPRS, MMS的設置信息
      *#7370925538#:刪除電子錢包的內容和 密碼 ,這個比較實用,要是忘記了,你既可以用這個命令,也可以 恢復出廠 設置,不過這個更實用。
      *#7370#:軟件格式化。刪除存儲空間的內容。
      *#7780#:一個 恢復出廠 設置的快捷操作。
      *#7220#:恢復一些功能
        *#92702689#LIFE:查系統版本
        *#0000#:查系統版本

    以上是一些NOKIA機型的查詢指令,不一定適合所有的NOKIA機型,但是基本上都可以使用。
    posted @ 2006-02-09 12:35 kelven 閱讀(1064) | 評論 (0)編輯 收藏
    下載地址:http://download.17hk.com/soft.asp?softid=44   (21.6M)
                        http://www.it1848.com/Soft/cyrjxz/yyrjxz/200510/Soft_20051014114011.html (46.4M)

    (WindowsXP SP2系統上SQLServer2000必須要安裝SP3之后的補丁才能正常使用)

    由于SQL Server Service Packs按照累積形式進行組織,因此,SP3包含了先期發布的 Service Pack 1(SP1)與 Service Pack 2(SP2)中的所有修正程序,它既可應用于全新安裝的系統,也可在已經安裝SP1或SP2的系統上加以應用。

      優勢
      除提供最新更新內容與修正程序外,SQL Server 2000 SP3還能夠為您提供以下優勢:

      可維護性
      在可維護性方面的改進包括:
    得以增強的錯誤報告功能。通過適當配置,SQL Server能夠將關鍵性錯誤信息自動發送至Microsoft公司。
      得以改進的多服務器管理功能。
      用于實現監控的新增API。數據庫管理員(DBA)或第三方工具可以對出現問題的進程加以診斷
      性能
      SP3引入了針對QLogic’s VI-enabled SANblade QLA2350 Fibre Channel控制器的支持能力。通過在SQL Server網絡互連層上應用虛擬接口(Virtual Interface)技術,在服務器和客戶端系統上針對每條消息所消耗的CPU資源得以顯著降低,同時,系統整體性能得到了相應提高。
      安全性
      最新提供的安全特性與工具包括:
      針對SQL Server 2000在線圖書的內容更新。SQL Server 2000在線圖書為廣大客戶提供了用以進一步增強應用環境安全性所需的更多指導信息。
      安全修補程序。SP3針對用戶反映或在持續測試過程中發現的各種已知薄弱環節提供了相應的修復程序。
      SQL Server Agent增強。SP3允許您在不具備管理員權限的情況下運行SQL Server Agent。
    posted @ 2006-01-17 01:37 kelven 閱讀(3222) | 評論 (1)編輯 收藏
        現在多數host裝的還是MySQL 4.0x 版本以下,如果升級到了4.1x 或者移動到使用4.1x 的主機上,估計會遇到一些問題。我在這上面遇到了兩個問題。
        一是數據導入。在phpMyAdmin內導入后,發現中文變成了亂碼。搜索學習后,了解到需要設置數據庫的collation (???,如果你的數據庫是utf-8的,設置為utf8_general_ci就可以了。
        二是,即使正確導入了,在phpMyAdmin里也能正確顯示,但頁面上顯示的文章內容都是“???”,而模板里面的漢字都能正常顯示。這讓我頭疼了很久。搜索到Windix’s Weblog上有對此的說明:
        “從MySQL 4.1開始引入的多語言支持確實很棒,而且一些特性已經超過了其他的數據庫系統。不過我在測試過程中發現使用適用于MySQL 4.1之前的PHP語句操作MySQL數據庫會造成亂碼,即使是設置過了表字符集也是如此。我讀了一下新的MySQL在線手冊中第十章‘Character Set Support’后終于找到了解決方法并測試通過。MySQL 4.1的字符集支持(Character Set Support)有兩個方面:字符集(Character set)和排序方式(Collation)。對于字符集的支持細化到四個層次: 服務器(server),數據庫(database),數據表(table)和連接(connection)。當我們按照原來的方式通過PHP存取MySQL數據庫時,就算設置了表的默認字符集為utf8并且通過UTF-8編碼發送查詢,你會發現存入數據庫的仍然是亂碼。問題就出在這個connection連接層上。解決方法是在發送查詢前執行一下下面這句:
    SET NAMES ‘utf8′;”
        但是我依舊不知道,如何,在何處讓WordPress運行這個SQL語句。后來在阿修的部落格上查到辦法:
      “為著解決這個問題必須去修改wp-includes/wp-db.php內的資料連線設定。詳細的修改方式是這樣的:
    $this->dbh = @mysql_connect($dbhost,$dbuser,$dbpassword);
    //加上下面這行
    $this->query(”SET NAMES ‘utf8′”);”
    這樣子終于能正常顯示中文的WordPress了。雖然后來還是沒用,但是覺得這個經驗會對別人有用。記得有人用email和我討論過這樣子的中文顯示問題,但是我那時哪里知道問題出在MySQL 4.1x上。
    還有,4.1x的數據庫不向下兼容,所以升級的時候要三思啊。
    posted @ 2006-01-01 08:02 kelven 閱讀(457) | 評論 (0)編輯 收藏
    (此為個人學習心得,以后會逐漸完善)

    (本例使用的數據庫是:MySql)

    1.當你用流讀取文件或者從數據庫讀取數據時,取得的字符串的編碼要與頁面的一致,否則會亂碼

    例如:

    public class FileOperation {

        
    //path為文件的全路徑
        public static String readFile(String path){
            String templateContent
    ="";
            
    try{
                BufferedReader br
    =new BufferedReader(new FileReader(path));
                String temp
    =null;
                
    while((temp=br.readLine())!=null){
                    templateContent
    =templateContent+temp+"\n";
                }

                br.close();
            }

            
    catch(Exception e){
                System.out.println(
    "讀取文件出錯");
                e.printStackTrace();
            }

            
            
    return templateContent;
        }

    }


    (假設頁面的編碼為UTF-8)

    調用以上函數只需要傳遞一個完整的文件路徑就可以以字符串的形式讀取文件.

    ......

    String str
    =FileOperation.readFile("d:\11.txt");

    ......

    request.setAttribute("str",str);

    ......

    則頁面用requset.getAttribute("str")取得的中文字符將會是亂碼.

    解決方案:

    將上段取中文字符串的代碼改成:



    String str
    =new String(FileOperation.readFile("d:\11.txt").getBytes("UTF-8"));



    request.setAttribute(
    "str",str);




    posted @ 2005-12-28 16:16 kelven 閱讀(537) | 評論 (0)編輯 收藏
    Resin的確是比較狠的應用服務器,運行速度快,配置又簡單!這里介紹一下Resin2.1.12的數據庫連接池配置方法。

    在%ResinHome%/conf/resin.conf中找到
    <!--
    - Sample database pool configuration
    - The JDBC name is java:comp/env/jdbc/test
    -->
    在其下加入相應的信息可以連接到不同的數據庫。

    Mysql:
    <resource-ref>
    <res-ref-name>jdbc/blog</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <init-param driver-name="com.caucho.jdbc.mysql.Driver"/>
    <init-param url="jdbc:mysql_caucho://localhost:3306/blog"/>
    <init-param user="root"/>
    <init-param password="****"/>
    <init-param max-connections="20"/>
    <init-param max-idle-time="30"/>
    </resource-ref>

    將相應的驅動放到%Resin/lib/%下。

    MS-Sql:
    <resource-ref>
    <res-ref-name>jdbc/blog</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <init-param driver-name="com.microsoft.jdbc.sqlserver.SQLServerDriver"/>
    <init-param url="jdbc:microsoft:sqlserver://localhost:1433;databaseName=blog"/>
    <init-param user="sa"/>
    <init-param password="****"/>
    <init-param max-connections="20"/>
    <init-param max-idle-time="30"/>
    </resource-ref>
    首先要下載安裝sqlserver-jdbc-驅動,然后將其lib下的三個jar文件放到%Resin/lib/%下。
    posted @ 2005-12-16 12:58 kelven 閱讀(593) | 評論 (0)編輯 收藏

    Servlet的演變:在常規的 JSP,Servlet,JavaBean三層結構中,JSP實現View的功能,Servlet實現Controller的功能,JavaBean實現Model的實現。

    在Struts中,將常規情況下的Servlet拆分與ActionServlet、FormBean、ActionBean三個部分。ActionServlet配合Struts-config.xml,專職完成頁面導航,而不再負責具體的數據獲取與相應邏輯,這兩部分功能由FormBean和ActionBean來完成。

    Struts的核心是Controller,即ActionServlet,而ActionServlet的核心就是Struts-config.xml,Struts-config.xml集中了所有頁面的導航定義。對于大型的WEB項目,通過此配置文件即可迅速把握其脈絡,這不管是對于前期的開發,還是后期的維護或升級都是大有裨益的。掌握Struts-config.xml是掌握Struts的關鍵所在。

    <struts-config>

       <data-sources />

       <form-beans >
          <form-bean name="systemForm" type="com.gdglc.survey.form.SystemForm" />
          <form-bean name="FindMemberForm" type="org.apache.struts.validator.DynaValidatorForm">
             <form-property name="findName" type="java.lang.String"/>
          </form-bean>
       </form-beans>

       <global-exceptions />

       <global-forwards>
          <forward name="showMsg" path="/msg.jsp" />
       </global-forwards>

       <action-mappings>

          <action 
             path="/list" 
             type="com.gdglc.survey.action.ListAction">
             <forward name="list" path="/list.jsp"/>
          </action>

          <action
             attribute="systemForm"
             input="/admin/System_Base_List.jsp"
             name="systemForm"
             path="/systemBaseModify"
             type="com.gdglc.survey.action.SystemAction"
             scope="request"
             validate="false">
          </action>

       </action-mappings>

       <message-resources parameter="com.gdglc.application" />
      
       <plug-in className="org.apache.struts.validator.ValidatorPlugIn">
          <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml"/>
       </plug-in>

    </struts-config>

    每一個FormBean 都必須繼承ActionForm類,FormBean是對頁面請求的封裝。即把HTTP request 封裝在一個對象中,需要說明的一點就是多個HTTP request可以共用一個FormBean,便于維護和重用。


    public final class RegUserForm extends ActionForm{

       private String logname;
       private String password;
       private String email;

       public RegUserForm(){
          logname = null;
          password = null;
          email = null;
       }

       ......

       public void reset(ActionMapping mapping, HttpServletRequest request)
       {
          logname = null;
          password = null;
          email = null;
       }

       public ActionErrors validate(ActionMapping mapping,HttpServletRequest request) 
       {
          ActionErrors errors=new ActionErrors();
          if(this.password==null)
             errors.add(ActionErrors.GLOBAL_ERROR,new ActionError("password is null!!"));
          ......
          return errors;
        }
    }

    FormBean的產生是為了提供數據給ActionBean,在ActionBean中可以取得FormBean中封裝的數據,經相應的邏輯處理后,調用業務方法完成相應業務要求。

    public final class RegUserAction extends Action
    {
       public ActionForward execute(ActionMapping mapping,
                                                      ActionForm form, 
                                                      HttpServletRequest request,
                                                      HttpServletResponse response)

       {
          ......
          if(true)
             return mapping.findForwad("list");
          else {
             ActionErrors errors=new ActionErrors();
             errors.add(ActionErrors.GLOBAL_ERROR,new ActionError("...."));
             this.saveErrors(request,errors);
             return new ActionForward(mapping.getInput());
          }
       }
    }

    Struts優缺點
    優點:


    Struts跟Tomcat、Turbine等諸多Apache項目一樣,是開源軟件,這是它的一大優點。使開發者能更深入的了解其內部實現機制。

    除此之外,Struts的優點主要集中體現在兩個方面:Taglib和頁面導航。Taglib是Struts的標記庫,靈活動用,能大大提高開發效率。另外,就目前國內的JSP開發者而言,除了使用JSP自帶的常用標記外,很少開發自己的標記,或許Struts是一個很好的起點。

    關于頁面導航,我認為那將是今后的一個發展方向,事實上,這樣做,使系統的脈絡更加清晰。通過一個配置文件,即可把握整個系統各部分之間的聯系,這對于后期的維護有著莫大的好處。尤其是當另一批開發者接手這個項目時,這種優勢體現得更加明顯。

    缺點:

    Taglib是Struts的一大優勢,但對于初學者而言,卻需要一個持續學習的過程,甚至還會打亂你網頁編寫的習慣,但是,當你習慣了它時,你會覺得它真的很棒。

    Struts將MVC的Controller一分為三,在獲得結構更加清晰的同時,也增加了系統的復雜度。

    Struts從產生到現在還不到半年,但已逐步越來越多運用于商業軟件。雖然它現在還有不少缺點,但它是一種非常優秀的J2EE MVC實現方式,如果你的系統準備采用J2EE MVC架構,那么,不妨考慮一下Struts。

    Struts實施經驗:

    1)、基于Struts架構的項目開發,首先需要有一個很好的整體規劃,整個系統中包括哪幾個模塊,每個模塊各需要多少FormBean和ActionBean等,而且最好有專人負責Struts-config.xml的管理。開發基于Struts的項目的難點在于配置管理,尤其是對Struts-config.xml的管理。

    2)、如果你的項目非常緊,并且項目組中又沒有富有經驗的Struts開發人員,建議不要冒然采用Struts。Struts的掌握需要一個過程,對于一個熟練的JSP程序員,自學大概需要半個月左右的時間。如果結合titls,則需要更長的時間。

    3)、如果你在網頁中大量運用taglib,那么你的美工將做出部分犧牲。當你結合Tiles,功能增強的同時,這種犧牲尤為明顯。當然,你對功能和美觀的取舍由你自己決定。

    4)、Taglib是一個好東西,但靈活運用它卻需要一個過程,如果你不想在Taglib上花太多的時間,那么只需理解與FORM有關的幾個標記,其它的標記就放著吧,以后再看,先去研究ActionServlet和Struts-config.xml,你會覺得很有成就感。

    5)、Struts是否只適合于大型項目呢?No!Struts適合于各種大小的項目,當然,對于大型項目,它所體現出來的優勢更加明顯。

    http://www.chinaitlab.com/www/news/article_show.asp?id=33092
    posted @ 2005-12-15 13:33 kelven 閱讀(838) | 評論 (0)編輯 收藏
    Resin使用簡介

    使用Resin開發Java Web項目時,需要建立自己的WebApp。這里不介紹Resin Cmp/Ejb的開發和使用,只介紹用Resin開發普通的jsp\java servlet項目。在這里還要談到resin.conf的配置。Resin中的應用可以有2種方式發布:一是在Resin的目錄下發布;二是打包成War發布。

    1、在Resin的目錄下發布

    在resin.conf中查找<web-app>標簽,該標簽表示一個web應用。

    標簽中,id屬性表示該應用的Web路徑。如<web-app id=’/test’>,表示該應用在Web上訪問的時候應該用http://hostname/test/來訪問。app-dir屬性表示該應用的實際路徑。如<app-dir>d:\resin\doc\test</app-dir>表示該應用在d:\resin\doc\test目錄下面。默認值為根下面的和id同名的目錄。Resin可以配置3種error-page:404錯誤也就是文件找不到錯誤頁;Exception違例頁;不能連接java引擎頁。他們分別可以這樣子設置。

    404文件找不到頁

    <web-app id='/app1'>

    <error-page error-code='404' location='/file_not_found.jsp'/>

    </web-app>

    Exception 違例頁

    <web-app id='/foo'>

    <error-page exception-type='java.lang.NullPointerException'

    location='/nullpointer.jsp'/>

    </web-app>

    不能連接到srun Servlet引擎錯誤頁

    該頁設置和應用無關,屬于服務器的設置。

    <http-server>

    <error-page exception-type='connection'

    location='/missing_file.html'/>

    </http-server>

    classpath的設置

    參見下面的語句:

    <classpath id='WEB-INF/classes' source='WEB-INF/src' compile='true'/>

    id參數的值表示classpath中編譯后的classpath的存放路徑;source參數的值表示classpath中java源代碼的存放路徑;compile中的值可能是true或者false,表示是否由Resin的srun自動編譯java源代碼。Classpath的設置一般和javaBean或者Servlet的使用有關。id的值表示javaBean的編譯好的包存放的根,source的值表示javaBean的java源代碼存放的根。Servlet相同。

    Servlet的設置

    參見下面的語句:

    <servlet-mapping url-pattern='*.xtp' servlet-name='xtp'/>

    <servlet-mapping url-pattern='*.jsp' servlet-name='jsp'/>

    <servlet-mapping url-pattern='/servlet/*' servlet-name='invoker'/>

    一般就是指定那些需要通過srun的解析。比如在這里,把*.jsp改成*.jss,其他不變,那么只要在訪問時遇到*.jss的文件就和原來遇到*.jsp一樣處理。通過這個可以指定解析的引擎,如以下的配置:

    <servlet-mapping url-pattern='*.xtp' servlet-name='com.caucho.jsp.XtpServlet'/>

    在Servlet中,也可以指定servlet。如

    <servlet servlet-name='hello' servlet-class='test.HelloWorld'/>

    <servlet-mapping url-pattern='/hello.html' servlet-name='hello'/>

    在servlet-mapping中有個重要的參數case-sensitive 如果在windows上,最好配置成false,忽略大小寫,從而和windows的約定一致。

    Session的配置

    參見如下的配置語句:

    <session-config>

    <session-max>4096</session-max>

    <session-timeout>30</session-timeout>

    <enable-cookies>true</enable-cookies>

    <enable-url-rewriting>true</enable-url-rewriting>

    <file-store>WEB-INF/sessions</file-store>

    </session-config>

    session-max :最大 session數量

    session-timeout :session過期時間,以分鐘為單位。

    是否允許cookie :指session是否采用cookies。如果采用cookies,瀏覽器必須支持session才能使用,發布時建議改成false。enable-url-rewriting和enable-cookies一般配合使用。如果enable-cookies是false,enable-url-rewriting應該設成true比較合適。

    file-store :該配置指示服務器是否把session作為文件存放在服務器上。如果把該項注釋掉,則在你的web-app目錄下的WEB-Inf/sessions目錄不保存序列化后的session對象。Session還有jdbc-store配置,對應著把session通過jdbc永久保存在數據庫中。其實也就是會話變量的序列化后的保存和重新載入的物理實現。在這里session還支持了多服務器的設置問題,

    通過tcp-store參數設置。由于涉及到負載平衡的問題,在這里不詳細敘述,只簡單寫一個例子:

    <http-server>

    <http id='a' port='80'/>

    <srun id='a' host='host-a' port='6802'/>

    <http id='b' port='80'/>

    <srun id='b' host='host-b' port='6802'/>

    <host id=''>

    <web-app id=''>

    <session-config>

    <tcp-store/>

    <always-load-session/>

    </session-config>

    </web-app>

    </host>

    </http-server>

    這個例子表示session是按照tcp ring的方式傳遞。

    temp-dir 的設置

    temp-dir指的是應用的臨時目錄。也就是在javax.servlet.context.tempdir中用到的目錄。模認是應用目錄下的WEB-INF\tmp目錄。

    以上的設置都可以在<web-app>標簽對中設置,控制某個web應用的設置。

    2、打包成War發布

    以下是介紹對如何在resin下使用已經打包成War的java Web應用進行發布。

    其實這個是最簡單也是最清晰的良好方法。在j2ee中,所有的項目都打包成ear發布。其中,Web應用打包成war,ejb應用打包成jar。在resin中,這些都可以直接部署。這里我只對打包成war的Web應用的部署做介紹。

    在resin.conf中,查找這個:<war-dir id='webapps'/>。他表示war文件應該被拷貝的路徑。這里指的是相對于resin的安裝路徑,如以上的設置表示d:\resin\webapps。只要重新啟動Resin就可以了。Resin會把該war自動解包到webapps目錄下。你可以在command控制臺或者stdout.log中看到類似于

    [2002-04-27 09:56:21.680] initializing application http://haitaiserver:8080/rwtest 的語句。這個表示該Web應用是自動安裝的。只要這個應用是符合j2ee標準的Web應用,應該不會有問題。通過如上顯示的路徑就可以訪問到這個應用。如果你到d:\resin\webapps\rwtest中瀏覽,你會看到Resin已經為你生成了rwtest目錄,下面是META-INF和WEB-INF還有你自己的JSP\servlet 文件和目錄。是完全符合j2ee的結構的。你可以在rwtest目錄下建立新的jsp\servlet,一樣可以被編譯和解析并運行的。在實際操作中,可以使用Jbuilder 或者 WebSphere等Ide工具進行集成調試和打包,非常的方便。

    使用Resin進行java Web項目的開發和調試

    這里篇幅有限,不可能講太多,我只對實際中最有用的部分做介紹。

    Resin中如果定義了錯誤頁,則出錯后最常見的一大串Exception不會被看到,直接跳轉到錯誤頁。所以建議開發中先不設置錯誤頁。jsp錯誤中最常見的就是Nullpoint Exception,其次是名稱的拼寫錯誤。錯誤也可以在Resin安裝目錄下的log目錄下的stderr.log中找到。通過對該log文件的分析可以看到很多有用的錯誤信息。

    在調試jsp的時候,如果定義了compile為true,jsp先被翻譯成Servlet的java文件,再被編譯成class文件。可以在你自己的work目錄中找到該文件。java的名稱在Resin中是這樣子定義的:原先的jsp文件名前加下劃線,再加上_jsp這個字樣。所以在java 應用中的命名不要以_jsp結尾,也不要出現中文名稱等字符;其實名稱以_jsp為開頭也是不合法的。

    關于java對多國語言的支持問題,在Resin中得到了很好的解決。以jsp為例,參考Resin自動生成的java Servlet文件。只要在任何的jsp文件的最開始處增加:

    <%@page contentType="text/html;charset=gb2312" %>

    中文問題就解決了。察看生成的Servlet源文件片斷:

    response.setContentType("text/html;charset=gb2312");

    request.setCharacterEncoding("GB2312");

    以上為設置字符集

    private static byte []_jsp_string26;

    private static byte []_jsp_string27;

    _jsp_string26 = "\r\n</table>\r\n<table class=\"type\">\r\n<tr>\r\n <td>".getBytes("GB2312");

    _jsp_string27 = "\r\n</td><td>\r\n</tr>\r\n<!--\r\n<tr>\r\n<td>\r\".getBytes("GB2312");

    以上是對頁面的顯示的編碼。其中,getBytes(“gb2312”)是靜態編碼,這是Resin為了解決某些環境下還是不能正常顯示而設置的。在Resin的配置文件(/conf/resin.conf)中,可以通過設置<jsp precompile='true' static-encoding='false' recompile-on-error='true'/>中的static-encoding屬性為true或者false,來控制是否靜態編碼。其實在Resin容器的內部,所有的字符都是按照iso-8859-1來處理的。iso-8859-1是一個大字符集,雖然中文的gb2312和8859在字的定義上有不同,但是編碼是包容了gb2312的。按照解決多國語言的方法,在純英文平臺上用iso-8859-1處理內部編碼,而把字符的顯示推向客戶端的機器。所以這樣只要編碼是正確的,

    在頁面上顯示中文就不存在問題。Tomcat3.2不方便的地方是Tomcat對數據庫的操作中文支持不好,需要手動在java Bean或者Servlet中硬編碼。通過測試,在Resin中完全沒有這個問題。Tomcat4.0解決了這個問題。不過個人習慣來講還是覺得resin在配置方面方便一些。

    在Resin中可以自動解決引入的jar。這個在使用特殊的類或者第三方提供的開發包非常有用。方法非常簡單:只要把該jar或者是zip拷貝到Resin安裝目錄下的lib目錄下面,重新啟動Resin,就可以了。如db2用到的db2java.zip文件,只要輕松拷貝到d:\resin\lib中就可以了。

    Resin提供了對Jbuilder的集成調試??梢缘剑?/P>

    http://www.caucho.com/projects/jbuilder/resin-jbuilder.jar免費下載到resin的jbuilder的ide擴展包。然后,把該包該名成:resin-jbuilder.jar,拷貝到jbuilder6\lib\ext目錄下。然后,把Resin2.1解包安裝在jbuilder6\resin-2.1目錄下,就可以了。打開任何的War項目,在project上點右鍵,選擇properties,選擇Servers標簽。在原來的選擇框上,就可以看到多了一項Resin2.1。這樣子就可以象原來用tomcat一樣調試jsp\servlet了,而且比Tomcat更方便。見圖2:

    圖2

    調試方法和用Tomcat調試一樣。

    其他問題

    使用Resin可以和apache結合使用。也就是利用apache做http服務器,而Resin做srun服務器??梢詤⒖紃esin\conf\samples目錄下的apache.conf。主要就是把 app-dir 設成 /usr/local/apache/htdocs(也就是apache的root)。同時在apache 中的http.conf也做了相應的設置。Resin還提供了對該過程的自動安裝程式,運行resin\bin\setup,你可以在彈處的對話框中選擇apache,這樣子就可以了。只要你曾經安裝過apache,resin可以自己找到httpd.conf文件所在的路徑。

    使用命令行方式啟動Resin,如果改動了Resin.conf,Resin會自己重新啟動適應新的配置。這個很適合初期安裝時使用。

    Resin對數據庫緩沖池的支持很好。在這里,它提供了DBPool對緩沖池做了封裝。實際使用時,只要在resin.conf這樣配置:

    <dbpool.sql>

    <id>ORCL</id>

    <driver>oracle.jdbc.driver.OracleDriver</driver>

    <url>jdbc:oracle:thin:@localhost:1521:SMTH</url>

    <!-- <url>jdbc:oracle:oci8:@SMTH</url> -->

    <user>scott</user>

    <password>tiger</password>

    <max-connections>5</max-connections>

    </dbpool.sql>

    然后,在你的jsp或者servlet中就可以這樣子使用了:

    先導入 com.caucho.sql.*包,然后如下直接得到連接:

    Connection conn = DBPool.getPool("ORCL").getConnection();

    個人建議不要如上使用連接池,還是按照ejb的方法用從Context中直接找到的DataSource對象中得到連接通用性比較好。代碼也很簡單:

    Context ctx = new InitialContext();

    DataSource ds = (DataSource)ctx.lookup(“jdbc/EmployeeDB”);

    Connection conn = ds.getConnection();

    在Resin中如下配置jdbc就可以了:

    <resource-ref>

    <res-ref-name> jdbc/EmployeeDB</res-ref-name>

    <res-type>javax.sql.DataSource</res-type>

    <init-param driver-name="com.caucho.jdbc.mysql.Driver"/>

    <init-param url="jdbc:mysql_caucho://localhost:3306/test"/>

    <init-param user="name"/>

    <init-param password="password"/>

    <init-param max-connections="20"/>

    <init-param max-idle-time="30"/>

    </resource-ref>

    用Resin Web Server開發還是比較愉快的。只是沒有像Weblogic 或者WebSphere那樣子提供現成的管理控制臺而已。但是從穩定性和方便性來講,Resin個人認為比Tomcat要好很多。況且Resin還有提供了resin-cmp 和 resin-ejb,功能更強大。

    posted @ 2005-12-15 13:22 kelven 閱讀(2082) | 評論 (0)編輯 收藏

    目錄

    正則表達式介紹
    匹配模式

    字符子集
    行結束符
    分組和引用
    Unicode支持


    正則表達式語法參考
    1. 字符
    2. 邏輯操作符
    3. 向后引用
    4. 邊界元字符
    5. 重復指示符
    6. 字符子集
    7. 預定義子集(元字符)
    8. 擴展子集(元字符)
    9. 擴展中文子集(元字符)
    10. POSIX字符子集(只適用于ASCII)
    11. Unicode塊和分類

    替換表達式
    替換表達式
    1. 特殊字符
    2. 自定義替換表

    匹配模式

    匹配模式指得是正則表達式引擎將以何種模式匹配字符串。
    模式名稱
    啟用,禁用
    缺省啟用
    說明
    UNIX_LINES
    (?d)啟用,(?-d)禁用

    啟用Unix行模式。
    在此模式下,只有 '\n'被認為是行結束符。它會影響., ^, 和 $ 的行為。

    CASE_INSENSITIVE
    (?i)啟用,(?-i)禁用

    啟用忽略大小寫模式。
    缺省時,忽略大小寫模式只會影響 ASCII字符的匹配。 而Unicode范圍的忽略大小寫匹配需要通過 UNICODE_CASE 標志與本標志聯合使用。
    啟用此模式會影響匹配性能。

    COMMENTS
    (?x)啟用,(?-x)禁用

    允許空格和注釋出現在正則表達式中。
    在此模式下,空格被忽略,以#開始的單行注釋被忽略。
    MULTILINE
    (?m)啟用,(?-m)禁用

    啟用多行模式。
    In multiline mode the expressions ^ and $ match just after or just before, respectively, a line terminator or the end of the input sequence. By default these expressions only match at the beginning and the end of the entire input sequence.

    DOTALL
    (?s)啟用,(?-s)禁用

    讓.可以匹配行結束符。
    在此模式下,元字符.可以匹配行結束符。缺省不允許如此匹配。


    UNICODE_CASE
    (?u)啟用,(?-u)禁用

    Enables Unicode-aware case folding.
    When this flag is specified then case-insensitive matching, when enabled by the CASE_INSENSITIVE flag, is done in a manner consistent with the Unicode Standard. By default, case-insensitive matching assumes that only characters in the US-ASCII charset are being matched. 啟用此模式會影響性能。

    CANON_EQ
    (?c)啟用,(?-c)禁用

    Enables canonical equivalence.
    When this flag is specified then two characters will be considered to match if, and only if, their full canonical decompositions match. The expression "a\u030A", for example, will match the string "?" when this flag is specified. By default, matching does not take canonical equivalence into account.
    啟用此模式會影響性能。



    字符子集

    字符子集可以含有別的字符子集,并且可以通過聯合操作符(缺?。┖徒患僮鞣?amp;&)實現組合。聯合操作符表示某個子集匹配它的子子集所匹配的任意字符。交集操作符表明某個字符子集只匹配它的子子集都匹配的字符。
    字符子集所能夠有的操作符的優先級如下,從高到低:
    1. 轉義符\x
    2. 成組符 [...]
    3. 區間符 a-z
    4. 聯合符 [a-e][i-u]
    5. 交集符 [a-z&&[aeiou]]
    注意:在字符子集[]內部的語法根本不同于正則表達式其它部分中的語法。例如,在字符子集內部,正則表達式 . 失去了它原有的含義,而是成了一個匹配.的元字符。

    行結束符

    行結束符是一個或兩個字符序列,用以表明輸入字符序列中一行的結束。下面的字符被認為是行結束符:
    • 一個換行符('\n')。
    • 一個回車符加上一個換行符("\r\n")。
    • 一個單獨的回車符('\r')。
    • 代表下一行的字符('\u0085')。
    • 行分隔符('\u2028'),Unicode中被定義。
    • 一個分段符('\u2029),Unicode中被定義。
    如果 UNIX_LINES 模式被啟用,則只有換行符被認為是行結束符。
    如果 MULTILINE 模式被啟用,。

    分組和引用

    字符分組以它們的左括號的出現順序來排序。例如在表達式((A)(B(C))),有四個分組:
    1. ((A)(B(C)))
    2. (A)
    3. (B(C))
    4. (C)
    第0組永遠表示表達式本身。
    分組采用這樣的命名方式,是因為,在一次匹配過程中,正則表達式會被匹配多次。以前的匹配子序列有可能在將來被使用;或者在匹配結束時,程序有可能需要重新獲得所有匹配的子字符序列。
    對于正則表達式中的某個分組而言,永遠只保留最后匹配的字符序列。如果對某個分組匹配嘗試失敗,則會保留上次匹配成功的字符序列。例如,對于正則表達式(a(b)?)+而言,字符序列"aba",將會讓分組2匹配的字符序列為"b"。
    以(?開始的分組,將不會計入分組數目,也不會被后續匹配所引用。

    Unicode支持

    本正則表達式匹配引擎的實現遵循了《Unicode技術報告:Unicode正則表達式指南》,實現了該指南的第二層所需的功能,但是在細微處有一些簡單語法修改。
    Unicode塊(Block)和分類(Category)通過\p和\P通配苻表示。\p{prop}匹配含有prop的輸入序列,而\P{prop}匹配不含有prop的輸入序列。Unicode塊通過前綴In表示,如\p{InMongolian}。Unicode分類通過可選的前綴Is表示,因此\p{L}和\p{IsL}都代表Unicode分類 letters。Unicode塊和分類都可以在正則表達式子集外部和內部使用。
    目前支持的Unicode塊和分類是《Unicode標準,第三版》中所指定的塊和分類。 Unicode塊名稱在《Unicode 字符數據庫》的第14章被定義,文件名稱叫

    與Perl 5正則表達式語法對比

    [TBD]


    正則表達式參考



    字符

    正則表達式字符串
    匹配的字符串
    X
    字符X,包括 CJK ExtB 區漢字
    \\
    反斜杠\
    \0n 八進制0n代表的字符(0<=n<=7)
    \0nn
    八進制0nn代表的字符(0<=n<=7)
    \0mnn
    八進制0mnn代表的字符(0<=m<=3,0<=n<=7)
    \xhh
    十六進制 0xhh所代表的字符
    \uhhhh
    十六進制 0xhhhh所代表的字符。注意,目前尚不支持CJK ExtB區漢字。
    \t
    制表符('\u0009')
    \n
    換行('\u000A')
    \r
    回車('\u000D')
    \a
    響鈴符('\u0007')
    \e
    取消符Escape('\001B')
    \cx
    x所代表的控制字符

    邏輯操作符

    正則表達式字符串
    匹配的字符串
    XY
    X后面跟隨Y
    X|Y
    X或者Y
    (X)
    X作為分組表達式

    向后引用

    正則表達式字符串
    匹配的字符串
    \n
    n個匹配的分組

    邊界元字符

    邊界字符
    匹配的字符串
    ^
    行首
    $
    行末
    \b 字符邊界
    \B
    非字符邊界
    \A
    輸入流的開始
    \G
    上次匹配的結束處
    \Z
    輸入流的結束,或者是最后一個行結束符,參見行結束符。
    \z
    輸入流的結束

    重復指示符

    正則表達式字符串
    匹配的字符串
    X?
    X重復一次,或者不重復
    X*
    X重復0次或多次
    X+
    X重復1次或多次
    X{n}
    X重復n次,不多也不少。
    X{n,}
    X至少重復n次
    X{n,m}
    X至少重復n次,至多重復m次。
    注:X{n,m}、?、*、+方式可以聯合使用。

    字符子集

    正則表達式字符串子集
    匹配的字符串
    組合方式
    [abc]
    字符a,b或c,包括 CJK ExtB 區漢字
    簡單子集
    [^abc]
    任意非a,b或c的字符。
    排除
    [a-zA-Z] 從a到z,或者A到Z,包含a,z,A,Z。
    區間
    [a-d[m-p]]
    從a到d,或者m到p,等于[a-dm-p]。
    聯合
    [a-z&&[def]]
    d,e或者f。
    交集
    [a-z&&[^bc]]
    從a到z,除了b和c,等于[ad-z]
    扣除
    [a-z&&[^m-p]]
    從a到z,并且不包括從m到p,等于[a-lq-z]
    扣除

    預定義子集(元字符)

    邊界字符
    匹配的字符串
    .
    任意字符,可能匹配行結束符。
    \d
    數字[0-9]
    \D 非數字[^0-9]
    \s
    空白符[ \t\n\x0B\f\r]
    \S
    非空白符[^\s]
    \w
    單詞符,包含有字母和數字[a-zA-Z_0-9]
    \W
    非單詞符,不包含有字母和數字。

    擴展子集(元字符)

    正則表達式字符串
    匹配的字符串




    擴展中文子集(元字符)

    名稱
    塊名稱(\p{InXXX})
    簡化通配符
    標準Unicode塊,或者漢字列表
    任意雙字節字符(漢字或全角符號)
    \p{InQuqnJiao}
    \E
    任意由GBK表示的漢字,不包括GB18030擴展部分,
    以及CJK ExtB區的漢字。
    任意單字節字符
    \p{InFQuanJiao}
    \~E
    任意單字節字符。
    任意全角ASCII字符
    \p{InQJAscii}
    \H
    標準HalfwidthandFullwidthForms塊
    任意收錄在BIG5碼集中的雙字節字符
    \p{InBig5}
    \I
    Big5可編碼雙字節字符
    匹配未收錄在BIG5碼集中的雙字節字符 \p{InFBig5}
    \~I
    非Big5可編碼雙字節字符
    匹配任意漢字(不包括符號)
    \p{InHanziOrCJKExtB}
    \X
    任意漢字,包括GB18030擴展部分。
    匹配任意漢字(不包括符號)
    \p{InHanzi}
    \M
    任意漢字,不包括GB18030擴展部分。
    匹配非漢字的雙字節字符
    \p{InFHanzi}
    \~M
    任意非漢字的雙字節字符,
    包括GB18030擴展部分。
    地支字符
    \p{InDiZhi}
    \U
    子丑寅卯辰巳午未申酉戌亥
    匹配收錄在GB碼集中的雙字節字符
    \p{InGB}
    \g
    收錄在GB碼集中的雙字節字符,
    不包括GB18030擴展部分。
    匹配非收錄在GB碼集中的雙字節字符
    \p{InFGB}
    \~g
    未收錄在GB碼集中的雙字節字符,
    不包括GB18030擴展部分。
    匹配收錄在GBK碼集中的雙字節字符
    \p{InGBK}
    \h
    收錄在GBK碼集中的雙字節字符,
    不包括GB18030擴展部分。
    匹配非收錄在GBK碼集中的雙字節字符
    \p{InFGBK}
    \~h
    未收錄在GBK碼集中的雙字節字符,
    不包括GB18030擴展部分。
    大寫希臘字母
    \p{InDaXila}
    \K
    ΑΒΓΔΕΖΗΘΙΚΛΜΝ
    ΞΟΠΡΣΤΥΦΧΨΩ
    日文片假名
    \p{InPianJia}
    \j
    標準Katakana塊
    日文平假名
    \p{InPingJia}
    \J
    標準Hiragana塊
    小寫希臘字母
    \p{InXiaoXila}
    \k
    αβγδεζηθικλμν
    ξοπρστυφχψω
    數學符號
    \p{InMathe}
    \m
    ±×÷∶∧∨∑∏∪∩∈∷√⊥∥∠⌒⊙
    ∫∮≡≌≈∽∝≠≮≯≤≥∞∵∴
    中文數字
    \p{InCnDigit}
    \i
    〇一二三四五六七八九十百千萬億兆吉京
    大寫中文數字
    \p{InDaCnDigit}
    \N
    零壹貳叁肆伍陸柒捌玖拾佰仟萬億兆吉京
    全角標點符號
    \p{InQJBiaoDian}
    \o
    、?!ぁァΑАā啊薄病?BR>〈〉《》「」『』〖〗【】?。ⅲВǎ?,
    -.:;<=>?[]{|}`﹉﹊﹋﹌﹍﹎﹏﹐﹑﹒﹔﹕﹖﹗﹙﹚
    ﹛﹜﹝﹞︵︶︹︺︿﹀︽︾﹁﹂﹃﹄
    ︻︼︷︸︱︳︴
    小寫俄文字母
    \p{InXiaoEWen}
    \l
    абвгдеёжзийклмн
    опрстуфхцчшщъыьэюя
    大寫俄文字母
    \p{InDaEWen}
    \R
    АБВГДЕЁЖЗИЙКЛМНО
    ПРСТУФХЦЧШЩЪЫЬЭЮЯ
    中文序號
    \p{InCnSN}
    \q
    ⅠⅡⅢⅣⅤⅥⅦⅧⅨⅩⅪⅫ
    ?、ⅱ"あアΒБá?BR>再加上Unicode標準EnclosedAlphanumerics塊
    天干字符
    \p{InTianGan}
    \T
    甲乙丙丁戊己庚辛壬癸
    豎排標點符號
    \p{InSPBiaoDian}
    \V
    ︵︶︹︺︿﹀︽︾﹁﹂﹃﹄︻︼︷︸︱︳︴
    拼音字符
    \p{InPinyin}
    \y
    āáǎàēéěèīíǐìōóǒòūúǔùǖǘǚǜüêɑńňɡ
    GBK -> 0xA8A1- 0xA8C0
    只是Unicode標準LatinExtended-A塊的一部分。
    注音字符
    \p{InZhuyin}
    \Y
    標準Bopomofo塊
    制表字符
    \p{InZhiBiao}
    \C
    標準BoxDrawing塊。
    經檢查發現 textpro 的算法含有部分非標
    準Unicode制表符:“∟∣≒≦≧⊿═”。

    POSIX字符子集(只適用于ASCII)

    正則表達式字符串
    匹配的字符串
    \p{Lower}
    小寫字母[a-z]
    \p{Upper}
    大寫字母[A-Z]
    \p{ASCII}
    所有的ASCII字符[\x00-\x7F]
    \p{Alpha}
    大小寫字母[\p{Lower}\p{Upper}]
    \p{Digit}
    數字[0-9]
    \p{Alnum}
    字母數字符,包含大小寫字母和數字[\p{Alpha}\p{Digit}]
    \p{Punct}
    標點符號,!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~之一。
    \p{Graph}
    可顯示字符[\p{Alnum}\p{Punct}]
    \p{Print}
    可打印字符[\p{Graph}]
    \p{Blank}
    空格或者制表符[ \t]
    \p{Cntrl}
    控制字符[\x00-\x1F\x7F
    \p{XDigit}
    十六進制數字[0-9a-fA-F]
    \p{Space}
    空白符[ \t\n\x0B\f\r]

    Unicode塊和分類


    中文名稱(摘自Word XP)
    代碼區域
    BasicLatin
    基本拉丁語
    \u0000-\u007F
    Latin-1Supplement
    拉丁語-1
    \u0080-\u00FF
    LatinExtended-A
    拉丁語擴充-A
    \u0100-\u017F
    LatinExtended-Bound
    拉丁語擴充-B
    \u0180-\u024F
    IPAExtensions
    國際音標擴充
    \u0250-\u02AF
    SpacingModifierLetters
    進格的修飾字符
    \u02B0-\u02FF
    CombiningDiacriticalMarks
    組合用發音符
    \u0300-\u036F
    Greek
    基本希臘語
    \u0370-\u03FF
    Cyrillic
    西里爾語
    \u0400-\u04FF
    Armenian

    \u0530-\u058F
    Hebrew

    \u0590-\u05FF
    Arabic

    \u0600-\u06FF
    Syriac

    \u0700-\u074F
    Thaana

    \u0780-\u07BF
    Devanagari

    \u0900-\u097F
    Bengali

    \u0980-\u09FF
    Gurmukhi

    \u0A00-\u0A7F
    Gujarati

    \u0A80-\u0AFF
    Oriya

    \u0B00-\u0B7F
    Tamil

    \u0B80-\u0BFF
    Telugu

    \u0C00-\u0C7F
    Kannada

    \u0C80-\u0CFF
    Malayalam

    \u0D00-\u0D7F
    Sinhala

    \u0D800-\uDFF
    Thai

    \u0E00-\u0E7F
    Lao

    \u0E80-\u0EFF
    Tibetan
    藏語
    \u0F00-\u0FFF
    Myanmar

    \u1000-\u109F
    Georgian

    \u10A0-\u10FF
    HangulJamo

    \u1100-\u11FF
    Ethiopic

    \u1200-\u137F
    Cherokee

    \u13A0-\u13FF
    UnifiedCanadianAboriginalSyllabics

    \u1400-\u167F
    Ogham

    \u1680-\u169F
    Runic

    \u16A0-\u16FF
    Khmer

    \u1780-\u17FF
    Mongolian
    蒙古語
    \u1800-\u18AF
    LatinExtendedAdditional

    \u1E00-\u1EFF
    GreekExtended

    \u1F00-\u1FFF
    GeneralPunctuation
    廣義標點
    \u2000-\u206F
    SuperscriptsandSubscripts

    \u2070-\u209F
    CurrencySymbols
    貨幣符號
    \u20A0-\u20CF
    CombiningMarksforSymbols

    \u20D0-\u20FF
    LetterlikeSymbols
    類似字母的符號
    \u2100-\u214F
    NumberForms
    數字形式
    \u2150-\u218F
    Arrows
    箭頭
    \u2190-\u21FF
    MathematicalOperators
    數學運算符
    \u2200-\u22FF
    MiscellaneousTechnical
    零雜技術用符號
    \u2300-\u23FF
    ControlPictures

    \u2400-\u243F
    OpticalCharacterRecognition

    \u2440-\u245F
    EnclosedAlphanumerics
    帶括號的字母數字
    \u2460-\u24FF
    BoxDrawing
    制表符
    \u2500-\u257F
    BlockElements
    方塊圖形
    \u2580-\u259F
    GeometricShapes
    幾何圖形
    \u25A0-\u25FF
    MiscellaneousSymbols
    零雜丁貝符(示意符等)
    \u2600-\u26FF
    Dingbats

    \u2700-\u27BF
    BraillePatterns

    \u2800-\u28FF
    CJKRadicalsSupplement

    \u2E80-\u2EFF
    KangxiRadicals

    \u2F00-\u2FDF
    IdeographicDescriptionCharacters

    \u2FF0-\u2FFF
    CJKSymbolsandPunctuation
    CJK符號和標點
    \u3000-\u303F
    Hiragana
    平假名
    \u3040-\u309F
    Katakana
    片假名
    \u30A0-\u30FF
    Bopomofo
    注音
    \u3100-\u312F
    HangulCompatibilityJamo

    \u3130-\u318F
    Kanbun

    \u3190-\u319F
    BopomofoExtended
    擴展注音
    \u31A0-\u31BF
    EnclosedCJKLettersandMonths
    帶括號的CJK字母及月份
    \u3200-\u32FF
    CJKCompatibility
    CJK兼容字符
    \u3300-\u33FF
    CJKUnifiedIdeographsExtensionA
    CJK統一漢字擴展-A
    \u3400-\u4dBF
    CJKUnifiedIdeographs
    CJK統一漢字
    \u4E00-\u9fAF
    YiSyllables

    \uA000-\uA48F
    YiRadicals

    \uA490-\uA4CF
    HangulSyllables

    \uAC00-\uD7A3
    HighSurrogates

    \uD800-\uDB7F
    HighPrivateUseSurrogates

    \uDB80-\uDBFF
    LowSurrogates

    \uDC00-\uDFFF
    PrivateUse
    專用區
    \uE000-\uF8FF
    CJKCompatibilityIdeographs
    CJK兼容漢字
    \uF900-\uFAFF
    AlphabeticPresentationForms

    \uFB00-\uFB4F
    ArabicPresentationForms-A

    \uFB50-\uFDFF
    CombiningHalfMarks

    \uFE20-\uFE2F
    CJKCompatibilityForms
    CJK兼容形式
    \uFE30-\uFE4F
    SmallFormVariants
    小寫變體
    \uFE50-\uFE6F
    ArabicPresentationForms-Bound

    \uFE70-\ufeFF
    Specials

    \uFFF0-\uFFFF
    HalfwidthandFullwidthForms
    半形及全形字符
    \uFF00-\uFFEF


    分類
    全稱
    說明
    Cn

    UNASSIGNED
    Lu

    UPPERCASE_LETTER
    Ll

    LOWERCASE_LETTER
    Lt

    TITLECASE_LETTER
    Lm

    MODIFIER_LETTER
    Lo

    OTHER_LETTER
    Mn

    NON_SPACING_MARK
    Me

    ENCLOSING_MARK
    Mc

    COMBINING_SPACING_MARK
    Nd

    DECIMAL_DIGIT_NUMBER
    Nl

    LETTER_NUMBER
    No

    OTHER_NUMBER
    Zs

    SPACE_SEPARATOR
    Zl

    LINE_SEPARATOR
    Zp

    PARAGRAPH_SEPARATOR
    Cc

    CNTRL
    Cf

    FORMAT
    Co

    PRIVATE_USE
    Cs

    SURROGATE
    Pd

    DASH_PUNCTUATION
    Ps

    START_PUNCTUATION
    Pe

    END_PUNCTUATION
    Pc

    CONNECTOR_PUNCTUATION
    Po

    OTHER_PUNCTUATION
    Sm

    MATH_SYMBOL
    Sc

    CURRENCY_SYMBOL
    Sk

    MODIFIER_SYMBOL
    So

    OTHER_SYMBOL
    L

    LETTER
    M

    MARK
    N

    NUMBER
    Z

    SEPARATOR
    C

    CONTROL
    P

    PUNCTUATION
    S

    SYMBOL
    LD

    LETTER_OR_DIGIT
    L1

    Latin-1
    all

    ALL
    ASCII

    ASCII
    Alnum

    字母數字(0-9,a-z,A-Z)
    Alpha

    字母(a-z,A-Z)
    Blank

    空格和制表符(' '|\t)
    Cntrl

    控制字符,不可打印
    Digit

    數字(0-9)
    Graph

    可打印且可視字母(例如空格' '是可打印的但不是可視字母,而 `a' 兩者都是。)
    Lower

    小寫字母
    Print

    可打印字母(非控制字符)
    Punct

    標符號(字母、數字、控制、空白符以外的字母),如:!@#$%}{<>,./?[]等等。
    Space

    空白符(' ',\t,0x09,0x0A,0x0B,0x0C,0x0D,0x20)
    Upper

    大寫字母
    XDigit

    十六進制數字(0-9,a-f, A-F)





    替換表達式

    特殊字符
    特殊字符介紹
    描述
    \n
    換行
    \b
    向前刪除一個字符。當這個字符位于替換串之首時,將刪除匹配串之前的一個字符。若匹配串位于行首,將使匹配串所在行與前一行相合并。
    \d
    向后刪除一個字符。當這個字符位于替換串之末時,將刪除匹配串之后的一個字符。若匹配串位于行末,將使匹配串所在行與下一行相合并。
    \e
    插入一個ESC字符
    \t
    插入一個TAB字符
    \n
    n代表查找正則表達式中的子表達式(組)。\1代表第一個子表達式,\2代表第二個子表達式,依次類推。\0代表整個匹配到的字符串。
    \v
    大寫下一個字母
    \U
    全部大寫以后的字母,直到碰到其它指示符為止。
    \l
    小寫下一個字母
    \L
    全部小寫以后的字母,直到碰到其它指示符為止。
    \E
    取消所有的字母大小寫指示符。


    自定義替換表

    在查找/替換中使用自定義替換表
    有的時候,上述簡單的自定義替換功能是不夠的。例如,用戶可能希望只把出現在括號內的源串替換為目標串。這種文本處理可以通過在查找/替換中使用自定義替換表來解決。

    在查找/替換功能中使用自定義替換表的替換函數是\Tn,其中n是0-9的數字, 注意n為0表示第10張替換表。如果略去n,其效果相當于\T1,即使用第一張替換表。例如要把所有放在方括號中的漢字替換為拼音,可以查找“\[(\E)\]”,替換為“\T{\1}”。即把第一個子表達式的匹配內容按自定義替換表轉換。注意,如果\T函數的參數不在替換表的源串中,\T函數的結果與源串相同,即不做任何變換。

    有些情況下,用戶可能希望只使用替換表的一部分內容。還是以拼音為例,前面給出的替換表中包含了拼音的音調,如果在替換時不希望加上這些音調數字,可以使用“過濾”功能。所謂過濾,其實是用一個正則表達式去分析替換表的目標串,并把其中的某個子表達式取出來。

    使用“過濾”時,在“設置自定義替換表”對話框中,點“過濾”按鈕,在彈出的對話框中填入一個正則表達式。再以拼音為例,表達式可以寫為“(\p{Alpha}+)(\d)”,其中第一對括號中的是不含音調的拼音,第二對括號是音調。在調用\T函數時,JTextPro會在目標串中查找這個正則表達式。但是如何把其中的子表達式取出來呢?\T函數還有一個可選的下標,取第n個子表達式的值就寫作\T{...}[n]。所以,把放在方括號中的漢字替換為不帶調的拼音,可以查找“\[(\E)\]”,替換為“\T{\1}[1]”

    posted @ 2005-12-12 13:38 kelven 閱讀(965) | 評論 (0)編輯 收藏
    我收集的Eclipse插件

    Poperties Editor
     
    http://propedit.sourceforge.jp/eclipse/updates/

    eclipseME
     
    http://eclipseme.org/updates/

    Eclipse加速插件KeepResident
    http://suif.stanford.edu/pub/keepresident/

     
    MyEclipse  J2EE開發插件,支持SERVLET/JSP/EJB/數據庫操縱等
    www.myeclipseide.com
     
    Properties Editor  編輯java的屬性文件,并可以自動存盤為Unicode格式
    http://propedit.sourceforge.jp/index_en.html
    http://propedit.sourceforge.jp/eclipse/updates/
     
    Colorer Take  為上百種類型的文件按語法著色
    http://colorer.sourceforge.net/
     
    XMLBuddy 編輯xml文件
    www.xmlbuddy.com
     
    Code Folding  加入多種代碼折疊功能(比eclipse自帶的更多)
    http://www.coffee-bytes.com/servlet/PlatformSupport
     
    Easy Explorer  從eclipse中訪問選定文件、目錄所在的文件夾
    http://easystruts.sourceforge.net/
     
    Fat Jar 打包插件,可以方便的完成各種打包任務,可以包含外部的包等
    http://fjep.sourceforge.net/
     
    RegEx Test 測試正則表達式
    http://brosinski.com/stephan/archives/000028.php
     
    JasperAssistant 報表插件(強,要錢的)
    http://www.jasperassistant.com/
     
    Jigloo GUI Builder JAVA的GUI編輯插件
    http://cloudgarden.com/jigloo/
     
    Profiler 性能跟蹤、測量工具,能跟蹤、測量BS程序
    http://sourceforge.net/projects/eclipsecolorer/
     
    AdvanQas 提供對if/else等條件語句的提示和快捷幫助(自動更改結構等)
    http://eclipsecolorer.sourceforge.net/advanqas/index.html
     
    Log4E     Log4j插件,提供各種和Log4j相關的任務,如為方法、類添加一個logger等
    http://log4e.jayefem.de/index.php/Main_Page
     
    VSSPlugin VSS插件
    http://sourceforge.net/projects/vssplugin
     
    Implementors   提供跳轉到一個方法的實現類,而不是接中的功能(實用!)
    http://eclipse-tools.sourceforge.net/implementors/
     
    Call Hierarchy 顯示一個方法的調用層次(被哪些方法調,調了哪些方法)
    http://eclipse-tools.sourceforge.net/call-hierarchy/index.html
     
    EclipseTidy 檢查和格式化HTML/XML文件
    http://eclipsetidy.sourceforge.net/
     
    Checkclipse 檢查代碼的風格、寫法是否符合規范
    http://www.mvmsoft.de/content/plugins/checkclipse/checkclipse.htm
     
    Hibernate Synchronizer Hibernate插件,自動映射等
    http://www.binamics.com/hibernatesync/
     
    spring updatesite 插件
    http://springide.org/updatesite/

    VeloEclipse  Velocity插件
    http://propsorter.sourceforge.net/
     
    EditorList   方便的列出所有打開的Editor
    http://editorlist.sourceforge.net/
     
    MemoryManager 內存占用率的監視
    http://cloudgarden.com/memorymanager/

    Eclipse的游戲插件
    http://eclipse-games.sourceforge.net/

    JBoss-IDE
    http://jboss.sourceforge.net/jbosside/updates/

    自動反編譯class,安裝后要設定class文件缺省關聯到jode
    http://www.technoetic.com/eclipse/update


    jigloo swing/sw設計工具,里面自帶的form/anchor布局很好用!
    http://cloudgarden.soft-gems.net/update-site/

    jinto的資源文件編輯工具,同時編輯多種語言,而且自動轉換成iso8859-1編碼。很好用!
    http://www.guh-software.de/eclipse/

    posted @ 2005-12-12 13:30 kelven 閱讀(713) | 評論 (1)編輯 收藏
    僅列出標題
    共3頁: 上一頁 1 2 3 下一頁 
    主站蜘蛛池模板: 丁香花在线视频观看免费| 亚洲综合激情另类专区| 香蕉视频在线免费看| 亚洲一区二区三区成人网站| 亚洲AV电影院在线观看| 亚洲国产成人VA在线观看| 毛片大全免费观看| 91在线手机精品免费观看| 中文字幕在线成人免费看| 蜜桃传媒一区二区亚洲AV| 亚洲一区二区三区久久| 67pao强力打造67194在线午夜亚洲 | 91视频免费网址| 在线免费观看h片| 永久免费观看黄网站| 亚洲国产精品成人综合色在线| 亚洲精品美女视频| 亚洲人成电影福利在线播放| 久久久久亚洲av毛片大| 亚洲欧洲日产国码高潮αv| 免费一级毛片在线播放| 日本高清免费aaaaa大片视频| 无码人妻精品中文字幕免费东京热| 欧洲人成在线免费| 国内精品久久久久影院免费| 久久久受www免费人成| jizz在线免费观看| 韩国免费A级毛片久久| 国产精品免费久久久久久久久 | 午夜私人影院免费体验区| 在线观看无码AV网站永久免费 | 亚洲妇女熟BBW| 中文字幕在线观看亚洲视频| 亚洲国产夜色在线观看| 亚洲成人一级电影| 亚洲午夜电影在线观看高清 | 国产免费丝袜调教视频| 免费观看国产网址你懂的| 在线观看av永久免费| 最近免费中文字幕大全视频 | 亚洲欧美乱色情图片|