频道直达 - 学院 - 下载 - 交易 - 特效 - 字库 - 手册 -排名-工具- 繁體
网页教学网站开发 设为首页
加入收藏
联系我们
建站搜索: 常用广告代码   用户注册 | 用户登陆
您当前的位置:中国建站之家 -> 网站开发设计技术教程 -> JSP教程 -> JSP/Servlet构建三层管理信息系统

JSP/Servlet构建三层管理信息系统

作者:未知  来源:转载  发布时间:2005-7-28 11:33:05  发布人:acx

减小字体 增大字体

  摘要:本文介绍了一种开发基于Web的管理信息系统的实现框架。利用JSP/Servlet技术,结合MVC设计模式,使得开发过程更加灵活,更加易于维护。

  关键词:管理信息系统,JSP,Servlet,MVC设计模式,JDBC

  1、 引言

  管理信息系统(MIS)是一个由人、计算机等组成的能进行信息的收集、传递、存储、加工和使用的系统。随着科技的发展,信息的膨胀,企业信息化成了企业在竞争中处于不败地位的有效手段之一。而MIS不仅能够及时全面地提供信息和数据,简化统计工作,对不同的管理层次提出不同的报告之外,还能根据过去的数据预测未来的情况。因此,采用何种方法开发出一种兼顾开发效率和运行效率,同时满足分布式事件处理功能的管理信息系统就显得尤为重要。本文阐述了一种利用JSP/Servlet构建三层式管理信息系统的方法。

  2、 系统的三层体系结构

  系统的三层体系结构如图1。
http://www.7880.comhttp://www.7880.com/Upload/2004_Pack/113055.gif';" hspace=3 src="http://www.7880.comhttp://www.7880.com/Upload/2004_Pack/113055.gif" align=center vspace=1 border=1>

图1基于Java技术的Web应用体系结构

  整个管理信息系统采用Browser/Web/DataBase的三层体系结构。Web服务器接受请求,通过应用程序服务器执行一个Java服务器端小程序Servlet并返回其输出,从而实现与客户机进行信息资源的交互。数据库服务器用来存储管理信息系统中所用到的各种数据,数据由数据库管理程序直接录入。系统的客户端只需要一个浏览器即可。相关人员通过浏览器来查询、增加、修改、删除数据,对信息进行管理。
  3、 系统的设计模式

  设计模式是面向对象的程序设计人员用来解决编程问题的一种形式化表示。目前,在大多数Browser/Server结构的Web应用中,浏览器直接通过HTML或者JSP的形式与用户交互,响应用户的请求。虽然很直观,但是大多数管理信息系统操作的数据量都是惊人的,随着代码的增多会使JSP页面臃肿不堪,Web服务器的负荷过重。因此,在中间层上采用基于模型视图控制器(MVC.Model-View-Controller)的设计模式。Model层用来实现业务逻辑,View层用来显示用户界面,Controller层主要负责View层和Model层之间的控制关系。具体实现时,把Servlet用作应用程序的控制器,把JSP文档作为视图,JavaBeans被用来表示模型。所有的请求都被发送给作为控制器的Servlet,它接受请求,并根据请求信息将它们分发给适当的JSP来响应。同时,Servlet还根据JSP的需求生成JavaBeans的实例并输出给JSP环境。JSP可以通过直接调用方法或使用UseBean的自定义标签得到JavaBeans中的数据。这种设计模式很好地实现了数据层与表示层的分离,使开发工作更加容易和迅速。在这种设计模式下,各层次之间的数据传递如图2。

http://www.7880.comhttp://www.7880.com/Upload/2004_Pack/113056.gif';" hspace=3 src="http://www.7880.comhttp://www.7880.com/Upload/2004_Pack/113056.gif" align=center vspace=1 border=1>

