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

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

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

    風(fēng)雨無阻

    2008年3月28日

    Jvm工作原理學(xué)習(xí)筆記

    class loader 加載 class file 到內(nèi)存
    jvm內(nèi)存包括: method area(存放class name, class path , 類修飾符等信息), java stack(每一個(gè)線程單獨(dú)有個(gè)stack),java heap(存放對(duì)象的數(shù)據(jù),數(shù)組數(shù)據(jù)等,被所有線程共享的), pc寄存器(每一個(gè)線程單獨(dú)有個(gè)pc寄存器,用于存放下一步指令),本地方法棧。

    java 堆 可 分為三部分:Perm,Tenured,Yong區(qū)。可以通過參數(shù)來配置空間大小:

    -Xms :指定了JVM初始啟動(dòng)以后初始化內(nèi)存

    -Xmx:指定JVM堆得最大內(nèi)存,在JVM啟動(dòng)以后,會(huì)分配-Xmx參數(shù)指定大小的內(nèi)存給JVM,但是不一定全部使用,JVM會(huì)根據(jù)-Xms參數(shù)來調(diào)節(jié)真正用于JVM的內(nèi)存

     Perm Generation

    -XX:PermSize=16M -XX:MaxPermSize=64M

    posted @ 2014-02-10 18:01 秋楓故事 閱讀(251) | 評(píng)論 (0)編輯 收藏

    Ajax Post提交

    jQuery.post( url, [data], [callback], [type] ) :使用POST方式來進(jìn)行異步請(qǐng)求


    參數(shù):

    url (String) : 發(fā)送請(qǐng)求的URL地址.

    data (Map) : (可選) 要發(fā)送給服務(wù)器的數(shù)據(jù),以 Key/value 的鍵值對(duì)形式表示。

    callback (Function) : (可選) 載入成功時(shí)回調(diào)函數(shù)(只有當(dāng)Response的返回狀態(tài)是success才是調(diào)用該方法)。

    type (String) : (可選)官方的說明是:Type of data to be sent。其實(shí)應(yīng)該為客戶端請(qǐng)求的類型(JSON,XML,等等)

    這是一個(gè)簡(jiǎn)單的 POST 請(qǐng)求功能以取代復(fù)雜 $.ajax 。請(qǐng)求成功時(shí)可調(diào)用回調(diào)函數(shù)。如果需要在出錯(cuò)時(shí)執(zhí)行函數(shù),請(qǐng)

    使用 $.ajax。示例代碼:

     var con = $('#content').val();//待提交的數(shù)據(jù)

        $.post("checkContent.action",{"mess.content":con},
        function (data){
      
       if(data != "")//有非法敏感字
        {  
         alert(data);
         $('#content').focus();
        }
      },"html");


    點(diǎn)擊提交:

    posted @ 2009-09-03 14:42 秋楓故事 閱讀(3122) | 評(píng)論 (4)編輯 收藏

    xmlns:XML命名空間

    以下轉(zhuǎn)載自:
    http://hi.baidu.com/tianhesj/blog/item/0dd9718d32be4011b21bbacc.html

    Namespaces翻譯為命名空間。命名空間有什么作用呢?當(dāng)我們?cè)谝粋€(gè)XML文檔中使用他人的或者多個(gè)DTD文件,就會(huì)出現(xiàn)這樣的矛盾:因?yàn)閄ML中標(biāo)識(shí)都是自己創(chuàng)建的,在不同的DTD文件中,標(biāo)識(shí)名可能相同但表示的含義不同,這就可能引起數(shù)據(jù)混亂。
    比如在一個(gè)文檔<table>wood table</table>中<table>表示桌子,
    而在另一個(gè)文檔<table>namelist</table>中<table>表示表格。如果我需要同時(shí)處理這兩個(gè)文檔,就會(huì)發(fā)生名字沖突。
    了解決這個(gè)問題,我們引進(jìn)了namespaces這個(gè)概念。namespaces通過給標(biāo)識(shí)名稱加一個(gè)網(wǎng)址(URL)定位的方法來區(qū)別這些名稱相同的標(biāo)識(shí)。
    Namespaces同樣需要在XML文檔的開頭部分聲明,聲明的語法如下:
    <document xmlns:yourname='URL'>
    其中yourname是由你定義的namespaces的名稱,URL就是名字空間的網(wǎng)址。
    假設(shè)上面的"桌子<table>"文檔來自http://www.zhuozi.com,我們就可以聲明為
    <document xmlns:zhuozi='http://www.zhuozi.com'>;
    然后在后面的標(biāo)識(shí)中使用定義好的名字空間:
    <zhuozi:table>wood table</table>
    這樣就將這兩個(gè)<table>區(qū)分開來。注意的是:設(shè)置URL并不是說這個(gè)標(biāo)識(shí)真的要到那個(gè)網(wǎng)址去讀取,僅僅作為一種區(qū)別的標(biāo)志而已。


    命名沖突
    因?yàn)閄ML文檔中使用的元素不是固定的,那么兩個(gè)不同的XML文檔使用同一個(gè)名字來描述不同類型的元素的情況就可能發(fā)生。而這種情況又往往會(huì)導(dǎo)致命名沖突。請(qǐng)看下面兩個(gè)例子

    這個(gè) XML 文檔在table元素中攜帶了水果的信息:

    <table>
    <tr>
    <td>Apples</td>
    <td>Bananas</td>
    </tr>
    </table>
    這個(gè) XML 文檔在table元素中攜帶了桌子的信息(家具,不能吃的哦):

    <table>
    <name>African Coffee Table</name>
    <width>80</width>
    <length>120</length>
    </table>

    如果上面兩個(gè)XML文檔片斷碰巧在一起使用的話,那么將會(huì)出現(xiàn)命名沖突的情況。因?yàn)檫@兩個(gè)片斷都包含了<table>元素,而這兩個(gè)table元素的定義與所包含的內(nèi)容又各不相同。


    --------------------------------------------------------------------------------

    使用前綴解決命名沖突問題
    下面的XML文檔在table元素中攜帶了信息:

    <h:table>
    <h:tr>
    <h:td>Apples</h:td>
    <h:td>Bananas</h:td>
    </h:tr>
    </h:table>

    下面的XML文檔攜帶了家具table的信息:

    <f:table>
    <f:name>African Coffee Table</f:name>
    <f:width>80</f:width>
    <f:length>120</f:length>
    </f:table>

    現(xiàn)在已經(jīng)沒有元素命名沖突的問題了,因?yàn)檫@兩個(gè)文檔對(duì)各自的table元素使用了不同的前綴,table元素在兩個(gè)文檔中分別是(<h:table> 和<f:table>)。

    通過使用前綴,我們創(chuàng)建了兩個(gè)不同的table元素。


    --------------------------------------------------------------------------------

    使用命名空間
    下面的XML文檔在table元素中攜帶了信息:

    <h:table xmlns:h="http://www.w3.org/TR/html4/">
    <h:tr>
    <h:td>Apples</h:td>
    <h:td>Bananas</h:td>
    </h:tr>
    </h:table>

    下面的XML文檔攜帶了家具table的信息:

    <f:table xmlns:f="http://www.w3schools.com/furniture">
    <f:name>African Coffee Table</f:name>
    <f:width>80</f:width>
    <f:length>120</f:length>
    </f:table>

    在上面兩個(gè)例子中除了使用前綴外,兩個(gè)table元素都使用了xmlns屬性,使元素和不同的命名空間關(guān)聯(lián)到一起。


    --------------------------------------------------------------------------------

    命名空間屬性
    命名空間屬性一般放置在元素的開始標(biāo)記處,其使用語法如下所示:

    xmlns:namespace-prefix="namespace"

    在上面的例子中,命名空間定義了一個(gè)Internet 地址:

    xmlns:f="http://www.w3schools.com/furniture"

    W3C 命名規(guī)范聲明命名空間本身就是一個(gè)統(tǒng)一資源標(biāo)示符,Uniform Resource Identifier (URI)。

    當(dāng)我們?cè)谠氐拈_始標(biāo)記處使用命名空間時(shí),該元素所有的子元素都將通過一個(gè)前綴與同一個(gè)命名空間相互關(guān)聯(lián)。

    注意:用來標(biāo)識(shí)命名空間的網(wǎng)絡(luò)地址并不被XML解析器調(diào)用,XML解析器不需要從這個(gè)網(wǎng)絡(luò)地址中查找信息,該網(wǎng)絡(luò)地址的作用僅僅是給命名空間一個(gè)唯一的名字,因此這個(gè)網(wǎng)絡(luò)地址也可以是虛擬的,然而又很多公司經(jīng)常把這個(gè)網(wǎng)絡(luò)地址值象一個(gè)真實(shí)的Web頁面,這個(gè)地址包含了關(guān)于當(dāng)前命名空間更詳細(xì)的信息。
    可以訪問http://www.w3.org/TR/html4/.


    --------------------------------------------------------------------------------

    統(tǒng)一資源標(biāo)識(shí)符
    通用資源標(biāo)識(shí)符(A Uniform Resource Identifier (URI))是一個(gè)標(biāo)識(shí)網(wǎng)絡(luò)資源的字符串。最普通的URI應(yīng)該是統(tǒng)一資源定位符Uniform Resource Locator (URL)。URL用于標(biāo)識(shí)網(wǎng)絡(luò)主機(jī)的地址。另一方面,另一個(gè)不常用的URI是通用資源名字Universal Resource Name (URN)。在我們的例子中,一般使用的是URLs。

    既然前面的例子使用的URL地址來標(biāo)識(shí)命名空間,我們可以確信這個(gè)命名空間是唯一的。


    --------------------------------------------------------------------------------

    默認(rèn)的命名空間
    定義一個(gè)默認(rèn)的XML命名空間使得我們?cè)谧釉氐拈_始標(biāo)記中不需要使用前綴。他的語法如下所示:

    <element xmlns="namespace">

    下面的XML文檔在table元素中包含了水果的信息:

    <table xmlns="http://www.w3.org/TR/html4/">
    <tr>
    <td>Apples</td>
    <td>Bananas</td>
    </tr>
    </table>

    下面的XML文檔包含了家具table的信息:

    <table xmlns="http://www.w3schools.com/furniture">
    <name>African Coffee Table</name>
    <width>80</width>
    <length>120</length>
    </table>

    --------------------------------------------------------------------------------

    使用命名空間
    檔開始使用XSL的時(shí)候,就會(huì)發(fā)現(xiàn)命名空間使用的是如此頻繁。XSL樣式單主要用于將XML文檔轉(zhuǎn)換成類似于HTML文件的格式。

    如果看一下下面的XSL文檔,就會(huì)發(fā)現(xiàn)有很多標(biāo)記都是HTML標(biāo)記。那些標(biāo)記并不是HTML標(biāo)記,是加了前綴的XSL,這個(gè)XSL前綴由命名空間"http://www.w3.org/TR/xsl"所標(biāo)識(shí):

    <?xml version="1.0" encoding="ISO-8859-1"?>
    <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/xsl">
    <xsl:template match="/">
    <html>
    <body>
    <table border="2" bgcolor="yellow">
    <tr>
    <th>Title</th>
    <th>Artist</th>
    </tr>
    <xsl:for-each select="CATALOG/CD">
    <tr>
    <td><xsl:value-of select="TITLE"/></td>
    <td><xsl:value-of select="ARTIST"/></td>
    </tr>
    </xsl:for-each>
    </table>
    </body>
    </html>
    </xsl:template>
    </xsl:stylesheet>


    本文來自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/yc_8301/archive/2008/11/19/3335738.aspx

    posted @ 2009-08-04 10:46 秋楓故事 閱讀(1324) | 評(píng)論 (0)編輯 收藏

    關(guān)于表單中的重置按鈕

    表單中有一個(gè)type=reset的button,可以將表單中的數(shù)據(jù)重置為初始表單的數(shù)據(jù),但如果表單中有一些“單選”或“多選”框,其默認(rèn)值是通過javascript腳本控制的;這種情況通過reset按鈕不會(huì)重置為初始狀態(tài),所以不能簡(jiǎn)單的調(diào)用reset自帶按鈕,解決方法:將重置按鈕設(shè)為普通按鈕,在onclick方法中,選調(diào)用form.reset()方法,然后再調(diào)用javascript腳本

    posted @ 2009-05-08 11:37 秋楓故事 閱讀(2534) | 評(píng)論 (1)編輯 收藏

    myeclipse連接oracle出現(xiàn)ora-12705錯(cuò)誤的解決辦法

    我用的myeclipse 6.0版本,oracle是10g版本,在連接的時(shí)候出現(xiàn)了以下問題

     java.sql.SQLException: ORA-00604: error occurred at recursive SQL level 1
    ORA-12705: Cannot access NLS data files or invalid environment specified

    一開始以為是驅(qū)動(dòng)程序的問題,其實(shí)不是,只需在eclipse目錄下找到eclipse.ini文件,把

    Duser.language=en  改成 Duser.language=zh就行了。

    有可能大家出現(xiàn)的問題不一樣,按我的方法有可能不好使,我寫出來僅供大家參考,因?yàn)楫?dāng)時(shí)為解決這問題,花了不少時(shí)間,希望大家少走彎路

    posted @ 2009-04-28 17:40 秋楓故事 閱讀(207) | 評(píng)論 (0)編輯 收藏

    摘一部電影中的內(nèi)容


        我有一把白色塑膠雨傘。買的時(shí)候喜歡它雪白可愛,瘦瘦長(zhǎng)長(zhǎng),簡(jiǎn)直像個(gè)鶴立雞群的美女。可惜這種美麗偏偏不耐看,風(fēng)吹雨打久了,顏色變黃,還多了雀斑一樣的污跡。而且瘦長(zhǎng)是沒用的,哪里像折傘這么善解人意。于是,我開始制造各種機(jī)會(huì)。 趁著下雨帶它出門,左擱一會(huì)兒,右放一下,希望一下子大意忘了拿,讓它自動(dòng)消失,大家無痛分手。我就可以理直氣壯買一把新的,多好!
    失寵的人通常最敏感。 有一天,它突如其來消失了,完全不用花我任何心思。傘也有它的自尊。問題是,等一等,我還沒有準(zhǔn)備好。不行,它不可以沒經(jīng)我的同意就玩失蹤。我便一心一意要找它回來,花盡心思去想,到底在哪里弄丟的呢?書店,餐廳還是公共汽車地鐵呢?
    真是峰回路轉(zhuǎn),沒想到在戲院把它找回來,小別重逢,它苦著副臉在等我來新發(fā)現(xiàn)。重拾舊歡,大團(tuán)圓結(jié)局。 換一個(gè)角度來看,如果我失敗了,找不到它,它永遠(yuǎn)消失了,淡淡的遺憾感覺,會(huì)不會(huì)更合我心意?
    人世間的破鏡重圓,大概都是一言難盡。

    posted @ 2009-04-23 09:15 秋楓故事 閱讀(213) | 評(píng)論 (0)編輯 收藏

    group by 。。。

     select t2.*,t3.ncount from 
    (select groupid, count(id) as ncount  from t_txlEmploy group by groupid) t3, t_txlgroup t2
    where  t2.id=t3.groupid(+)
    group by t2.id,t3.groupid

    構(gòu)架一張t3表,字段為“集團(tuán)編號(hào)”,“集團(tuán)用戶數(shù)”

    然后用“集團(tuán)表”和t3表再關(guān)聯(lián)

    posted @ 2009-04-22 16:37 秋楓故事 閱讀(237) | 評(píng)論 (0)編輯 收藏

    Spring獲取ApplicationContext的正確方式

    前兩天聯(lián)華對(duì)單系統(tǒng)頻頻出現(xiàn)out of memory的問題,經(jīng)過層層分析,終于弄明白原來瓶頸出現(xiàn)在Spring獲取Bean那一步上。以前的做法是在delegate層ApplicationContext context = new ClassPathXmlApplicationContext("Compare.xml"); 這樣我把log4j的debug打開后發(fā)現(xiàn),每做1步操作的時(shí)候系統(tǒng)都會(huì)重新加載這個(gè)xml,重新創(chuàng)建Bean的實(shí)例,重新獲取url-mapping,這無疑是個(gè)及其錯(cuò)誤的方式。      研究后發(fā)現(xiàn)正確的使用方式是:      首先在web.xml里配置ApplicationContext      <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>     然后在Action中編寫如下代碼得到Context,(我是覆蓋了Struts Action的setServlet方法,也許還有更好的方法)。     public void setServlet(ActionServlet servlet){
             super.setServlet(servlet);
             ServletContext servletContext = servlet.getServletContext();
            WebApplicationContext wac =    WebApplicationContextUtils.getRequiredWebApplicationContext(servletContext);
             // get yours beans     }     這樣在啟動(dòng)服務(wù)時(shí)已經(jīng)加載了xml中的配置,而不用每次都重新加載,大大提高了系統(tǒng)的效率

    posted @ 2009-04-17 16:45 秋楓故事 閱讀(1019) | 評(píng)論 (0)編輯 收藏

    suse硬盤安裝(網(wǎng)絡(luò)收集)

    事先,把你的硬盤劃出 10G左右的空閑空間!

    1.下載suse安裝光盤,準(zhǔn)備好8G左右的空間,最好是ntfs格式的。現(xiàn)在有 10.1正式版和10.2的beta 2版,2006年12月7號(hào),10.2就除正式版了!然后將五張光盤全部解壓,加壓到根目錄的一個(gè)文件夾下,比如X:\suse\

    2.找到解壓出的第一張光盤linux和initrd文件,放在根目錄下.

    32位的路徑應(yīng)該是 x:\suse\SUSE-Linux-10.1-Remastered-x86_64-CD1\boot\i386\loader\

    64位的路徑是:X:\suse\SUSE-Linux-10.1-Remastered-x86_64-CD1\boot\x96_64\loader\

    3.下載Grub for dos。下載網(wǎng)址:http://download.it168.com/14/1411/33307/33307_4.shtml

    http://grub4dos.sourceforge.net

    4.將下載的grub for dos 解壓到C盤可能會(huì)提示覆蓋什么profile.sys文件,直接替換就行。

    5.改boot.ini文件,先把boot.ini文件的隱藏屬性給去掉!

    把boot.ini文件用記事本打開在最下添加這么一行

    C:\GRLDR="GRUB"

    然后保存,

    6.下一步就是重啟系統(tǒng)了,當(dāng)要選擇要啟動(dòng)的系統(tǒng)時(shí),選擇grub,找到類似 commanderline ,按下enter,進(jìn)入dos 提示符狀態(tài)下,

    輸入 find /linux 回車,此時(shí)會(huì)顯示

    hd(0,6)——(肯定會(huì)有不同,請(qǐng)看下面注釋

    kernel hd(0,6)/linux回車

    initrd hd(0,6)/initrd回車

    boot回車

    注釋:hd(0,6)   6是你的分區(qū),根據(jù)你的分區(qū)不同,這個(gè)數(shù)字會(huì)不同,0表示是第一塊硬盤。)

    進(jìn)入圖形界面,

    會(huì)提示類似 no cd in your cd drive的語句,不用管他,選擇back

    7.按照提示選擇,都是簡(jiǎn)單的英語,完全可以搞定的(抄襲linuxsir.org幾位大俠的話。。呵呵)

    8.等到要你指定安裝文件的位置的時(shí)候,你把你剛才解壓的suse的幾張光盤的位置填進(jìn)去就行了,然后回車,會(huì)提示選擇安裝語言,鍵盤鼠標(biāo)什么的,按照提示選就ok了。大家安裝時(shí)候注意分區(qū),不要采用它默認(rèn)的分區(qū)方式,那樣的你的windows操作系統(tǒng)就會(huì)被它給刪掉了。

    再羅嗦一點(diǎn),Suse的分區(qū)方式?jīng)]有fedora和ubuntu做的好,后面的兩個(gè)全部可以手動(dòng)分區(qū),而suse只有切換到專家模式下才能更改分區(qū),剛開始,搞的我又點(diǎn)郁悶。

    等待安裝完成。。。。大約40 ~ 1個(gè)小時(shí)。不要著急!中間還要填root密碼和給機(jī)器命名,添加user等操作!

    9.安裝完成后,重啟,進(jìn)入系統(tǒng),user不用填密碼自動(dòng)登錄系統(tǒng)(現(xiàn)在我還不知道怎么才能不讓它自動(dòng)登錄)

    祝大家好運(yùn)。。。。

    ——部分內(nèi)容來自linuxsir.org,感謝Thruth大俠!

     

    posted @ 2008-11-25 13:51 秋楓故事 閱讀(444) | 評(píng)論 (0)編輯 收藏

    關(guān)于ORACLE中的DECODE

         摘要: 關(guān)于ORACLE中的DECODE- -                               ...  閱讀全文

    posted @ 2008-11-13 15:59 秋楓故事 閱讀(2931) | 評(píng)論 (0)編輯 收藏

    Spring MVC 入門(轉(zhuǎn))

    如果你手上有一本《Spring in Action》, 那么你最好從第三部分"Spring 在 Web 層的應(yīng)用--建立 Web 層"開始看, 否則那將是一場(chǎng)惡夢(mèng)!

        首先, 我需要在你心里建立起 Spring MVC 的基本概念. 基于 Spring 的 Web 應(yīng)用程序接收到 http://localhost:8088/hello.do(請(qǐng)求路徑為/hello.do) 的請(qǐng)求后, Spring 將這個(gè)請(qǐng)求交給一個(gè)名為 helloController 的程序進(jìn)行處理, helloController 再調(diào)用 一個(gè)名為 hello.jsp 的 jsp 文件生成 HTML 代碼發(fā)給用戶的瀏覽器顯示. 上面的名稱(/hello.do, helloController, hello.jsp) 都是變量, 你可以更改.

        在 Spring MVC 中, jsp 文件中盡量不要有 Java 代碼, 只有 HTML 代碼和"迭代(forEach)"與"判斷(if)"兩個(gè)jstl標(biāo)簽. jsp 文件只作為渲染(或稱為視圖 View)模板使用.

        好了, 我們開始吧. 首先我們需要一個(gè)放在 WEB-INF 目錄下的 web.xml 文件:

    web.xml:
     <?xml version="1.0" encoding="UTF-8"?>
    <web-app version="2.4"
     xmlns="http://java.sun.com/xml/ns/j2ee"
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
     http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
     <context-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>
       /WEB-INF/database.xml
       /WEB-INF/applicationContext.xml
      </param-value>
     </context-param>
     
     <listener>
      <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
     </listener>
     
     <filter>
      <filter-name>EncodingFilter</filter-name>
      <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
      <init-param>
       <param-name>encoding</param-name>
       <param-value>UTF-8</param-value>
      </init-param>
     </filter>
     
     <filter-mapping>
      <filter-name>EncodingFilter</filter-name>
      <url-pattern>*.do</url-pattern>
     </filter-mapping>
     
     <servlet>
      <servlet-name>test</servlet-name>
      <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
      <load-on-startup>1</load-on-startup>
     </servlet>
     
     <servlet-mapping>
      <servlet-name>test</servlet-name>
      <url-pattern>*.do</url-pattern>
     </servlet-mapping>
     
     <welcome-file-list>
      <welcome-file>index.jsp</welcome-file>
      <welcome-file>index.html</welcome-file>
     </welcome-file-list>
     
     <jsp-config>
      <taglib>
       <taglib-uri>http://java.sun.com/jsp/jstl/core</taglib-uri>
       <taglib-location>/WEB-INF/c.tld</taglib-location>
      </taglib>
      <taglib>   
       <taglib-uri>http://java.sun.com/jsp/jstl/fmt</taglib-uri>
       <taglib-location>/WEB-INF/fmt.tld</taglib-location>
      </taglib>
     </jsp-config>
    </web-app>
    它配置了以下功能:
    • 配置 DispatcherServlet (servlet 標(biāo)簽), 它是一個(gè) Java Servlet 程序. 我們將它命名為 test. 然后我們?cè)倥渲?Servlet 映射(test-mapping 標(biāo)簽), 也就是你希望哪些請(qǐng)求被DispatcherServlet處理. 這里, 我們?cè)O(shè)置后綴名為 do(*.do) 的所有URL請(qǐng)求都被名為 test 的 DispatcherServlet 的程序處理. 選擇 .do 只是一個(gè)習(xí)慣,但是你不要選擇 .html! 雖然《Spring in Action》選擇了 .html, 但是那是一種非常糟糕的作法, 特別是你整合 ApacheTomcat 的時(shí)候.

    • 配置 CharacterEncodingFilter (filter 標(biāo)簽), 否則你會(huì)發(fā)現(xiàn)中文亂碼. 因?yàn)槲业?jsp 和 html 文件都是 UTF-8 編碼的, 所以我在 param-value 標(biāo)簽中設(shè)置了 UTF-8. 估計(jì)你使用的是 GB2312 或者 GBK, 立即轉(zhuǎn)到 UTF-8 上來吧.

    • 分解配置文件. context-param 標(biāo)簽指明我們的配置文件還有 /WEB-INF/database.xml 和 /WEB-INF/applicationContext.xml. ContextLoaderListener(listener 標(biāo)簽) 由此得知配置文件是哪些, 它會(huì)將它們載入.

    因?yàn)槲覀儗?DispatcherServlet 命名為test, 所以我們?cè)?WEB-INF 目錄下建立一個(gè)名為 test-servlet.xml 的文件:

    test-servlet.xml:
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
    <beans>
     <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
      <property name="prefix" value="/WEB-INF/jsp/"/>
      <property name="suffix" value=".jsp"/>
     </bean>
     
     <bean id="simpleUrlHandlerMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
      <property name="mappings">
       <props>
        <prop key="/hello.do">helloController</prop>
       </props>
      </property>
     </bean>
     <bean id="helloController" class="com.ecnulxq.test.HelloController">
     </bean>
    </beans>
    它配置了以下功能:
    
    • 配置 InternalResourceViewResolver, 它是 jsp 渲染模板的處理器. 如果你告訴 InternalResourceViewResolver 處理一個(gè)名為 hello 的模板時(shí), 它會(huì)渲染 /WEB-INF/jsp/hello.jsp 文件. 把 jsp 文件放到 /WEB-INF/jsp/ 目錄下是被鼓勵(lì)的, 這樣可以防止用戶不經(jīng)過 Controller 直接訪問 jsp 文件從而出錯(cuò)(有些頑皮的人很喜歡這樣做).

    • 配置 SimpleUrlHandlerMapping, 在上面的配置文件中, /hello.do 的請(qǐng)求將被 helloController 處理. "/hello.do"和"helloController" 是變量, 你可以更改. 但是你注意到了嗎, hello.do 以 .do 作為后綴名. 如果這里(本文的條件下)你不使用.do 作為后綴名, 就沒有程序來處理這個(gè)請(qǐng)求了. 因?yàn)?DispatcherServlet 將收到的請(qǐng)求轉(zhuǎn)交給 SimpleUrlHandlerMapping, DispatcherServlet 收不到的請(qǐng)求, SimpleUrlHandlerMapping 當(dāng)然也收不到了. 你可以在 props 標(biāo)簽內(nèi)配置多個(gè) prop 標(biāo)簽.

    • 我們將在后面編寫com.ecnulxq.test.HelloController類.

    上面, 我們?cè)?web.xml 文件中告訴 ContextLoaderListener, 我們還有另外兩個(gè)配置文件 /WEB-INF/database.xml 和 /WEB-INF/applicationContext.xml.

    applicationContext.xml:

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">

    <beans>
     <bean id="propertyConfigure" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
      <property name="locations">
       <list>
        <value>/WEB-INF/jdbc.properties</value>
       </list>
      </property>
     </bean>

    </beans>

    它配置了以下功能:

    • 讀取 /WEB-INF/jdbc.properties 文件. 你可以在 list 標(biāo)簽中配置多個(gè) value 標(biāo)簽.

    database.xml:
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" ">
     
    <beans>
    <!-- Remove this if your database setting is fine.
      <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="${jdbc.driverClassName}"/>
        <property name="url" value="${jdbc.url}"/>
        <property name="username" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
      </bean>
    -->
      <!-- Transaction manager for a single JDBC DataSource
      <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
      </bean>
       -->
      <!--
      <bean id="attributeManager" class="com.ideawu.core.AttributeManager">
        <property name="dataSource" ref="dataSource"/>
      </bean>
      -->
    </beans>
    

    它配置了以下功能(不過,已經(jīng)注釋掉了):

    • 配置數(shù)據(jù)庫連接. 類似${jbbc.url}是一種訪問變量的方法. 我們可以從 /WEB-INF/jdbc.properties 中找到這個(gè)變量的值. 如果你的數(shù)據(jù)庫已經(jīng)配置好, 就將第一個(gè)注釋去掉.

    jdbc.properties:
    jdbc.driverClassName=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=UTF-8
    jdbc.username=root
    jdbc.password=root
    
    現(xiàn)在, 我們來編寫 Java 代碼吧.
     
    package com.ecnulxq.test;


    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;



    import org.springframework.web.servlet.ModelAndView;
    import org.springframework.web.servlet.mvc.Controller;



    /**
     * @author lxq ecnulxq@163.com
     * @version 創(chuàng)建時(shí)間:Oct 12, 2007 類說明
     *
     */
    public class HelloController implements Controller {



     public ModelAndView handleRequest(HttpServletRequest request,
       HttpServletResponse response) throws Exception {
      request.setAttribute("hello_1", "你好!Spring!");
      request.setAttribute("hello_2", "Hello!Spring!");
      return new ModelAndView("hello");
     }



    }


    return new ModelAndView("hello"); 告訴 InternalResourceViewResolver jsp 模板的名字叫作 hello. request.setAttribute() 設(shè)置的對(duì)象我們可以在 jsp 文件中使用.

    hello.jsp:

    <%@ page contentType="text/html; charset=UTF-8"%>
    <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
     <head>
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
      <title>Hello World!</title>
     </head>
     <body>



      <h2>
       ${hello_1}
      </h2>



      <h2>
       ${hello_2}
      </h2>



     </body>
    </html>

    posted @ 2008-06-05 12:46 秋楓故事 閱讀(902) | 評(píng)論 (1)編輯 收藏

    JSTL詳解(一轉(zhuǎn))

    7 Functions 標(biāo)簽庫

            稱呼 Functions 標(biāo)簽庫為標(biāo)簽庫,倒不如稱呼其為函數(shù)庫來得更容易理解些。因?yàn)?Functions 標(biāo)簽庫并沒有提供傳統(tǒng)的標(biāo)簽來為 JSP 頁面的工作服務(wù),而是被用于 EL 表達(dá)式語句中。在 JSP2.0 規(guī)范下出現(xiàn)的 Functions 標(biāo)簽庫為 EL 表達(dá)式語句提供了許多更為有用的功能。 Functions 標(biāo)簽庫分為兩大類,共 16 個(gè)函數(shù)。

    長(zhǎng)度函數(shù): fn:length

    字符串處理函數(shù): fn:contains 、 fn:containsIgnoreCase 、 fn:endsWith 、 fn:escapeXml 、 fn:indexOf 、 fn:join 、 fn:replace 、 fn:split 、 fn:startsWith 、 fn:substring 、 fn:substringAfter 、 fn:substringBefore 、 fn:toLowerCase 、 fn:toUpperCase 、 fn:trim

    以下是各個(gè)函數(shù)的用途和屬性以及簡(jiǎn)單示例。

    9.7.1  長(zhǎng)度函數(shù) fn:length 函數(shù)

         長(zhǎng)度函數(shù) fn:length 的出現(xiàn)有重要的意義。在 JSTL1.0 中,有一個(gè)功能被忽略了,那就是對(duì)集合的長(zhǎng)度取值。雖然 java.util.Collection 接口定義了 size 方法,但是該方法不是一個(gè)標(biāo)準(zhǔn)的 JavaBean 屬性方法(沒有 get,set 方法),因此,無法通過 EL 表達(dá)式“ ${collection.size} ”來輕松取得。

    fn:length 函數(shù)正是為了解決這個(gè)問題而被設(shè)計(jì)出來的。它的參數(shù)為 input ,將計(jì)算通過該屬性傳入的對(duì)象長(zhǎng)度。該對(duì)象應(yīng)該為集合類型或 String 類型。其返回結(jié)果是一個(gè) int 類型的值。下面看一個(gè)示例。

    <%ArrayList arrayList1 = new ArrayList();

                                arrayList1.add("aa");

                                arrayList1.add("bb");

                                arrayList1.add("cc");

    %>

    <%request.getSession().setAttribute("arrayList1", arrayList1);%>

    ${fn:length(sessionScope.arrayList1)}

    假設(shè)一個(gè) ArrayList 類型的實(shí)例“ arrayList1 ”,并為其添加三個(gè)字符串對(duì)象,使用 fn:length 函數(shù)后就可以取得返回結(jié)果為“ 3 ”。

    9.7.2  判斷函數(shù) fn:contains 函數(shù)

    fn:contains 函數(shù)用來判斷源字符串是否包含子字符串。它包括 string 和 substring 兩個(gè)參數(shù),它們都是 String 類型,分布表示源字符串和子字符串。其返回結(jié)果為一個(gè) boolean 類型的值。下面看一個(gè)示例。

    ${fn:contains("ABC", "a")}<br>

    ${fn:contains("ABC", "A")}<br>

    前者返回“ false ”,后者返回“ true ”。

    9.7.3 fn:containsIgnoreCase 函數(shù)

    fn:containsIgnoreCase 函數(shù)與 fn:contains 函數(shù)的功能差不多,唯一的區(qū)別是 fn:containsIgnoreCase 函數(shù)對(duì)于子字符串的包含比較將忽略大小寫。它與 fn:contains 函數(shù)相同,包括 string 和 substring 兩個(gè)參數(shù),并返回一個(gè) boolean 類型的值。下面看一個(gè)示例。

    ${fn:containsIgnoreCase("ABC", "a")}<br>

    ${fn:containsIgnoreCase("ABC", "A")}<br>

    前者和后者都會(huì)返回“ true ”。

    9.7.4  詞頭判斷函數(shù) fn:startsWith 函數(shù)

    fn:startsWith 函數(shù)用來判斷源字符串是否符合一連串的特定詞頭。它除了包含一個(gè) string 參數(shù)外,還包含一個(gè) subffx 參數(shù),表示詞頭字符串,同樣是 String 類型。該函數(shù)返回一個(gè) boolean 類型的值。下面看一個(gè)示例。

    ${fn:startsWith ("ABC", "ab")}<br>

    ${fn:startsWith ("ABC", "AB")}<br>

    前者返回“ false ”,后者返回“ true ”。

    9.7.5  詞尾判斷函數(shù) fn:endsWith 函數(shù)

    fn:endsWith 函數(shù)用來判斷源字符串是否符合一連串的特定詞尾。它與 fn:startsWith 函數(shù)相同,包括 string 和 subffx 兩個(gè)參數(shù),并返回一個(gè) boolean 類型的值。下面看一個(gè)示例。

    ${fn:endsWith("ABC", "bc")}<br>

    ${fn:endsWith("ABC", "BC")}<br>

    前者返回“ false ”,后者返回“ true ”。

    9.7.6  字符實(shí)體轉(zhuǎn)換函數(shù) fn:escapeXml 函數(shù)

    fn:escapeXml 函數(shù)用于將所有特殊字符轉(zhuǎn)化為字符實(shí)體碼。它只包含一個(gè) string 參數(shù),返回一個(gè) String 類型的值。

    9.7.8  字符匹配函數(shù) fn:indexOf 函數(shù)

    fn:indexOf 函數(shù)用于取得子字符串與源字符串匹配的開始位置,若子字符串與源字符串中的內(nèi)容沒有匹配成功將返回“ -1 ”。它包括 string 和 substring 兩個(gè)參數(shù),返回結(jié)果為 int 類型。下面看一個(gè)示例。

    ${fn:indexOf("ABCD","aBC")}<br>

    ${fn:indexOf("ABCD","BC")}<br>

    前者由于沒有匹配成功,所以返回 -1 ,后者匹配成功將返回位置的下標(biāo),為 1 。

    posted @ 2008-06-05 09:49 秋楓故事 閱讀(226) | 評(píng)論 (0)編輯 收藏

    hibernate二級(jí)緩存的實(shí)現(xiàn)

         摘要: 對(duì)于Hibernate這類ORM而言,緩存顯的尤為重要,它是持久層性能提升的關(guān)鍵.簡(jiǎn)單來講Hibernate就是對(duì)JDBC進(jìn)行封裝,以實(shí)現(xiàn)內(nèi)部狀態(tài)的管理,OR關(guān)系的映射等,但隨之帶來的就是數(shù)據(jù)訪問效率的降低,和性能的下降,而緩存就是彌補(bǔ)這一缺點(diǎn)的重要方法.     緩存就是數(shù)據(jù)庫數(shù)據(jù)在內(nèi)存中的臨時(shí)容器,包括數(shù)據(jù)庫數(shù)據(jù)在內(nèi)存中的臨時(shí)拷貝,它位于數(shù)據(jù)庫與數(shù)...  閱讀全文

    posted @ 2008-04-16 18:17 秋楓故事 閱讀(1763) | 評(píng)論 (1)編輯 收藏

    深入淺出SQL教程之Group By和Having

    在介紹GROUP BY 和 HAVING 子句前,我們必需先講講sql語言中一種特殊的函數(shù):聚合函數(shù),例如SUM, COUNT, MAX, AVG等。這些函數(shù)和其它函數(shù)的根本區(qū)別就是它們一般作用在多條記錄上。 

    SELECT SUM(population) FROM bbc 

    這里的SUM作用在所有返回記錄的population字段上,結(jié)果就是該查詢只返回一個(gè)結(jié)果,即所有國(guó)家的總?cè)丝跀?shù)。 

    通過使用GROUP BY 子句,可以讓SUM 和 COUNT 這些函數(shù)對(duì)屬于一組的數(shù)據(jù)起作用。當(dāng)你指定 GROUP BY region 時(shí), 屬于同一個(gè)region(地區(qū))的一組數(shù)據(jù)將只能返回一行值,也就是說,表中所有除region(地區(qū))的字段,只能通過 SUM, COUNT等聚合函數(shù)運(yùn)算后返回一個(gè)值。  HAVING子句可以讓我們篩選成組后的各組數(shù)據(jù),WHERE子句在聚合前先篩選記錄.也就是說作用在GROUP BY 子句和HAVING子句前,而 HAVING子句在聚合后對(duì)組記錄進(jìn)行篩選。 

    讓我們還是通過具體的實(shí)例來理解GROUP BY 和 HAVING 子句,還采用第三節(jié)介紹的bbc表。 

    SQL實(shí)例: 

    一、顯示每個(gè)地區(qū)的總?cè)丝跀?shù)和總面積: 

    SELECT region, SUM(population), SUM(area)

    FROM bbc

    GROUP BY region

     

    先以region把返回記錄分成多個(gè)組,這就是GROUP BY的字面含義。分完組后,然后用聚合函數(shù)對(duì)每組中的不同字段(一或多條記錄)作運(yùn)算。 

    二、 顯示每個(gè)地區(qū)的總?cè)丝跀?shù)和總面積.僅顯示那些面積超過1000000的地區(qū)。 

    SELECT region, SUM(population), SUM(area)

    FROM bbc

    GROUP BY region

    HAVING SUM(area)>1000000

     

    在這里,我們不能用where來篩選超過1000000的地區(qū),因?yàn)楸碇胁淮嬖谶@樣一條記錄。 

    相反,HAVING子句可以讓我們篩選成組后的各組數(shù)據(jù)。


    group by分組統(tǒng)計(jì)SQL語句(實(shí)例)

    用一條查詢語句,查出各姓名的數(shù)值余額.

    用戶表:
    姓名
    a
    b
    c
    ....

    扣費(fèi)表:
    姓名 數(shù)值
    a 3.5
    b 5.2
    a 2
    ...

    充值表:
    姓名 數(shù)值
    b 10
    a 10
    a 10.5
    ...

    返回:
    姓名 差額(充值和-扣費(fèi)和)

    測(cè)試通過

    select table1.TNAME,table1.TelName, (table3.充值-table2.扣費(fèi)) as 差額
    from 用戶表 table1,(select TelName,sum(TelQryh)as 扣費(fèi) from 扣費(fèi)表 group by TelName)table2,
    (select TelName,sum(TelQryc)as 充值 from 充值表 group by TelName)table3 where
    table1.TelName=table2.TelName and table1.TelName=table3.TelName

    posted @ 2008-04-12 19:32 秋楓故事 閱讀(146) | 評(píng)論 (0)編輯 收藏

    (轉(zhuǎn))Struts Spring Hibernate 整合報(bào)空指針解決方法

    最近一直在弄WebWork,Struts都快忘了。今天又自己小試了一下SSH,結(jié)果每次都是報(bào)空指針異常,經(jīng)過一番研究,發(fā)現(xiàn),如果不把a(bǔ)ction的type改成

    org.springframework.web.struts.DelegatingActionProxy

    的話,就會(huì)報(bào)這個(gè)

    java.lang.NullPointerException

     com.test.struts.action.UserAction.show(UserAction.java:46)
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    java.lang.reflect.Method.invoke(Method.java:597)
    org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:274)
    org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:194)
    org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:419)
    org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:224)
    org.apache.struts.action.ActionServlet.process(ActionServlet.java:1194)
    org.apache.struts.action.ActionServlet.doGet(ActionServlet.java:414)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:690)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
    解決辦法:
    1.在struts-config.xml的action把type改成org.springframework.web.struts.DelegatingActionProxy,例如:
    <action attribute="userForm" input="/index.jsp" name="userForm"
              parameter="param" path="/user" scope="request"
              type="org.springframework.web.struts.DelegatingActionProxy"
              validate="false">
              <forward name="success" path="/success.jsp" />
    </action>
    2.在spring的配置文件(applicationContext.xml)里添加一些代碼:
    <bean id="transactionManager"
             class="org.springframework.orm.hibernate3.HibernateTransactionManager">
             <property name="sessionFactory">
              <ref bean="sessionFactory" />
             </property>
    </bean>
    給DAO加上代理
    <bean id="UserDAOIProxy"
             class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
             <property name="transactionManager">
              <ref bean="transactionManager" />
             </property>
             <property name="target">
              <ref bean="UserDao" />
             </property>
             <property name="transactionAttributes">
              <props>
               <prop key="create*">PROPAGATION_REQUIRED</prop>
               <prop key="update*">PROPAGATION_REQUIRED</prop>
               <prop key="delete*">PROPAGATION_REQUIRED</prop>
               <prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
              </props>
             </property>
    </bean>
    3.更改Service的引用
     <bean name="UserService"
             class="com.test.service.impl.UserServiceImpl">
             <property name="userDao">
              <ref bean="
    UserDAOIProxy" />
             </property>
    </bean>
    這樣就不會(huì)報(bào)那個(gè)異常了,測(cè)試通過^_^
    我的配置文件代碼:
    applicationContext.xml
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
    <beans>
    <bean id="dataSource"
             class="org.apache.commons.dbcp.BasicDataSource">
             <property name="driverClassName"
              value="oracle.jdbc.driver.OracleDriver">
             </property>
             <property name="url"
              value="jdbc:oracle:thin:@192.192.192.19:1521:orcl">
             </property>
             <property name="username" value="sunyu"></property>
             <property name="password" value="19830317"></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.Oracle9Dialect
               </prop>
               <prop key="hibernate.show_sql">true</prop>
              </props>
             </property>
             <property name="mappingResources">
              <list>
               <value>com/test/model/TestUser.hbm.xml</value>
              </list>
             </property>
    </bean>
    <bean id="transactionManager"
             class="org.springframework.orm.hibernate3.HibernateTransactionManager">
             <property name="sessionFactory">
              <ref bean="sessionFactory" />
             </property>
    </bean>
    <bean name="UserDao" class="com.test.dao.impl.UserDaoImpl">
             <property name="sessionFactory">
              <ref bean="sessionFactory" />
             </property>
    </bean>
    <bean id="UserDAOIProxy"
             class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
             <property name="transactionManager">
              <ref bean="transactionManager" />
             </property>
             <property name="target">
              <ref bean="UserDao" />
             </property>
             <property name="transactionAttributes">
              <props>
               <prop key="create*">PROPAGATION_REQUIRED</prop>
               <prop key="update*">PROPAGATION_REQUIRED</prop>
               <prop key="delete*">PROPAGATION_REQUIRED</prop>
               <prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
              </props>
             </property>
    </bean>
    <bean name="UserService"
             class="com.test.service.impl.UserServiceImpl">
             <property name="userDao">
              <ref bean="UserDAOIProxy" />
             </property>
    </bean>
    <bean name="/user" class="com.test.struts.action.UserAction">
             <property name="userService">
              <ref bean="UserService" />
             </property>
    </bean>
    </beans>
    struts-config.xml
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.2//EN" "
    http://struts.apache.org/dtds/struts-config_1_2.dtd
    ">
    <struts-config>
    <data-sources />
    <form-beans>
             <form-bean name="userForm" type="com.test.struts.form.UserForm" />
    </form-beans>
    <global-exceptions />
    <global-forwards />
    <action-mappings>
             <action attribute="userForm" input="/index.jsp" name="userForm"
              parameter="param" path="/user" scope="request"
              type="org.springframework.web.struts.DelegatingActionProxy"
              validate="false">
              <forward name="success" path="/success.jsp" />
             </action>
    </action-mappings>
    <message-resources parameter="com.test.struts.ApplicationResources" />
    <plug-in
             className="org.springframework.web.struts.ContextLoaderPlugIn">
             <set-property property="contextConfigLocation"
              value="/WEB-INF/applicationContext.xml" />
    </plug-in>

    </struts-config>



    ------------------------------------------
    第二種方法,如果在struts-config.xml里面加上

    <controller>
    <set-property property="processorClass"
    value="org.springframework.web.struts.DelegatingRequestProcessor" />
    </controller>

    這樣action就不需要type屬性了
    ----------------------------------------------

    posted @ 2008-04-03 19:14 秋楓故事 閱讀(2446) | 評(píng)論 (0)編輯 收藏

    (轉(zhuǎn))jboss部署ejb

    開發(fā)sessionbean EJB最少也需要三個(gè)class,remote interface,home interface,and bean implementation(bean行為).

    1. remote interface 用來揭示EJB對(duì)外的一些方法.

    package helloWorld; import javax.ejb.EJBObject;
    import java.rmi.RemoteException;
    public interface RemoteHello extends EJBObject
    { public String HelloEcho(String inputString) throws RemoteException; }
    2.home interface 是用來規(guī)定怎樣創(chuàng)建一個(gè)實(shí)現(xiàn)remote interface的bean.
    package helloWorld;
    import java.io.Serializable;
    import java.rmi.RemoteException;
    import javax.ejb.CreateException;
    import javax.ejb.EJBHome;
    public interface HomeHello extends EJBHome

    { RemoteHello create() throws RemoteException, CreateException; }

    3.bean implementation 是提供方法的實(shí)現(xiàn),這些方法在上述兩種interface中都有規(guī)定了.

    package helloWorld;

    import java.rmi.RemoteException;

    import javax.ejb.SessionBean;

    import javax.ejb.SessionContext;

    public class HelloBean implements SessionBean{

       public String HelloEcho(String inputString) {

         System.out.println("Someone called 'Hello Echo Successed!'");

         return "*********" + inputString + "*********"; }

         /** Empty method body  */

         public void ejbCreate() {

            System.out.println("Ejb 4 is creating!...");}

         /** Every ejbCreate() method ALWAYS needs a corresponding   ejbPostCreate () method with exactly the same parameter types.   */

    public void ejbPostCreate() {}

    /** Empty method body   */

    public void ejbRemove() {

        System.out.println("Ejb 4 is removing!...");}

     /** Empty method body */

    public void ejbActivate() {

       System.out.println("Ejb 4 is activating!...");}

    /** Empty method body */

    public void ejbPassivate()

     {}

    /** Empty method body   */

    public void setSessionContext(SessionContext sc)

     {}

    }

    部署jar

    這些classes必須打包進(jìn)一個(gè)JAR文件中,JAR文件中包含了目錄結(jié)構(gòu)和包的層次.在本例中, 這些classes是在包helloworld,這樣他們需要在目錄helloWorld/ 下.

    部署發(fā)布描述器ejb-jar.XML和jboss.xml
    在JAR文檔創(chuàng)建之前,還需要一個(gè)叫META-INF的目錄,這是存放部署發(fā)布描述器的(一般叫ejb-jar.xml).

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD EntERPrise JavaBeans 2.0//EN" "
    http://java.sun.com/dtd/ejb-jar_2_0.dtd">
    <ejb-jar>
     <description>Neosue Helloworld Sample Application</description>
     <display-name>Helloworld EJB</display-name>
     <enterprise-beans>
      <session>
       <ejb-name>Helloworld</ejb-name>
       <!-- home interface -->
       <home>helloWorld.HomeHello</home>
       <!-- remote interface -->
       <remote>helloWorld.RemoteHello</remote>
       <!-- bean implementation -->
       <ejb-class>helloWorld.HelloBean</ejb-class>
       <session-type>Stateless</session-type>
       <transaction-type>Bean</transaction-type>
      </session>
     </enterprise-beans>
    </ejb-jar>

    jboss.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE jboss PUBLIC "-//JBoss//DTD JBOSS 4.0//EN" "
    http://www.jboss.org/j2ee/dtd/jboss_4_0.dtd">
    <jboss>
     <enterprise-beans>
      <session>
       <ejb-name>Helloworld</ejb-name>
       <jndi-name>Helloworld/Hello</jndi-name>
      </session>
     </enterprise-beans>
    </jboss>
    雖然有了上面你的應(yīng)用程序和JNDI name的梆定,但是一旦部署發(fā)布到JBoss服務(wù)器上,你還需要一個(gè)jndi.properties文件,以告訴調(diào)用你程序的客戶端請(qǐng)求到哪里去初始化JNDI naming service.

    測(cè)試程序:

    import javax.naming.Context;

    import javax.naming.InitialContext;

    import javax.rmi.PortableRemoteObject;

    import helloWorld.*;

    public class MyTest {

       public static void main(String[] args) {

          try{ Context ctx=new InitialContext();

               Object ref=ctx.lookup("Helloworld/Hello");

               HomeHello home=(HomeHello)PortableRemoteObject.narrow(ref,HomeHello.class);

               RemoteHello user=home.create(); System.out.println(user.HelloEcho("So easy!"));

            }catch(Exception e) {

              e.printStackTrace();

            }

       }

    }

    Jboss EJB 部署步驟 建立 remote interface-->home interface-->and bean implementation--> ejb-jar.xml-->jboss.xml--打包(package[jar cvf packageName.jar .])-->復(fù)制到j(luò)boss deploy目錄.

    ---------------------------------------------------------
    原文 URL
    http://blog.blogchina.com/refer.159508.html
    ---------------------------------------------------------
    補(bǔ)充說明如下:

    OS: windows 2000;
    JDK: 1.5.0rc;
    JBoss: 4.0

    HelloWorld.jar
    |--META-INF
    |      |--jboss.xml
    |      |--ejb-jar.xml
    |      |--MANIFEST.MF (自動(dòng)生成)
    |--helloWorld
           |--RemoteHello.class
           |--jndi.properties
           |--HomeHello.class
           |--HelloBean.class


    其中 測(cè)試文件 MyTest.class 同目錄拷貝一份 jndi.properties 文件過來.

    jndi.properties 的內(nèi)容如下:

    java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
    java.naming.provider.url=localhost:1099
    java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces

    posted @ 2008-03-30 19:38 秋楓故事 閱讀(1054) | 評(píng)論 (0)編輯 收藏

    ( 轉(zhuǎn))重寫自已的HashCode()方法

     大家都知道,在Java里對(duì)對(duì)象的操作是基于引用的。而當(dāng)我們需要對(duì)一組對(duì)象操作的時(shí)候,  就需要有接收這一組引用的容器。平時(shí)我們最常用的就是數(shù)組。在Java里可以定義一個(gè)對(duì)象數(shù)組來完成許多操作。可是,數(shù)組長(zhǎng)度是固定的,如果我們需要更 加靈活的解決方案該怎么辦呢?

           Java提供了container  classes來解決這一問題。container  classes包括兩個(gè)部分:Collection和Map。

    它們的結(jié)構(gòu)是這樣的: 

           本文重點(diǎn)介紹HashMap。首先介紹一下什么是Map。在數(shù)組中我們是通過數(shù)組下標(biāo)來對(duì)其內(nèi)容索引的,  而在Map中我們通過對(duì)象來對(duì)對(duì)象進(jìn)行索引,用來索引的對(duì)象叫做key,其對(duì)應(yīng)的對(duì)象叫做value。  在下文中會(huì)有例子具體說明。

           再來看看HashMap和TreeMap有什么區(qū)別。HashMap通過hashcode對(duì)其內(nèi)容進(jìn)行快速查找,而TreeMap中所有的元素都保持著 某種固定的順序,如果你需要得到一個(gè)有序的結(jié)果你就應(yīng)該使用TreeMap(HashMap中元素的排列順序是不固定的)。

    下面就要進(jìn)入本文的主題了。先舉個(gè)例子說明一下怎樣使用HashMap:













    程序代碼:
    import java.util.*; 
    public class Exp1 { 
         public static void main(String[] args){ 
              HashMap h1=new HashMap(); 
              Random r1=new Random();     
              for(int i=0;i< 1000;i++){ 
                   Integer t=new Integer(r1.nextInt(20)); 
                   if(h1.containsKey(t)) 
                        ((Ctime)h1.get(t)).count++; 
                   else 
                        h1.put(t, new Ctime()); 
              } 
              System.out.println(h1); 
         } 

    class Ctime{ 
         int count=1; 
         public String toString(){ 
              return Integer.toString(count); 
         } 


               在HashMap中通過get()來獲取value,通過put()來插入value,ContainsKey()則用來檢驗(yàn)對(duì)象是否已經(jīng)存在。可以看 出,和ArrayList的操作相比,HashMap除了通過key索引其內(nèi)容之外,別的方面差異并不大。

             前面介紹了,HashMap是基于HashCode的,在所有對(duì)象的超類Object中有一個(gè)HashCode()方法,  但是它和equals方法一樣,并不能適用于所有的情況,這樣我們就需要重寫自己的HashCode()方法。
    下面就舉這樣一個(gè)例子:













    程序代碼:
    import java.util.*; 
    public class Exp2 { 
         public static void main(String[] args){ 
              HashMap h2=new HashMap(); 
              for(int i=0;i< 10;i++) 
                   h2.put(new Element(i), new Figureout()); 
              System.out.println("h2:"); 
              System.out.println("Get the result for Element:"); 
              Element test=new Element(5); 
              if(h2.containsKey(test)) 
                   System.out.println((Figureout)h2.get(test)); 
              else 
                   System.out.println("Not found"); 
         } 

    class Element{ 
         int number; 
         public Element(int n){ 
              number=n; 
         } 

    class Figureout{ 
         Random r=new Random(); 
         boolean possible=r.nextDouble()>0.5; 
         public String toString(){ 
              if(possible) 
                   return "OK!"
              else 
                   return "Impossible!"
         } 

     
           在這個(gè)例子中,Element用來索引對(duì)象Figureout,也即Element為key,F(xiàn)igureout為value。  在Figureout中隨機(jī)生成一個(gè)浮點(diǎn)數(shù),如果它比0.5大,打印“OK!”,否則打印“Impossible!”。  之后查看Element(5)對(duì)應(yīng)的Figureout結(jié)果如何。  

           結(jié)果卻發(fā)現(xiàn),無論你運(yùn)行多少次,得到的結(jié)果都是“Not  found”。也就是說索引Element(5)并不在HashMap中。這怎么可能呢?

           原因得慢慢來說:Element的HashCode方法繼承自O(shè)bject,而Object中的HashCode方法返回的HashCode對(duì)應(yīng)于當(dāng)前 的地址,也就是說對(duì)于不同的對(duì)象,即使它們的內(nèi)容完全相同,用HashCode()返回的值也會(huì)不同。這樣實(shí)際上違背了我們的意圖。因?yàn)槲覀冊(cè)谑褂?HashMap時(shí),  希望利用相同內(nèi)容的對(duì)象索引得到相同的目標(biāo)對(duì)象,這就需要HashCode()在此時(shí)能夠返回相同的值。

           在上面的例子中,我們期望new  Element(i)  (i=5)與  Element  test=new  Element(5)是相同的,  而實(shí)際上這是兩個(gè)不同的對(duì)象,盡管它們的內(nèi)容相同,但它們?cè)趦?nèi)存中的地址不同。因此很自然的,  上面的程序得不到我們?cè)O(shè)想的結(jié)果。下面對(duì)Element類更改如下:













    程序代碼:
    class Element{ 
      int number; 
      public Element(int n){ 
        number=n; 
     } 
      public int hashCode(){ 
       return number; 
      } 
      public boolean equals(Object o){ 
       return (o instanceof Element) && (number==((Element)o).number); 
      } 


               在這里Element覆蓋了Object中的hashCode()和equals()方法。覆蓋hashCode()使其以number的值作為 hashcode返回,這樣對(duì)于相同內(nèi)容的對(duì)象來說它們的hashcode也就相同了。而覆蓋equals()是為了在HashMap判斷兩個(gè)key是否 相等時(shí)使結(jié)果有意義(有關(guān)重寫equals()的內(nèi)容可以參考我的另一篇文章《重新編寫Object類中的方法  》)。修改后的程序運(yùn)行結(jié)果如下:

    h2:  
    Get  the  result  for  Element:  
    Impossible!  

    請(qǐng)記住:如果你想有效的使用HashMap,你就必須重寫在其的HashCode()。

    還有兩條重寫HashCode()的原則:

           不必對(duì)每個(gè)不同的對(duì)象都產(chǎn)生一個(gè)唯一的hashcode,只要你的HashCode方法使get()能夠得到put()放進(jìn)去的內(nèi)容就可以了。即“不為 一原則”。  生成hashcode的算法盡量使hashcode的值分散一些,  不要很多hashcode都集中在一個(gè)范圍內(nèi),這樣有利于提高HashMap的性能。即“分散原則”。  至于第二條原則的具體原因,有興趣者可以參考Bruce  Eckel的《Thinking  in  Java》,
    在那里有對(duì)HashMap內(nèi)部實(shí)現(xiàn)原理的介紹,這里就不贅述了。

           掌握了這兩條原則,你就能夠用好HashMap編寫自己的程序了。不知道大家注意沒有,  java.lang.Object中提供的三個(gè)方法:clone(),equals()和hashCode()雖然很典型,  但在很多情況下都不能夠適用,它們只是簡(jiǎn)單的由對(duì)象的地址得出結(jié)果。  這就需要我們?cè)谧约旱某绦蛑兄貙懰鼈儯鋵?shí)java類庫中也重寫了千千萬萬個(gè)這樣的方法。  利用面向?qū)ο蟮亩鄳B(tài)性——覆蓋,Java的設(shè)計(jì)者很優(yōu)雅的構(gòu)建了Java的結(jié)構(gòu),也更加體現(xiàn)了Java是一門純OOP語言的特性。

         Java提供的Collection和Map的功能是十分強(qiáng)大的,它們能夠使你的程序?qū)崿F(xiàn)方式更為靈活,  執(zhí)行效率更高。希望本文能夠?qū)Υ蠹腋玫氖褂肏ashMap有所幫助。

    posted @ 2008-03-28 11:17 秋楓故事 閱讀(252) | 評(píng)論 (0)編輯 收藏

    產(chǎn)生對(duì)象個(gè)數(shù)問題

    String a = "hello";
    String b = "world";
    String c = "ok";
    String d = "is";
    String result = a+b+c+d;
    問:共產(chǎn)生多少個(gè)對(duì)象?

    答:
    現(xiàn)在的編譯器早就對(duì)這些代碼作了優(yōu)化,編譯成如下:
    String a = "hello";
    String b = "world";
    String c = "ok";
    String d = "is";
    String result = new StringBuffer().append(a),append(b),append(c).append(d).toString();
    因此產(chǎn)生了6個(gè)對(duì)象,其中5個(gè)字符串對(duì)象,一個(gè)StringBuffer臨時(shí)對(duì)象。

    posted @ 2008-03-28 10:39 秋楓故事 閱讀(311) | 評(píng)論 (0)編輯 收藏

    <2008年3月>
    2425262728291
    2345678
    9101112131415
    16171819202122
    23242526272829
    303112345

    導(dǎo)航

    統(tǒng)計(jì)

    • 隨筆 - 63
    • 文章 - 0
    • 評(píng)論 - 14
    • 引用 - 0

    常用鏈接

    留言簿(2)

    隨筆分類

    隨筆檔案

    新聞檔案

    搜索

    •  

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 麻豆亚洲AV成人无码久久精品 | 亚洲国产精品第一区二区三区| 亚洲女人初试黑人巨高清| 日日操夜夜操免费视频| 免费人成视频在线观看视频| 亚洲国产日韩在线观频| 疯狂做受xxxx高潮视频免费| 国产yw855.c免费视频| 亚洲欧美熟妇综合久久久久| 天天天欲色欲色WWW免费| 亚洲欧美自偷自拍另类视| 成人爱做日本视频免费| 高潮毛片无遮挡高清免费| heyzo亚洲精品日韩| 亚洲综合视频在线| 人人爽人人爽人人片A免费 | 亚洲人成网亚洲欧洲无码| 在线免费视频一区二区| 国产精品亚洲专区无码WEB| 免费国产在线观看| 中文字幕av免费专区| 国产亚洲综合一区柠檬导航| 99久9在线|免费| 亚洲欧洲精品成人久久曰| 四虎永久免费地址在线网站| 好湿好大好紧好爽免费视频| 毛片A级毛片免费播放| 最新亚洲卡一卡二卡三新区 | 真实国产乱子伦精品免费| 亚洲国产精品白丝在线观看| 97无码免费人妻超级碰碰夜夜| 久久亚洲国产视频| 无人在线直播免费观看| 国产成人综合亚洲一区| 精品亚洲一区二区| 大地资源在线观看免费高清| 日本视频免费观看| 97亚洲熟妇自偷自拍另类图片| 性感美女视频在线观看免费精品 | 亚洲国色天香视频| 免费在线观看视频a|