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

原创 2003年01月03日 10:06:00

实战Jbuilder7+JBoss3+SQL Server2000

完整的三层结构的例子

刘晓巍:liuxiaowei2000@sina.com

 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

内容介绍:

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

 

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

一.        环境设置

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

1.       配置MS SQL Server 2000 JDBC
JBoss设置:

将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.Main
VM Parameters
-ms64m -mx64m -Dprogram.name=run.bat
Server Parameters
-c default
Working Directory
F:/jboss-3.0.4_tomcat-4.1.12/bin
Custom
页:

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.SQLServerDriver
URL
jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=Northwind
UserName
sa        // ßSQLServer用户名
Password
“”    // ßSQLServer密码
JNDI Name
java:/MSSQLDS
Extended 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
MSSQLDS
datasource-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
GetOrdersByEmployeesID
Return Type
Vector
Input Parameters
Integer ID
Interface
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
EmployeeID
Type
String
Desc
employee’s ID
Variable
employeeID
Default
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>,选择Properties
WebApp页的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”即可。

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

内容介绍:       本文讲述了建立一个典型的3层结构的J2EE的实现过程,主要是实现过程,没有理论说明。这完全是根据我个人的经验所写,希望能够对大家有所帮助,欢迎大家多多批评指正! 假设Jbuil...
  • bxh2dai
  • bxh2dai
  • 2005年02月25日 14:05
  • 847

spring security4 实例(小菜完整版)

小菜第一次写博客,废话不多说直接开始上干货。主要面对security小白,大牛绕行 第一步:创建web maven工程,不会的可自行与度娘打招呼。 第二步:环境说明。 jdk:1.7  , ...
  • u011127348
  • u011127348
  • 2016年07月01日 17:01
  • 1325

【深入浅出Node.js系列八】一个基于Node.js完整的Web应用实战

1 Web用例 我们来把目标设定得简单点,不过也要够实际才行: 用户可以通过浏览器使用我们的应用。 当用户请求http://domain/start时,可以看到一个欢迎页面,页面上有一个文件...
  • zhangyuan19880606
  • zhangyuan19880606
  • 2016年05月26日 17:42
  • 2142

shiro(三)shiro实战——Spring 集成 Shiro(案例)

**步骤 加入 jar 包 配置 web.xml 文件 在 Spring 的配置文件中配置 Shiro**配置 web.xml 文件配置启动 Spring IOC 容器的 Filter 配置 W...
  • qq_14996421
  • qq_14996421
  • 2016年11月24日 15:47
  • 602

jquery File upload 的一个例子

1. jquery file upload 下载 jQuery file upload Demo 地址:https://blueimp.github.io/jQuery-File-Upload/ ...
  • zsg88
  • zsg88
  • 2017年04月26日 16:52
  • 976

Nginx的完整配置示例

#运行用户 user nobody; #启动进程,通常设置成和cpu的数量相等 worker_processes 1;#全局错误日志及PID文件 #error_log logs/error.log...
  • github_26672553
  • github_26672553
  • 2016年06月30日 16:37
  • 7191

完整的一个表单例子

完整的一个表单例子 .error {color: #FF0000;} // 定义变量并默认设置为空值 $nameErr = $emailErr = $genderErr = ...
  • huochequan888
  • huochequan888
  • 2016年12月13日 17:02
  • 109

【AJAX】——实战应用,完整Demo

前提     之前小编整理过关于AJAX的一些理论内容,其实在这些理论之后也做一些实战工作,可惜那时候的小编没有整理出来,随着项目结束,直到最近项目的使用,发现小编自己忘记怎么做了!!!惭愧啊,归根...
  • jiadajing267
  • jiadajing267
  • 2017年02月23日 11:24
  • 812

VB.NET版的三层实例

​学了VB.NET视频,学了三层视频,那么接下来就是要实现VB.NET版的三层实例了!这个在一开始还真的无从下手,但是通过和C#的对比,发现VB.NET和C#以及VB的语句结构,思想都差不太多,所以就...
  • u013045959
  • u013045959
  • 2015年01月24日 11:00
  • 1422

微服务实战(四):服务发现的可行方案以及实践案例

(转载自dockone.io 原作者杨峰) 这是关于使用微服务架构创建应用系列的第四篇文章。第一篇介绍了微服务架构的模式,讨论了使用微服务架构的优缺点。第二和第三篇描述了微服务架构内部的通讯机制。这...
  • Irene__Tang
  • Irene__Tang
  • 2016年03月22日 10:41
  • 2551
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:实战JBuilder7+JBoss3+SQL Server2000完整的三层结构的例子
举报原因:
原因补充:

(最多只允许输入30个字)