图2 MVC设计模式的数据传递图

  4、 数据存取技术

  数据库是管理信息系统的核心内容。目前,Web与数据库接口技术有很多,其中JDBC是Java程序连接和存取数据库的应用程序接口,由一组用Java语言编写的类与接口组成,是执行SQL语句的Java API。本文介绍的管理信息系统中,在数据的存取方面,采用了 JSP/Servlet+JDBC的技术,即客户端不产生数据库查询命令,客户端上的浏览器通过URL和中间层的Web服务器建立连接。Web服务器主要负责接收本地或远程浏览器的HTTP数据请求,然后中间层的Servlet收到请求后,通过执行程序中的SQL语句,利用JDBC提供的标准API对数据库进行访问和相应的操作处理。Servlet再将查询的数据传给JSP,最后生成标准的JSP页面将结果返回给提出请求的浏览器。这样,不仅将客户端与数据库服务器端分开,同时提高了数据库的访问效率。

  5、 实例

  为了更好地说明用JSP/Servlet构建三层式管理信息系统的方法,作者将举例分析设计一个商品邮购管理信息系统。这个商品邮购管理信息系统利用Java语言进行服务器端应用程序的开发,使用IBM公司的Webshpere作为应用服务器,数据库管理系统选用SQL Server7.0,数据库接口程序使用JDBC2接口。整个系统使用基于Web的方式来实现邮购业务的客户管理、职员管理、订单管理、商品管理、出库管理、入库管理等业务处理、流程控制、权限控制、查询统计以及打印等功能。其中详细分析订单管理部分的查询功能。

  5.1数据库设计

  对于订单部分,需要定义订单信息表Db_order,表中的字段有订单编号(ddbh),客户编号(khbh),商品编号(spbh),商品单价(spdj),定购数量(dgsl),合计总价(hjzj),收到金额(sdje),收到日期(sdrq)。为了能够在应用中使用Db_order表,必须建立数据库连接。这个功能由sql_data.java来实现。其部分代码如下。

public class sql_data {

 String url = "jdbc:odbc:PostOrder"; // use your hostname and port number here
 String login = "sa"; // use your login here
 String password ="zh12345"; // use your password here
 public Connection connection = null;
 public Statement st = null;
 public ResultSet rs = null;
 try
 {
  Class.forName("com.microsoft.jdbc.sqlserver.SqlServerDriver");
  conn =DriverManager.getConnection(url, user, password);
 } catch (Exception e)
 {
  e.printStackTrace();
 }
}

  5.2中间层设计

  在商品邮购管理信息系统的开发过程中,基于MVC设计模式的思想,结合系统的实际情况,我们将Model层按照分工进行了进一步划分。Model层一般来说由许多JavaBeans组成,根据这些Beans在系统中起的不同的作用,将它们分为Command Beans、Data Beans、View Beans三种类型。其中Command Beans用来实现业务逻辑即对对象实例的处理;Data Beans是用来描述和定义从现实世界中抽象出来的对象模型;而 View Beans则是用来将处理完的对象实例进一步封装并返回到客户端。

  首先,Command Beans获得Servlet传递过来的信息,并将这些业务信息封装在Data Beans定义的对象实例中,根据业务逻辑对信息进行处理。当需要进行调用数据库的存取操作时,Command Beans将对象实例以及相应的控制信息通过数据库接口方法完成对数据库的操作。数据库操作完成后,再将返回的记录集封装成Data Beans的对象实例,进行一定的处理后,将这些需要返回到界面的信息再封装到事先定义的View Beans中去,通过View Beans将信息返回到界面上。

  以下是对订单进行查询处理的OrderGl.java的部分代码。

