分享
 
 
 

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

王朝java/jsp·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

实战Jbuilder7+JBoss3+SQL Server2000

完整的三层结构的例子

刘晓巍:liuxiaowei2000@sina.com

内容介绍:

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

假设Jbuilder7和JBoss3x 安装完毕,操作系统为:windows2000 server(SP2),数据库为: SQLServer2000(SP2)。JDBC为Microsoft 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,. 在弹出的对话框中填写Name为MS 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.jar和jboss-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 Schemas和Views项

单击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.java的doGet()函数:

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.java的doPost()函数:

别忘了在开始处加入以下语句:

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”即可。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有