实战JBuilder7+JBoss3+SQL Server2000完整的三层结构的例子

    技术2022-05-11  189

    实战Jbuilder7+JBoss3+SQL Server2000

    完整的三层结构的例子

    刘晓巍:liuxiaowei2000@sina.com

     

    内容介绍:

           本文讲述了建立一个典型的3层结构的J2EE的实现过程,主要是实现过程,没有理论说明。这完全是根据我个人的经验所写,希望能够对大家有所帮助,欢迎大家多多批评指正!

     

    假设Jbuilder7JBoss3x 安装完毕,操作系统为:windows2000 server(SP2),数据库为: SQLServer2000(SP2)JDBCMicrosoft SQLServer2000的驱动。例子源码:http://weisoft.myrice.com/download/JBossDemo.rar,(SQLServer sa密码为csdn

    一.        环境设置

    1.         下载并安装JBossOpenTool For JBuilder 7http://weisoft.myrice.com/download/JBuilder_JBossOT.jar将下载的JbossOpenTool.jar拷贝至Jbuilder7的lib/ext目录下,重起JBuilder。

    1.       配置MS SQL Server 2000 JDBCJBoss设置:将msbase.jar, msutil.jar, mssqlserver.jar三个文件拷贝至Jboss的Server/default/lib目录下。将Jboss的docs/examples/jca目录下的mssql-service.xml, mssql-xa-service.xml文件拷贝至Jboss的server/default/deploy目录下,并做如下修改:mssql-service.xml(红色是修改部分,分别是数据库名,用户名,密码,根据你的环境调整即可):<config-property name="ConnectionURL" type="java.lang.String">jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=Northwind</config-property><config-property name="UserName" type="java.lang.String">sa</config-property><config-property name="Password" type="java.lang.String">csdn</config-property>mssql-xa-service.xml(红色是修改部分,分别是sqlserver服务器名,数据库名):<config-property name="XADataSourceProperties" type="java.lang.String">ServerName=localhost;DatabaseName=Northwind;SelectMethod=cursor</config-property>JBuilder配置:选择:Tools->Enterprise Setup,单击Database Drivers页上的Add, 在弹出的对话框中单击New,. 在弹出的对话框中填写NameMS SQL Server JDBC Location选择User Home,单击Add按钮,选择msbase.jar, msutil.jar, mssqlserver.jar,单击OK关闭当前对话框,可以看到MS SQL Server JDBC已被加入,单击OK关闭当前对话框,再次单击OK,配置完成。重起JBuilder 7

    2.         启动Jbuilder7,选择:Tools->Configure Servers选中左侧的JBoss 3.X,选中右边的Enable Server,按下表信息填写:General页:Home Directiry F:/jboss-3.0.4_tomcat-4.1.12           //       <——JBoss的安装目录Main Class org.jboss.MainVM Parameters -ms64m -mx64m -Dprogram.name=run.batServer Parameters -c defaultWorking Directory F:/jboss-3.0.4_tomcat-4.1.12/binCustom页:JBoss Installation Directory = F:/jboss-3.0.4_tomcat-4.1.12           //       <——JBoss的安装目录Tomcat 4X  JBuilder Installation Directory = F:/JBuilder7/jakarta-tomcat-4.0.3       //<——Tomcat的安装目录JBoss Configuration to Use default单击OK

    3.         选择Tools>Configure Libraries, 在弹出的对话框中单击New按钮,在Name栏中填写JBoss Libs,单击Add按钮,加入JBoss目录下/Server/default/lib目录下的javax.servlet.jarjboss-j2ee.jar文件,单击OK

    二.      实现步骤

    1.         新建一个Project选择File>New Project,在Name栏填写JBossDemo,在Directory栏输入保存路径,其它不变,单击Finsih选择Project>Project properties,在Path页的Required Libraries中单击Add按钮,在弹出的对话框中选择我们刚才建立的JBoss Libs,单击OK。选择Server页,选中Single Server For All Service in Project,在下拉列表中选择JBoss 3.X,单击OK

    2.         新建一个EJB Module选择File->New,在弹出的对话框中选择Enterprise页中的EJB Module图标,单击OK。在弹出的对话框中Name栏填写JBossDemoModule,其它不变,单击OK

    3.         新建两个CMP右键单击左下角的DataSource,选择Import Schema From Database,按如下信息在弹出的对话框中填写:Driver com.microsoft.jdbc.sqlserver.SQLServerDriverURL jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=NorthwindUserName sa        // ßSQLServer用户名Password “”    // ßSQLServer密码JNDI Name java:/MSSQLDSExtended properties中添加一项DatabaseName Northwind选中All SchemasViews单击OK。成功的话,在DataSource下面将出现一个java:/MSSQLDS项,单击其左侧的+号,将其展开,将会看到表名。右键单击Employees表,选择CMP 2.0 Entity Bean, 同样右键单击Orders表,选择CMP 2.0 Entity Bean

    4.         建立表关系右键单击右侧的代表Employees表的矩形,选择Add>Relationship后,单击指向代表Oderss表的矩形后,将会看到一条线把两个矩形连接起来了,同时Employees表多了一个orders字段。单击右下角的JBossCMP-JDBC页,按如下填写,其它不变:datasource MSSQLDSdatasource-mapping Hypersonic SQL选择File>Save All保存项目。选择Project>Make Project JbossDemo.jpx”编译项目。

    5.         建立Session Bean在右边的空白处单击右键,选择Create EJB> Session Bean, Bean Name改为GetData,右键单击代表这个Session Bean的矩形,选择Add>Method,按如下填写:Method Name GetOrdersByEmployeesIDReturn Type VectorInput Parameters Integer IDInterface Remote选择File>Save All保存项目。选择Project>Make Project JbossDemo.jpx”编译项目。

    6.         编写代码右键单击代表GetData的矩形,选择 View Bean Source在开始处加入以下语句:import java.util.*;import javax.naming.*;按如下填写GetOrdersByEmployeesID

      public Vector GetOrdersByEmployeesID(Integer ID)

      {

        Vector result = new Vector();

        result.add(ID);

        try

        {

          Context ctx = new InitialContext();

          EmployeesHome home = (EmployeesHome)ctx.lookup("Employees");

          Employees emp = home.findByPrimaryKey(ID);

          Collection orders = emp.getOrders();

          Iterator it = orders.iterator();

          while(it.hasNext())

          {

            Orders order = (Orders)it.next();

            result.add(order.getOrderID());

          }

        }

        catch (Exception ex)

        {

          System.out.println("ShowOrdersByEmployeesID() error : " + ex.getMessage());

        }

        return result;

      }

    7.      建立Servlet

    选择File->New,在弹出的对话框中选择Web页中的Servlet图标,单击OK。在弹出的对话框中Class Name栏填写FormServlet,其它不变,单击Next,选中doGet()项,其它不变,单击Finish按如下填写FormServlet.javadoGet()函数:  public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException

      {

        response.setContentType(CONTENT_TYPE);

        PrintWriter out = response.getWriter();

        out.println("<h1>Enter the Employees ID</h1>");

        out.println("<strong>Enter Employees ID in the input fields below.</strong>");

        out.println("<br><br>");

        out.println("<form action=showordersservlet method=POST>");

        out.println("Name<br>");

        out.println("<input type=text name=EmployeeID value=/"/" size=20 maxlength=150>");

        out.println("<br><br><br><br>");

        out.print("<input type=submit value=Submit>");

        out.println("</form>");

      }再次选择File->New,在弹出的对话框中选择Web页中的Servlet图标,单击OK。在弹出的对话框中Class Name栏填写ShowOrdersServlet,其它不变,单击Next,选中doPost()项,其它不变,单击Next,单击Next,单击Add Parameter,按如下填写:Name EmployeeIDType StringDesc employee’s IDVariable employeeIDDefault 1单击Next,单击Finish按如下填写ShowOrdersServlet.javadoPost()函数:别忘了在开始处加入以下语句:import java.util.*;import javax.naming.*;  public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException

      {

        String employeesID = request.getParameter("EmployeeID");

        if (employeesID == null)

        {

          employeesID = "1";

        }

        response.setContentType(CONTENT_TYPE);

        PrintWriter out = response.getWriter();

        Vector orders = new Vector();

        try

        {

          Context ctx = new InitialContext();

          ShowDataHome home = (ShowDataHome)ctx.lookup("ShowData");

          ShowData showData = home.create();

          orders = showData.ShowOrdersByEmployeesID(new Integer(employeesID));

        }

        catch (Exception ex)

        {

          System.out.println("ShowOrdersServlet doPost() error :"+ex.getMessage());

        }

     

        Iterator it = orders.iterator();

     

        out.println("<html>");

        out.println("<head><title>ShowOrdersServlet</title></head>");

        out.println("<body>");

        out.println("<p>Orders with EmployeesID " + employeesID+ "</p>");

        while(it.hasNext())

        {

          out.println("<p>OrderID = " + it.next().toString()+"</p>");

        }

        out.println("<h1>Order Count = " + orders.size()+"</h1>");

        out.println("</body></html>");

      }

    8.         建立EAR文件右键单击左侧目录树中的的<Default WebApp>,选择PropertiesWebApp页的Name填写为JBossDemo,将Dependencies页中的所有项设置成Exclude All,单击OK选择File->New,在弹出的对话框中选择Enterprise页中的EAR图标,单击OK第一页不变,单击Next,选中JBossDemoModule,单击Next,单击Next,单击Next,选中JBossDemo,单击Finish选择File>Save All保存项目。选择Project>Rebuild Project JBossDemo.jpx”编译项目。

    9.         发布整个应用程序右键单击左侧目录树中的的JBossDemo.eargrp,选择Deploy Options for  “JBossDemo.ear” >Deploy,发布应用程序。

    10.     测试应用程序打开IE,在地址栏输入 http://localhost:8080/JBossDemo/formservlet,回车,在编辑框中输入3,单击“submit”即可。


    最新回复(0)