public class OrderGl {
……
//定义如下的方法完成对订单的查询操作
public final String currentMultiQuery(
javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response)
throws com.goods.exception.GoodsException
{
//从JSP页面获得相应查询信息
com.goods.view.OrderView view = getView(request, response);
String ddbh = view.getDdbh(); //订单编号

//生成SQL语句
String sqlQuery = "select ddbh,khbh,spbh,spdj,dgsl,hjzj,sdje,sdrq from db_order ";
//执行查询操作
java.util.Vector vector = new java.util.Vector();
com.goods.sjk.sql_data per = new com.goods.sjk.sql_data();
try
{
 java.sql.ResultSet rs = per.executeQuery(sqlQuery);
 while (rs.next())
 {
  com.goods.dx.Db_order temp = new com.goods.dx.Db_order();
  temp.setDdbh(rs.getString("ddbh"));
  temp.setKhbh(rs.getString("khbh"));
  temp.setSpbh(rs.getString("spbh"));
  temp.setSpdj(rs.getString("spdj"));
  temp.setDgsl(rs.getString("dgsl"));
  temp.setHjzj(rs.getString("hjzj"));
  temp.setSdje(rs.getString("sdje"));
  temp.setSdrq(rs.getString("sdrq"));
  vector.addElement(temp);
 }
 rs.close();
 per.close();
 } catch (Throwable e)
 {
  e.printStackTrace();
  per.close();
  cxyw.printErrorToWeb(request, response, e.toString());
  return e.toString();
 }
 //将相关信息回显给界面
 view.setVct(vector);
 request.setAttribute("view", view);
 return "1";
}
}

  5.3客户端设计

  视图是向用户显示信息的应用程序的一部分,也就是用户发出请求之后返回给用户的Web页面。当单击"查询"按钮时,将显示根据订单编号得到的订单信息结果页面ordercx.jsp。这是用JSP页面中如下语法完成的:

<jsp:useBean id="view" class="com.goods.view.OrderView" scope="request" />
<jsp:useBean id="temp" class="com.goods.dx.Db_order" scope="page" />
< jsp:useBean >动作用id和scope发现存在的各个对象,再通过<%=view.getDdbh()
和<%=temp.getDdbh()%>来获取相关数据。

  6、 小结

  本文提出了一个开发基于Web的利用JSP/Servlet技术的三层管理信息系统的解决方案。该方案实现了表示层和逻辑层的分离,使得系统具有很好的扩展性,同时,给管理信息系统的开发提供了一个完整的思路和方法。


将本文收藏到QQ书签与更多好友分享
[打 印]
[] [返回上一页] [收 藏]
上一篇文章:在jsp中发送email
下一篇文章:轻松使用JSP生成饼图
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
精彩推荐
热门文章
· 注册码大全二
· 注册码大全四
· 注册码大全一
· 要10G免费网络硬盘的请进..
· 通过google 赶快来赚美金..
· 注册码大全十
· 头像-qq头像(qq新头像)4..
· 让你轻松架设FTP服务器1..
· 注册码大全三
· 梦幻背景图片7
· 卡通动物图片6
· 网页制作素材-按钮素材2..
· 让你轻松架设FTP服务器5..
· 风景图片8
· 注册码大全九
· 让你轻松架设FTP服务器2..
关注此文读者还看过
· 关于教师评价系统的WEB程..
· "Linux之父"助手投Googl..
· 编写通用的asp防注入程序..
· ASP.Net写的浏览器间谍
· Flash转像素图为矢量图(..
· PhotoShop常见的50个疑难..
· 一个简洁的多级别论坛
· CSS控制字体效果的思考
· PHP网站漏洞的相关总结(..
· 被遗忘的HTML元素
· YouTube 早就该安息了
· 像素图教程(三)
· 连接到数据及创建可重用..
· 就是要玩“虚”的-在PS中..
· Google视频共享服务现虐..
· ASP.NET创建Web服务之使..
相关文章
· PHP+JSP/servlets+Mysql+po..
· JSP/JAVABEAN+TOMCAT4.0.5+..
· 用JSP/ASP创建WAP应用
· JSP/Servlet应用程序优化八..
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 人才招聘
网站合作、内容监督、商务咨询:QQ: 9576619
Copyright ? 2005--2008 中国建站之家版权所有
粤ICP备05092265号