<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開發與研究

    にほん

    上海房產

    東京生活

    數據庫大全

    編程與開發

    美國開發生活

    走向管理

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲精品456播放| 在线综合亚洲中文精品| 久久久久久精品免费免费自慰| 7777久久亚洲中文字幕| 亚洲伦乱亚洲h视频| 99视频免费观看| 色吊丝免费观看网站| 亚洲国产精品自在线一区二区| 日产乱码一卡二卡三免费| a级毛片毛片免费观看久潮| 亚洲精品无码久久久久秋霞| 狠狠色伊人亚洲综合成人| 最近免费中文字幕大全| 久久国产免费直播| 亚洲日韩亚洲另类激情文学| 国产精品亚洲A∨天堂不卡| 精品国产精品久久一区免费式| 最近的2019免费中文字幕| 亚洲狠狠婷婷综合久久| 亚洲A∨无码一区二区三区 | 啊v在线免费观看| 日本免费污片中国特一级| 免费精品国自产拍在线播放| 亚洲天堂中文字幕| 亚洲天堂中文字幕在线| 福利免费观看午夜体检区| 免费无码又爽又刺激网站直播| 最新亚洲人成无码网www电影| 亚洲第一页中文字幕| 亚洲成A人片77777国产| 午夜视频免费成人| 免费精品国产日韩热久久| 免费人成在线观看网站| av片在线观看永久免费| 久久精品国产亚洲av瑜伽| 亚洲jizzjizz在线播放久| 亚洲卡一卡2卡三卡4卡无卡三| 久久青青草原亚洲av无码| 国产午夜免费福利红片| 成人免费视频网址| 无码国产精品一区二区免费I6 |