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

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

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

    如何使用Eclipse + Resin + WebWork + Hibernate 開發

    版權申明:允許非盈利性引用,如有轉載,請注明來源:“編譯:brickhan;轉載自http://www.javapub.com ”字樣, 版權歸原作/譯者所有。
    按照下面的步驟進行:
    1. 下載 Eclipse. 2.1 M2 版本
    2. 下載Resin. 2.1.7
    3. 下載Resin plug-in for Eclipse. 0.5.2 版本
    4. 安裝并設置上面的軟件,如果JDBC DRIVER不在系統的CLASSPATH內,則需要把它復制到Resin的 "lib" 目錄里面.
    5. 下載 Hibernate. 1.2b2 .
    6. 下載WebWork. Version 1.2.1.
    7. 下載Log4J. Version 1.2.7
    8. 用Eclipse 創建一個 Resin 的Java project.
    9. 右擊 "WEB-INF/src" 后從下拉菜單選擇 "Import...".
    10. 瀏覽文件系統找到 WebWork′s skeleton example, 導入 "webwork.properties", "webwork.vm", "log4j.properties", 和 "views.properties".
    11. 用同樣的方法導入 WebWork的 "web.xml" 到 "WEB-INF" .
    12. 從 WebWork′s "lib" 文件夾中導入 "webwork.jar" 和所有其他支持的.jar文件,除開 "saxon.jar" 文件,到 "WEB-INF/lib".
    13. 導入 WebWork′s "template" 文件夾到你 Resin project的根目錄.
    14. 從 Hibernate′s 根目錄導入 "cache.ccf" 和 "hibernate.properties" 到 "WEB-INF/src".
    15. 注意這兒另外也有一個Note that there′s also another "log4j.properties" 文件file. 用編輯器打開,將其中的內容復制,然后追加到你已經導入到"WEB-INF/src"目錄的"log4j.properties"中。
    16. 從Hibernate′s 根目錄中導入 "hibernate.jar" 到 "WEB-INF/lib"中.
    17. 從Hibernate的 "lib" 目錄導入所有jar文件到"WEB-INF/lib",除開 "j2ee.jar," "junit.jar," "xerces.jar," 和 "xml-apis.jar" 文件.
    18. 導入Log4J .jar 文件到 "WEB-INF/lib".
    19. 使用 Hibernate工具來建立持久層的類和映射.
    20. 編輯 "WEB-INF/web.xml".增加如下的節點:
    12: <servlet>
    13: <servlet-name>initializer</servlet-name>
    14: <servlet-class>skeleton.servlet.SkeletonInitializer</servlet-class>
    15: <load-on-startup>1</load-on-startup>
    16: </servlet>
    17:
    18: <resource-ref>
    19: <res-ref-name>jdbc/skeleton</res-ref-name>
    20: <res-type>javax.sql.DataSource</res-type>
    21: <init-param driver-name="org.postgresql.Driver"/>
    22: <init-param url="jdbc:postgresql://localhost/skeleton"/>
    23: </resource-ref>

    編寫類似下面的初始化 servlet.:

    1:package skeleton.servlet;
    2:
    3:import java.io.IOException;
    4:
    5:import javax.servlet.GenericServlet;
    6:import javax.servlet.ServletConfig;
    7:import javax.servlet.ServletContext;
    8:import javax.servlet.ServletException;
    9:import javax.servlet.ServletRequest;
    10:import javax.servlet.ServletResponse;
    11:
    12:import javax.naming.Context;
    13:import javax.naming.InitialContext;
    14:import javax.naming.NamingException;
    15:
    16:import java.sql.Connection;
    17:import java.sql.SQLException;
    18:import javax.sql.DataSource;
    19:
    20:import cirrus.hibernate.Datastore;
    21:import cirrus.hibernate.Hibernate;
    22:import cirrus.hibernate.HibernateException;
    23:import cirrus.hibernate.SessionFactory;
    24:import cirrus.hibernate.Session;
    25:
    26:public class SkeletonInitializer extends GenericServlet
    27:{
    28: public void init(ServletConfig config) throws ServletException
    29: {
    30: super.init(config);
    31: Datastore ds = Hibernate.createDatastore()
    32: .storeClass(skeleton.persistent.Customer.class)
    33: .storeClass(skeleton.persistent.Purchase.class);
    34:
    35: try
    36: {
    37: SessionFactory factory = ds.buildSessionFactory();
    38:
    39: Context ctx = (Context)new InitialContext().lookup("java:comp/env");
    40: DataSource db = (DataSource)ctx.lookup("jdbc/skeleton");
    41: Connection conn = db.getConnection();
    42: Session sess = factory.openSession(conn);
    43: sess.disconnect();
    44:
    45: ServletContext app = getServletContext();
    46: app.setAttribute("hibernate.factory", factory);
    47: app.setAttribute("hibernate.session", sess);
    48: }
    49: catch (HibernateException he)
    50: {
    51: he.printStackTrace();
    52: }
    53: catch (NamingException ne)
    54: {
    55: ne.printStackTrace();
    56: }
    57: catch (SQLException se)
    58: {
    59: se.printStackTrace();
    60: }
    61: }
    62:
    63: public void service(ServletRequest req, ServletResponse res) throws IOException, ServletException
    64: {
    65: // This space intentionally left blank
    66: }
    67:}



    當然你需要使用真實的持久類的名稱,最好,對這段代碼再進行加工。.


    編寫類似下面的 WebWork action classes:

    1:package skeleton.action;
    2:
    3:import webwork.action.Action;
    4:import webwork.action.ActionContext;
    5:import webwork.action.ActionSupport;
    6:
    7:import cirrus.hibernate.Hibernate;
    8:import cirrus.hibernate.HibernateException;
    9:import cirrus.hibernate.Session;
    10:
    11:import java.sql.SQLException;
    12:
    13:import java.util.List;
    14:
    15:import skeleton.persistent.Customer;
    16:
    17:public class SkeletonAction extends ActionSupport
    18:{
    19: private String incomingA;
    20: private String incomingB;
    21: private Customer customer;
    22:
    23: public void setIncomingA(String value)
    24: {
    25: incomingA = value;
    26: }
    27:
    28: public void setIncomingB(String value)
    29: {
    30: incomingB = value;
    31: }
    32:
    33: public void setCustomer(Customer value)
    34: {
    35: customer = value;
    36: }
    37:
    38: public String getIncomingA()
    39: {
    40: return incomingA;
    41: }
    42:
    43: public String getIncomingB()
    44: {
    45: return incomingB;
    46: }
    47:
    48: public Customer getCustomer()
    49: {
    50: return customer;
    51: }
    52:
    53: public String execute()
    54: {
    55: Session sess = (Session)ActionContext.getContext().getApplication.().get("hibernate.session");
    56: try
    57: {
    58: sess.reconnect();
    59: List results = sess.find("Your query here", new Object[]{incomingA, incomingB}, new Object[]{Hibernate.STRING, Hibernate.STRING});
    60: // Do something to discriminate among the results; for now snag the first one
    61: customer = (Customer)results.iterator().next();
    62: }
    63: catch (HibernateException he)
    64: {
    65: he.printStackTrace();
    66: return Action.ERROR;
    67: }
    68: catch (SQLException se)
    69: {
    70: se.printStackTrace();
    71: return Action.ERROR;
    72: }
    73: finally
    74: {
    75: try
    76: {
    77: sess.disconnect();
    78: }
    79: catch (HibernateException he)
    80: {
    81: he.printStackTrace();
    82: }
    83: catch (SQLException se)
    84: {
    85: se.printStackTrace();
    86: }
    87: }
    88: return Action.SUCCESS;
    89: }
    90:}




    使用WebWork′s <property> tag 開發你的views,:

    1:<ww:property value="customer">
    2: <ww:property value="name"/><br>
    3: <ww:property value="address"/><br>
    4: ...
    5:</ww:property>


    在不同的項目上,步驟19-23是需要對action的代碼進行一些工作。

    posted on 2006-09-05 17:48 77 閱讀(277) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    <2006年9月>
    272829303112
    3456789
    10111213141516
    17181920212223
    24252627282930
    1234567

    導航

    統計

    常用鏈接

    留言簿(12)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    新聞檔案

    相冊

    API文檔

    java開發與研究

    にほん

    上海房產

    東京生活

    數據庫大全

    編程與開發

    美國開發生活

    走向管理

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲第一页在线视频| 国产乱弄免费视频| 久久综合图区亚洲综合图区| eeuss影院www天堂免费| 亚洲成A人片在线观看中文| 国产精品亚洲lv粉色| 国产一区二区三区在线观看免费| 男男gay做爽爽的视频免费| 亚洲成?v人片天堂网无码| 思思久久99热免费精品6| 久久夜色精品国产亚洲av| a毛看片免费观看视频| 亚洲日韩乱码中文无码蜜桃臀网站| yy一级毛片免费视频| 亚洲午夜久久久久久久久电影网| 久久久久成人片免费观看蜜芽| 亚洲精品自产拍在线观看动漫| 99久久99这里只有免费费精品| 亚洲www77777| 亚洲欧洲日产国码高潮αv| 成人无码WWW免费视频| 亚洲春色在线观看| 天天摸天天操免费播放小视频| 国产亚洲漂亮白嫩美女在线| 色噜噜亚洲精品中文字幕| 91嫩草免费国产永久入口| 亚洲色www永久网站| 亚洲国产午夜福利在线播放| 可以免费观看的毛片| 亚洲中文无码av永久| 亚洲 综合 国产 欧洲 丝袜| 永久免费av无码网站yy| 亚洲中文字幕人成乱码| 亚洲日韩VA无码中文字幕| 18禁无遮挡无码国产免费网站| 亚洲精品成a人在线观看夫| 亚洲av永久无码精品表情包| 无码乱肉视频免费大全合集| 黄色a三级免费看| 亚洲春黄在线观看| 红杏亚洲影院一区二区三区|