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

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

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

    與Java相伴的日子
    相識,相知,相戀,到相守......我的日子因你的到來而充實(shí),我的日子因你的存在而多姿!
    posts - 4,comments - 31,trackbacks - 0
    ??????? J2EE 即Java2平臺企業(yè)版,它提供了基于組件的方式來設(shè)計、開發(fā)、組裝和部署企業(yè)應(yīng)用。J2EE使用多層分布式的應(yīng)用模型,這個多層通常通過三層或四層來實(shí)現(xiàn):

    ?????????1、客戶層,運(yùn)行在客戶計算機(jī)上的組件。
    ???????? 2、Web 層,運(yùn)行在J2EE服務(wù)器上的組件。
    ?????????3、業(yè)務(wù)層,同樣是運(yùn)行在J2EE服務(wù)器上的組件。
    ?????????4、企業(yè)信息系統(tǒng)層(EIS),是指運(yùn)行在EIS服務(wù)器上的軟件系統(tǒng)。
    ??????
    ?????????以上層次一般也指三層應(yīng)用,因分布在三個不同位置:客戶計算機(jī)、J2EE服務(wù)器及后臺的數(shù)據(jù)庫或過去遺留下來的系統(tǒng)。請看圖例:?????????????????????????????????

    ?????????????????????????

    ??????????

    ?????????????????????
    ?????????J2EE組件

    ?????????J2EE應(yīng)用程序是由組件構(gòu)成的。J2EE組件是一個封裝了功能的軟件單元,能夠與相關(guān)的一些類和文件一起組成J2EE應(yīng)用程序。
    ?????????1、應(yīng)用程序客戶端和Applet是指運(yùn)行在客戶計算機(jī)上的組件。
    ?????????2、基于Java Servlet和JSP技術(shù)的組件叫Web組件,它們運(yùn)行在服務(wù)器上。
    ?????????3、企業(yè)JavaBean(EJB)組件叫業(yè)務(wù)組件,同樣運(yùn)行在服務(wù)器上。

    ??????J2EE客戶端

    ?????????J2EE客戶端可以是一個Web組件或者是一個應(yīng)用程序客戶端。
    ?????????1、Web客戶端??
    ?????????包括兩部分,首先是那些動態(tài)Web頁面(HTML、XML等),這些組件運(yùn)行在Web層;另一個是Web瀏覽器,由客戶機(jī)上的瀏覽器從服務(wù)器接收并且解析和顯示W(wǎng)eb頁面。
    ?????????2、小應(yīng)用程序(Applet)?
    ?????????需要運(yùn)行在客戶端安裝了Java虛擬機(jī)的Web瀏覽器上。
    ?????????3、應(yīng)用程序客戶端
    ?????????J2EE應(yīng)用程序客戶端運(yùn)行在客戶機(jī)上,能提供強(qiáng)大而靈活易用的用戶界面,如使用Swing或AWT創(chuàng)建的圖形化的用戶界面(GUI)。應(yīng)用程序可直接訪問運(yùn)行在業(yè)務(wù)層的企業(yè)Bean,如果需求允許,也可以打開HTTP連接來建立與運(yùn)行在Web層上的Servlet之間的通訊。
    ?????????4、JavaBean組件架構(gòu)
    ?????????在服務(wù)器和客戶端兩層中也可能包括了基于JavaBean的組件架構(gòu),通過JavaBean來實(shí)現(xiàn)數(shù)據(jù)的流動,可以是在應(yīng)用程序客戶或Applet與運(yùn)行在J2EE服務(wù)器上的組件之間,或者是在J2EE服務(wù)器和后臺數(shù)據(jù)庫之間。(不過JavaBean組件并沒有包含在J2EE規(guī)范里)
    ?????????5、J2EE服務(wù)的通訊
    ?????????客戶層與J2EE服務(wù)器上運(yùn)行的業(yè)務(wù)層之間的通訊可以是直接的,也可以通過運(yùn)行在Web層中的Servlet和JSP來實(shí)現(xiàn),在這種情況下,客戶端運(yùn)行在瀏覽器中。

    ?????????Web組件

    ?????????J2EE的Web組件可以是Servlet或JSP頁面。在應(yīng)用程序組裝過程中,靜態(tài)HTML頁面和Applet也可以一起打包成Web組件,但這并不是J2EE規(guī)范所認(rèn)可的Web組件。

    ?????????業(yè)務(wù)組件

    ?????????業(yè)務(wù)代碼是指那些由位于業(yè)務(wù)層的企業(yè)Bean(EJB)執(zhí)行的邏輯,它們能夠解決或滿足特定的商業(yè)領(lǐng)域的一些需求。有三種不同類型的企業(yè)Bean:會話Bean、實(shí)體Bean和消息驅(qū)動Bean。會話Bean代表客戶一次短暫的會話過程,當(dāng)客戶執(zhí)行完成后,會話Bean以及它所包含的數(shù)據(jù)也隨之消失。實(shí)體Bean代表的是持久的數(shù)據(jù),即存儲在數(shù)據(jù)庫表中的一行記錄,即使客戶終止或者服務(wù)器關(guān)閉,在J2EE底層的服務(wù)會確保實(shí)體Bean的數(shù)據(jù)被保存下來。

    ?????????企業(yè)信息系統(tǒng)層

    ?????????企業(yè)信息系統(tǒng)層處理企業(yè)信息系統(tǒng)的軟件,包括企業(yè)組織結(jié)構(gòu)系統(tǒng),例如企業(yè)資源計劃(ERP)、大型的事務(wù)處理、數(shù)據(jù)庫系統(tǒng)及其他歷史上遺留下來的信息系統(tǒng)。

    ?????????J2EE的主要技術(shù)
    ?????????
    ?????????JDBC(Java Database Connectivity): JDBC API?為訪問數(shù)據(jù)庫提供一種統(tǒng)一的方式,其接口包括在java.sql和javax.sql兩個包中。
    ?????????JNDI(Java Name and Directory Interface):Java名稱和目錄服務(wù),包含在javax.naming 及其子包中。它為應(yīng)用程序提供標(biāo)準(zhǔn)的目錄操作的方法 ,如獲得對象的關(guān)聯(lián)屬性,根據(jù)它們的屬性搜尋對象等。使用JNDI,一個J2EE應(yīng)用程序可以存儲和動態(tài)獲取任何類型的命名Java對象。JNSI分為兩種:應(yīng)用程序編程接口(API)和服務(wù)供應(yīng)商接口(SPI)。
    ?????????EJB(Enterprise JavaBean):參見上文。
    ?????????RMI(Remote Method Invoke):即遠(yuǎn)程方法調(diào)用,它使用了連續(xù)序列的方式在客戶端和服務(wù)器端傳遞數(shù)據(jù),將面向?qū)ο缶幊棠P蛿U(kuò)展到了客戶機(jī)/服務(wù)器系統(tǒng),使開發(fā)者可以用本地對象調(diào)用的語法進(jìn)行遠(yuǎn)程調(diào)用。
    ?????????JSP(Java Server Pages):Java服務(wù)器頁,可以在HTML代碼中嵌入部分Java代碼,這種文件由服務(wù)器編譯成Servlet并執(zhí)行,然后將產(chǎn)生的結(jié)果作為一個HTML文件傳給瀏覽器。
    ?????????Servlet:Java Servlet實(shí)質(zhì)上是一種小型的,與平臺無關(guān)的Java類,它由容器管理并被編譯成平臺無關(guān)的字節(jié)代碼,可以動態(tài)地加載到一個Web服務(wù)器上,并由該Web服務(wù)器運(yùn)行。
    ?????????JMS(Java Message Service):Java 消息服務(wù),是用于和企業(yè)消息傳遞系統(tǒng)相互通信的應(yīng)用程序接口。企業(yè)消息傳遞系統(tǒng)又稱為面向消息的中間件(Message Oriented Middle Ware, MOM),它使用松耦合的、非常靈活的方式來集成應(yīng)用程序,在存儲和轉(zhuǎn)發(fā)的基礎(chǔ)上支持應(yīng)用程序間數(shù)據(jù)的異步傳遞;
    每個應(yīng)用程序都只與作為中介的MOM通信。
    ?????????JTA(Java Transaction API):指定事務(wù)管理與分布式事務(wù)中涉及的其他系統(tǒng)之間的各種高級接口。
    ?????????JavaMail:用于存取郵件服務(wù)器的API,提供了一套用于郵件服務(wù)的抽象類。
    ?????????JAXP(Java API for XML Processing):Java XML 處理API,支持使用DOM、SAX和XSLT對XML文檔進(jìn)行處理。
    ?????????J2EE Connector Architecture:J2EE工具提供商提供的J2EE連接體系結(jié)構(gòu),通過它可以建立支持訪問企業(yè)信息系統(tǒng)的資源適配器。??????

    ????????歸納幾個概念:

    ?????????EJB

    ?????????即Enterprise JavaBean,一種組件架構(gòu),用于開發(fā)和部署面向?qū)ο蟮摹⒎植际降摹⑵髽I(yè)級的應(yīng)用程序。所開發(fā)的應(yīng)用程序使用EJB架構(gòu)來實(shí)現(xiàn)可擴(kuò)展性及管理事務(wù)和安全。
    ?????????EJB包括會話Bean(session bean)、實(shí)體Bean(entity bean)和消息驅(qū)動Bean(message-driven bean)。其中會話Bean分為無狀態(tài)會話Bean(stateless session bean)和有狀態(tài)會話Bean(stateful session bean)。而實(shí)體Bean又分為Bean管理實(shí)體Bean和容器管理實(shí)體Bean。由于這種Bean對應(yīng)于數(shù)據(jù)庫中的記錄,所以數(shù)據(jù)庫記錄的任何改變也被同步到組件池中的相關(guān)Bean中,這個過程叫做持久性(persistenced),這是實(shí)體Bean最重要的一個特征。根據(jù)持久性操作方式的不同分為:容器管理持久性(Container-Managed Persistence,CMP)和Bean管理持久性(Bean-Managed Persistence,BMP)。

    ?????????容器

    ?????????即container,一個實(shí)體,它管理著組件的生命周期、安全、部署和運(yùn)行時服務(wù)。每個類型的容器都只提供與相應(yīng)類型的組件相關(guān)的服務(wù),如EJB、Web、JSP、Applet和應(yīng)用程序客戶端。其中,EJB容器和Web容器都運(yùn)行在J2EE服務(wù)器中。

    ?????????J2EE

    ?????????即Java 2 Platform Enterprise Edition,Java 2 平臺企業(yè)版。是開發(fā)和部署企業(yè)應(yīng)用程序的一種平臺或環(huán)境。它由一系列服務(wù)、應(yīng)用程序編程接口(API)、提供多層開發(fā)的功能性的協(xié)議以及基于Web的應(yīng)用程序組成。

    ?????????


    ?



    ?

    posted @ 2006-04-16 01:28 南一郎 閱讀(2954) | 評論 (0)編輯 收藏
         摘要: 以下是我用Swing 組件編寫的記事本,功能是模仿微軟的,使用了觀感,自我覺得界面比Win的記事本更為好看(臭屁一下吧)。除了沒有做字體選擇之外,其他功能基本都有了吧。 /**?**/ /** ?*Author: Zhang?Zhijian? ?*Mail: q...  閱讀全文
    posted @ 2006-04-15 01:06 南一郎 閱讀(3223) | 評論 (14)編輯 收藏
         摘要: 我做過的一個項(xiàng)目,需要實(shí)現(xiàn)在線實(shí)時生成 Excel文件供客戶端下載的需求,最初考慮的是先在服務(wù)器端生成真實(shí)的文件,然后在客戶端下載該文件。后來發(fā)現(xiàn)這樣做不但性能不夠好、速度較慢,而且還要占用服務(wù)器空間。所以采取了在服務(wù)器端生成文件輸出流(ServletOutputStream),通過HttpServletResponse對象設(shè)置相應(yīng)的響應(yīng)頭,然后將此輸出流傳往客戶端的方法實(shí)現(xiàn)。在實(shí)現(xiàn)過程中,用到了...  閱讀全文
    posted @ 2005-12-30 10:08 南一郎 閱讀(12304) | 評論 (16)編輯 收藏

    ?

    ??????? 我的一個項(xiàng)目使用了Hibernate3操作Oracle9i數(shù)據(jù)庫,遇到一個很奇怪的問題,即在按某些使用了聚合函數(shù)的值的升序排序后,翻頁到一定頁數(shù)(通常是3或5)以后,顯示的內(nèi)容不會變化,即出現(xiàn)不是期望的查詢結(jié)果.
    ??????? 剛開始仔細(xì)排查,找不出原因.后來通過查Hibernate 包中的Oracle9Dialect及OracleDialect的源碼,將Dialect換成 OracleDialect后問題解決.
    ?????? 但是,問題雖解決了,根源何在呢?為什么Oracle9卻要用到OracleDialect(源碼注解中說這是兼容Oracle8i)的才能解決問題呢?!
    ???? ?查看源碼,發(fā)現(xiàn)兩者取得分頁查詢字符串的方式是有點(diǎn)區(qū)別的(在 getlimitString()方法中).

    ?? ?在Oracle9Dialect中:

    ?? public ?String?getLimitString(String?sql,? boolean ?hasOffset)? {
    ??
    ??sql?
    = ?sql.trim();
    ??
    boolean ?isForUpdate? = ? false ;
    ??
    if ?(?sql.toLowerCase().endsWith( " ?for?update " )?)? {
    ???sql?
    = ?sql.substring(? 0 ,?sql.length() - 11 ?);
    ???isForUpdate?
    = ? true ;
    ??}

    ??
    ??StringBuffer?pagingSelect?
    = ? new ?StringBuffer(?sql.length() + 100 ?);
    ??
    if ?(hasOffset)? {
    ???pagingSelect.append(
    " select?*?from?(?select?row_.*,?rownum?rownum_?from?(? " );
    ??}

    ??
    else ? {
    ???pagingSelect.append(
    " select?*?from?(? " );
    ??}

    ??pagingSelect.append(sql);
    ??
    if ?(hasOffset)? {
    ???pagingSelect.append(
    " ?)?row_?where?rownum?<=??)?where?rownum_?>?? " );
    ??}

    ??
    else ? {
    ???pagingSelect.append(
    " ?)?where?rownum?<=?? " );
    ??}


    ??
    if ?(isForUpdate)?pagingSelect.append( " ?for?update " );
    ??
    ??
    return ?pagingSelect.toString();
    ?}



    ??????? 在OracleDialect中:

    public ?String?getLimitString(String?sql,? boolean ?hasOffset)? {

    ??sql?
    = ?sql.trim();
    ??
    boolean ?isForUpdate? = ? false ;
    ??
    if ?(?sql.toLowerCase().endsWith( " ?for?update " )?)? {
    ???sql?
    = ?sql.substring(? 0 ,?sql.length() - 11 ?);
    ???isForUpdate?
    = ? true ;
    ??}

    ??
    ??StringBuffer?pagingSelect?
    = ? new ?StringBuffer(?sql.length() + 100 ?);
    ??
    if ?(hasOffset)? {
    ???pagingSelect.append(
    " select?*?from?(?select?row_.*,?rownum?rownum_?from?(? " );
    ??}

    ??
    else ? {
    ???pagingSelect.append(
    " select?*?from?(? " );
    ??}

    ??pagingSelect.append(sql);
    ??
    if ?(hasOffset)? {
    ???pagingSelect.append(
    " ?)?row_?)?where?rownum_?<=???and?rownum_?>?? " );
    ??}

    ??
    else ? {
    ???pagingSelect.append(
    " ?)?where?rownum?<=?? " );
    ??}


    ??
    if ?(isForUpdate)?pagingSelect.append( " ?for?update " );
    ??
    ??
    return ?pagingSelect.toString();
    ?}



    ??????? 兩者的區(qū)別主要在于,前者:
    row_ where rownum <= ?) where rownum_ > ?
    后者:
    where rownum_ <= ? and rownum_ > ?

    我模擬了我的出問題的查詢,使用前者問題重現(xiàn),使用后者不出問題.
    另外是,只在升序排序時才出問題,降序則不會.

    我的語句分別如下:
    *************************************************************************
    第一種:

    select ? * ? from ?(

    ?
    select ?rownum?row_num?,t. * ?? from (
    ?
    select ? Sum (b.disp_Count)?,? Sum (b.click_Count)?,?
    ???
    Sum (b.total_Price)?,? Sum (b.return_Cost)?,?
    ???
    avg (b.rank)??,?b.sta_Date???,?b.keyword_Name??,?
    ???b.union_Name??
    ???
    from ?Bid_Report?b??
    ????????
    where ??(b.sta_Date? = ' 20051129 ' )??
    ??????????
    group ? by ??b.sta_Date,??b.keyword_Name,??b.union_Name?
    ??????????
    order ? by ?? Sum (b.click_Count),?b.sta_Date?
    ????????)?t??
    where ?rownum <= 60
    ??)?
    where ?row_num? > ? 40


    (在Hibernate3中,Oracle9Dialect的getLimitString()方法采取類似實(shí)現(xiàn)方式)

    第二種:

    select ? * ? from ?(

    ?
    select ?rownum?row_num?,t. * ?? from (
    ?
    select ? Sum (b.disp_Count)?,? Sum (b.click_Count)?,?
    ???
    Sum (b.total_Price)?,? Sum (b.return_Cost)?,?
    ???
    avg (b.rank)??,?b.sta_Date???,?b.keyword_Name??,?
    ???b.union_Name??
    ???
    from ?Bid_Report?b??
    ????????
    where ??(b.sta_Date? = ' 20051129 ' )??
    ??????????
    group ? by ??b.sta_Date,??b.keyword_Name,??b.union_Name?
    ??????????
    order ? by ?? Sum (b.click_Count),?b.sta_Date??
    ????????)?t??
    ??)?
    where ?row_num? <= 60 ? and ?row_num > 40

    (在Hibernate3中,OracleDialect的getLimitString()方法采取類似實(shí)現(xiàn)方式)

    **********************************************************************

    現(xiàn)在,問題是:為什么采取后者就可以解決問題了呢?這是不是Oracle9Dialect的一個bug呢?!
    哪位高手能給我詳析,感激不盡!!!!

    posted @ 2005-12-30 09:41 南一郎 閱讀(1359) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 婷婷综合缴情亚洲狠狠尤物| 手机在线免费视频| 久久国产乱子伦精品免费午夜| 国产h视频在线观看免费| 亚洲精品在线播放视频| 久久久久免费看成人影片| 可以免费观看的国产视频| 无码国产精品一区二区免费虚拟VR | 亚洲综合小说久久另类区| 99在线观看精品免费99| 亚洲成人福利在线观看| 亚洲男同gay片| 成在线人永久免费视频播放| 亚洲精品乱码久久久久久蜜桃不卡| 添bbb免费观看高清视频| 国产无限免费观看黄网站| 国产亚洲精久久久久久无码77777| 美女被免费网站91色| 亚洲AV成人精品网站在线播放| 亚洲AV香蕉一区区二区三区| a级片在线免费看| 久久亚洲AV成人出白浆无码国产| 国产精品亚洲а∨无码播放麻豆| 亚洲AⅤ优女AV综合久久久| h视频在线观看免费| 亚洲综合在线视频| 五月婷婷综合免费| 另类小说亚洲色图| 亚洲成AV人片在| 成年女人色毛片免费看| 思思久久99热免费精品6| 亚洲国产精品成人精品无码区在线| 无码日韩精品一区二区免费暖暖| 精品国产人成亚洲区| 97视频免费观看2区| 性色av极品无码专区亚洲| 亚洲国产一成人久久精品| 毛片免费在线播放| 精品人妻系列无码人妻免费视频| 亚洲精品视频在线播放| 免费一级毛片在级播放|