Kaixinhutu

糊涂

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  5 随笔 :: 0 文章 :: 0 评论 :: 0 Trackbacks

一、 概述

AJAX是今年初才问世的新技术,是Asynchronous JavaScript and XML的缩写。它是一组开发Web应用程序的技术,它使浏览器可以为用户提供更为自然的浏览体验。每当需要更新时,客户端Web页面的修改是异步的和逐步增加的。这样,AJAX在提交Web页面内容时大大提高了用户界面的速度。在基于AJAX的应用程序中没有必要长时间等待整个页面的刷新。页面中需要更新的那部分才进行更改,如果可能的话,更新是在本地完成的,并且是异步的。

J2ee是一种用来开发分布式系统的体系结构。它主要是用Java类开发业务实体。通过JSP来连接应用服务器。

本文开发一个组织机构管理小系统,通过这个实例来介绍如何用Ajax开发WEB应用程序。本系统具有增加、修改、删除组织机构的功能。同时给机构分配人员,能增加、修改、删除人员。

二、 界面设计

树结构是大多软件系统中常采用的结构形式。由于树型结构层次分明、上下级关系清楚、且展开收缩表达信息方便、界面也较美观,所以是大家热衷于用此结构。组织机构管理是一般软件基本具有的。组织机构是指公司的组织结构。集团公司可包括分公子公司,公司下面又有科室。员工归属于所在的公司。系统运行后的界面如下:

orgManager.htm是组织机构管理的主页面。WEB应用程序界面设计是非常重要的。如何布局、么样组织可直接体现一个人的设计水平。

组织机构主要包括树结构、组织机构编辑、人员编辑等三大块,如何分成三块呢,然而一般树型结构的窗体常先二块,树型结构独占一块,另一块又分成上下二部分,上面是机构编码,下面是人员编码。固可以把页面划分成如下图形式:

树结构区1
组织编码区2
人员管理区3


显然我们是通过表来实现。这是一个二行二列的表,且第一、二行的左边列合并单元格。代码如下:

< TABLE border="1" width="100%" height="100%">

<TR>

<TD rowspan="2"><FONT face="宋体"></FONT></TD>

<TD></TD>

</TR>

<TR>

<TD></TD>

</TR>

</TABLE>


我们在1区(单元格)上加上一个DIV,因为DIV可以动态地滚动,并且可以插入其它控件。DIV的id为"divTree",且风格设置为溢出时自动滚动,宽与高都为100%,及满区域。代码如下:

<div id="divTree" style="width:100%; height:100%;background-color:#f5f5f5;border :1px solid Silver;overflow:auto;">

</div>


我们在2区(单元格)上也加上一个DIV,在DIV里再插入一个表格。表格上放下控件,这很简单,就不详细说了。

我们在3区(单元格)上加上一个DIV。此DIV的id为" divContent ",且风格设置为竖直溢出时自动滚动,宽与高都为100%,及满区域,此DIV用来装载人员信息;在DIV里再插入一个表格, 此table的id为" tbList ",是用来输入、显示人员作息,同时在此表中插入一些如checkbox 、text、select等控件。说明,表的第二列是用来放人员唯一编号的,不显示。代码如下:

<div id="divContent" style="height:100%; overflow-y:auto;" width="100%">

<table id="tbList" border="1" width="100%">

<tr seqNo="1"><td>

<table border="1" width="100%">

<tr>

<td width="5%"><input type="checkbox" value="on"></input> </td>

<td width="0%" style="display:none"> <input type="text" size="20"></input></td>

<td width="40%"><input type="text" size="20"></input></td>

<td width="25%">

<select size="1" name="D1">

<option value="0">男</option>

<option selected="true" value="1">女</option>

</select>

</td>

</tr>

</table>

</td></tr>

</table>

</div>

三、 前端页面的主要编码

1. 树的实现

在WEB上实现树结构,同样我们是通过Ajax来实现的。树上可以显示自定义的图标,可以插入、删除、结点。并且结点可任意移动。这里我们不重点讲树的实现技术,我们已经封装好了,你只要按要求去改动就是了。

1) 键接树型文件

在<head>与</head>之间键接我们的与树有关的文件, 代码如下:

<link rel="STYLESHEET" type="text/css" href="css/dhtmlXTree.css">

<script src="js/dhtmlXCommon.js"></script>

<script src="js/dhtmlXTree.js"></script>


2) 装载方法

在页面的文档打开时装载自定义方法, preLoadImages方法实现树控件的图标定义,doOnLoad实现树控件的图标定义代码如下:

<body onload="preLoadImages();doOnLoad();">


3) 编写方法

//doOnLoad实现装载并显示树。设置树属性等。

function doOnLoad(){

 OrgTree=new dhtmlXTreeObject(document.getElementById('divTree'),"100%","100%",0);

 //dhtmlXTreeObject是树对象,通过新建对象,指定树显示的DIV可定义树。

 OrgTree.setImagePath("imgs/");//设置树的图片所在位置

 OrgTree.setDragHandler();//设置树结点拖动

 OrgTree.enableDragAndDrop(true) //设置树结点是否可拖动

 OrgTree.setDragHandler(myDragHandler); //设置树结点拖动时所执行的方法

 OrgTree.setOnClickHandler(mySelectHandler); //设置树单击时所执行的方法

 //OrgTree.setXMLAutoLoading("Org.jsp");//装载树结点数据。数据来源如Org.jsp所返回的XML格式的字符串,数据是动态装载,且当展开时才装载。

 OrgTree.loadXML("root.xml?0");//装载树结点数据。数据来源root.xml文件,并且从xml文件的ID号为0处读取数据。

 //OrgTree.loadXML("Org.jsp");//装载树结点数据。数据来源如Org.jsp所返回的XML格式的字符串,并且是一次性全部装载数据。

}

//preLoadImages方法实现树控件的图标定义

function preLoadImages(){

 var imSrcAr = new Array("line1.gif","line2.gif","line3.gif","line4.gif","minus2.gif","minus3.gif",

"minus4.gif","plus2.gif","plus3.gif","plus4.gif","book.gif","books_open.gif","books_close.gif",

"magazine_open.gif","magazine_close.gif","tombs.gif","tombs_mag.gif","book_titel.gif")

 var imAr = new Array(0);

 for(var i=0;i<imSrcAr.length;i++){

imAr[imAr.length] = new Image();

imAr[imAr.length-1].src = "imgs/"+imSrcAr[i]

 }

}


 组织管理的实现

组织可以增加、删除、编辑。同时当选择树结点时应该把组织显示出来供编辑,查看。为了实现这些功能,你只要按要求去改动就是了。

1) 全局变量的定义

许多地方我们要用到一些公共变量,我们在<script>与</script>之间定义全局变量, 代码如下:

var OrgTree = null; //组织树Dom

var nextSeq = 0;//人员管理的顺序号(流水号)

var personDom;//人员Dom

var CurrNodeId;//当前结点Id



2) 初始化

当页面打开时我们要控件好那部分该显示,那部分要隐藏。且对全局变量的赋值等,组织类型装载。在页面的文档打开时装载自定义方法init(), init方法实现初始化。

<body onload="init();">



init方法实现如下:

function init(){

 //定义personDom为一个XMLDOM'对象

 personDom= new ActiveXObject('Microsoft.XMLDOM');

 personDom.async = false;

 //定义stylesheet为一个XMLDOM'对象,且stylesheet为personDom确定显示风格

 stylesheet = new ActiveXObject('Microsoft.XMLDOM');

 stylesheet.async = false;

 stylesheet.load("addOrgPerson.xsl"); //装载stylesheet的风格定义文件

 //装载组织类型数据

 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

 xmlhttp.open("POST","Org.jsp?mode=GetOrgType", false);

 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

 xmlhttp.send();

 retXml=xmlhttp.responseText;

 // alert(retXml);

 //把组织类型插入下拉列表控件中

 var OrgDoc = new ActiveXObject('Microsoft.XMLDOM');

 OrgDoc.async = false;

 OrgDoc.loadXML(retXml);

 var root = OrgDoc.documentElement;

 oNodeList = root.childNodes;

 txtType.options.length =oNodeList.length;

 for (var i=0; i<oNodeList.length; i++)

 {

Item = oNodeList.item(i);

var OrgTypeId=Item.childNodes(0).text;

var OrgTypeName=Item.childNodes(1).text;

txtType.options[i].value=OrgTypeId;

txtType.options[i].text=OrgTypeName;

// txtType.options[0].

 }

}



3) 编写树拖动及选择结点的方法

// myDragHandler实现树结点拖动时重新指定父子关系。

function myDragHandler(idFrom,idTo){

 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

 xmlhttp.open("POST","Org.jsp?mode=moveOrg&orgId=" + idFrom + "&newparentOrgId=" + idTo, false);

 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

 xmlhttp.send();

 retXml=xmlhttp.OrgponseText;

 return true;

}

// mySelectHandler实现选择树结点对系统的控制,同时显示组织信息及该组织下的人员。

function mySelectHandler(id){

 tbOrg.style.display="block";

 divOrgMemo.style.display="none";

 divOrgInfo.style.display="none";

 if(id==1)

 {

divOrgMemo.style.display="block";

div1.style.display="none";

div2.style.display="none";

div3.style.display="none";

divContent.style.display="none";

div5.style.display="none";

 }

 else

 {

divOrgInfo.style.display="block";

div1.style.display="block";

div2.style.display="block";

div3.style.display="block";

divContent.style.display="block";

div5.style.display="block";

 }

 CurrNodeId=id;

 //装载组织信息并显示在编码和名称的文本控件上。

 loadOrg(id);

 //装载某组织下人员信息

 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

 xmlhttp.open("POST","Org.jsp?mode=GetPerson&orgId=" + id, false);

 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

 xmlhttp.send();

 retXml=xmlhttp.responseText;

 personDom.loadXML (retXml);

 //给人员信息的每行加上序号

 for(var i=0; i<personDom.documentElement.childNodes.length; i++){

personDom.documentElement.childNodes[i].setAttribute("seqNo", nextSeq);

nextSeq++;

 }

 //人员信息显示在divContent上面

 divContent.innerHTML = personDom.transformNode(stylesheet);

};

//装载组织信息并显示在编码和名称的文本控件上。

function loadOrg(OrgId){

 if(OrgId == null){

OrgId = OrgTree.getSelectedItemId();

 }

 if(OrgId == ""){

tbOrg.style.display = "none";

return;

 }

 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

 xmlhttp.open("POST","Org.jsp?mode=loadOrg&OrgId=" + OrgId, false);

 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

 xmlhttp.send();

 retXml=xmlhttp.responseText;

 var OrgDoc = new ActiveXObject('Microsoft.XMLDOM');

 OrgDoc.async = false;

 OrgDoc.loadXML(retXml);

 if(OrgId != 1){

txtCode.value = OrgDoc.selectSingleNode("//OrgCode").text;

txtName.value = OrgDoc.selectSingleNode("//OrgName").text;

 }

 tbOrg.style.display = "block";

}



4) 建立组织

组织建立主要是通过调用XMLHTTP对象来实现。我们主要学会如何调用XMLHTTP。组织建立应该在后台实现,把组织信息插入数据库中。这里我们通过JSP来实现。我们的Org.jsp 文件中有个createOrg方法,该方法传递一个父ID。

function createOrg(parentOrgId){

 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

 xmlhttp.open("POST","Org.jsp?mode=createOrg&parentOrgId=" + parentOrgId, false);

 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

 xmlhttp.send();

 retXml=xmlhttp.responseText;

 var orgId = (new Number(retXml)).toString();

 return orgId;

}


5) 删除组织

组织删除同样是调用Org.jsp 文件中的deleteOrg方法来实现,该方法传递所删除的结点ID。

function deleteOrg(){

 var OrgId = OrgTree.getSelectedItemId();

 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

 xmlhttp.open("POST","Org.jsp?mode=deleteOrg&OrgId=" + OrgId, false);

 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

 xmlhttp.send();

}


6) 编辑组织

组织修改是调用Org.jsp 文件中的modifyOrg方法来实现,该方法传递所修改的结点ID。同时修改的数据通过自定义的XML格式的字符串传送,这时通过send字符串来实现。修改前数据一律要验证其合法性,并提示错误信息。

function modifyOrg(){

 if(OrgTree.getSelectedItemId() == ""){

return "N";

 }

 if(txtCode.value == ""){

alert("请输入编码!");

return "N";

 }

 if(txtName.value == ""){

alert("请输入名称!");

return"N";

 }

 var OrgId = OrgTree.getSelectedItemId();

 var OrgKind;

 //alert(txtType.options[txtType.selectedIndex].value)

 var strModify = "<?xml version='1.0' encoding='gb2312'?>" +

 "<data>" +

 "<OrgCode><![CDATA[" + txtCode.value + "]]></OrgCode>" +

 "<OrgName><![CDATA[" + txtName.value + "]]></OrgName>" +

 "<OrgKind><![CDATA[" + txtType.options[txtType.selectedIndex].value+ "]]></OrgKind>" +

 "</data>";

 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

 xmlhttp.open("POST","Org.jsp?mode=modifyOrg&OrgId=" + OrgId, false);

 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

 xmlhttp.send(strModify);

 OrgTree.setItemText(OrgTree.getSelectedItemId(),txtName.value);

}
3. 人员管理的实现

人员可以增加、删除、编辑。同时当选择树结点时应该把人员显示出来供编辑、查看......

1) 增加人员

人员增加实现的原理是在personDom中加入结点peorsone,该结点相当于表的一行,设置属性。同时在peorsone中不继地加入其它结点,代表数据库的字段,且必须与XLT文件的标号同名。这些结点相当该行的列。最后在表中插入一行,行上插入一列,并显示之。

function addPerson(){

 var seqNo = nextSeq;

 nextSeq++;

 var peorsonNode = personDom.createNode("1", "peorsone","");

 peorsonNode.setAttribute("isNew", "Y");

 peorsonNode.setAttribute("isDelete", "N");

 peorsonNode.setAttribute("seqNo", seqNo);

 personDom.documentElement.appendChild(peorsonNode);

 var PersonId= personDom.createNode("1", "personId", "");

 peorsonNode.appendChild(PersonId);

 var personCode= personDom.createNode("1", "personCode", "");

 peorsonNode.appendChild(personCode);

 var PersonName= personDom.createNode("1", "personName", "");

 peorsonNode.appendChild(PersonName);

 var Sex= personDom.createNode("1", "sex", "");

 peorsonNode.appendChild(Sex);

 var tr = tbList.insertRow(tbList.rows.length);

 tr.setAttribute("seqNo", seqNo);

 var td = tr.insertCell(0);

 td.innerHTML = peorsonNode.transformNode(stylesheet);

}


2) 删除人员

人员删除同样是调用Org.jsp 文件中的deletePerson方法来实现,该方法传递所删除的人员ID。如何确定人员ID是通过读取隐藏的ID,并扫描整个表,看那些被选中。这里我们要注意是提供多项选择的。

function deletePerson(){

 for(var i=0; i<tbList.rows.length; i++){

var row=tbList.rows[i].cells[0].children[0].rows[0];

if(row.cells[0].children[0].checked)

{

 var personId=row.cells[1].children[0].value;

 if(personId>0)

 {

var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

xmlhttp.open("POST","Org.jsp?mode=deletePerson&personId=" + personId, false);

xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

xmlhttp.send();

 }

 tbList.deleteRow(i);

 i--;

}

 }

}


3) 编辑人员

人员修改我们要判定哪些行被修改了。刚增加但没保存的行应该是新增而不是修改的。

function save(){

 if( modifyOrg()=="N")

 {

return;

 }

 for(var i=0; i<tbList.rows.length; i++)

 {

var row=tbList.rows[i].cells[0].children[0].rows[0];

var personId=row.cells[1].children[0].value;

var seqNo = tbList.rows[i].getAttribute("seqNo");

var staffNode = personDom.selectSingleNode("//peorsone[@seqNo='" + seqNo + "']");

var personCode=row.cells[2].children[0].value;

var personName=row.cells[3].children[0].value;

var sex=row.cells[4].children[0].value; //alert(staffN;ode );

if(staffNode.getAttribute("isNew") == "Y")

{

 createPerson(CurrNodeId,personCode,personName,sex);

}

else

{

 var strXML = "<?xml version='1.0' encoding='gb2312'?>" +

"<data>" +

"<personCode><![CDATA[" + personCode+ "]]></personCode>" +

"<personName><![CDATA[" + personName + "]]></personName>" +

"<sex><![CDATA[" + sex+ "]]></sex>" +

"<personId><![CDATA[" + personId+ "]]></personId>" +

"</data>";

 //alert(strXML );

 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

 xmlhttp.open("POST","Org.jsp?mode=modifyPerson", false);

 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

 xmlhttp.send(strXML );

}

 }

}


四、 XML与XSL文件设计

XML是种可扩展的标记语言,它具有开放的、可扩展的、可自描述的语言结构,它已经成为网上数据和文档传输的标准。XSLT的目的是将信息内容与 Web 显示分离,HTML 通过按抽象概念(如段落、重点和编号列表)定义显示来实现设备独立性。XSLT用来具体显示控件,设置控件风格。

Ajax主要使用XML和XSLT进行数据交换与处理。

1. 树信息的XML文件(见root.xml文件)

XML是标记语言,元素必须成对出现。树结构中以tree为根结点,以item为结点体,属性text指出结点所显示的文本,id指出唯一的所标识号。

<?xml version='1.0' encoding='gb2312'?>

<tree id="0">

<item child="1" text="组织" id="1" >

</item>

</tree>


这文件并不是必要的,只是为了系统能独立运行才加的。事实如果连接了后台数据是不需要的。只要吧OrgTree.loadXML("root.xml?0")改为OrgTree.loadXML("Org.jsp")就可以了。

2. 人员信息XML文件(见peorson.xml文件)

说明![CDATA[]]可在任何显示任何格式的文本,文本中可插入其它任何字符。这文件也不是必要的。

3. 人员信息展现的xsl文件(见addOrgPerson.xsl文件)

xsl文件同样是XML格式文件。所以一律遵守XML标准。下面对主要的行讲解:

<?xml version="1.0" encoding="gb2312"?>

//这是定义xml文件的首行。用来指明版本及字符集

<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl" language="JavaScript">

//这里定义了stylesheet 元素。并指出其国际命名的组织及语言。

<xsl:template match="/">

<xsl:apply-templates select="peorsones"/>

</xsl:template>

//上面是匹配的规则。"/"表示从根结开始去匹配。匹配到下面的peorsones标记。这是正则表达式有关的学问。我们只要理解就可以。

<xsl:template match="peorsones">

//当匹配上peorsones时所要做的事情。

<table id="tbList" border="1" width="100%">

//定义一个id为"tbList的表格。此表格是显示在WEB上的

<xsl:for-each select="peorsone">

//循环匹配peorsone

<tr>

//定义tbList表格的一行,并在行上增加一个叫seqNo的属性名,值为匹配到的seqNo(序号)

<xsl:attribute name="seqNo"><xsl:value-of select="@seqNo"/></xsl:attribute>

<td>

//定义行上的一列,列又去匹配

<xsl:apply-templates select="."/>

</td>

</tr>

</xsl:for-each>

</table>

</xsl:template>

<xsl:template match="peorsone">

<table border="1" width="100%">

<tr>

//定义宽为5%的一列,在该列上插入一个checkbox控件

<td width="5%">

<input type="checkbox" value="on" size="10"></input>

</td>

//定义一个不显示的列,在该列上插入一个text控件,text的值为匹配到的personId(人员Id)

<td style="display:none">

<input type="text" size="25">

<xsl:attribute name="value"><xsl:value-of select="personId"/></xsl:attribute>

</input>

</td>

<td width="30%">

<input type="text" size="20">

<xsl:attribute name="value"><xsl:value-of select="personCode"/></xsl:attribute>

</input>

</td>

<td width="40%">

<input type="text" size="40">

<xsl:attributename="value"><xsl:value-of select="personName"/></xsl:attribute>

</input>

</td>

//定义一个width为28%的列,在该列上插入一个下拉列表select 控件,select的值如果匹配到为0时则为"男",1时则为"女"

<td width="28%">

<select size="1">

<option value="0">

<xsl:if test=".[sex=0]">

<xsl:attribute name="selected">true</xsl:attribute>

</xsl:if>



</option>

<option value="1">

<xsl:if test=".[sex=1]">

<xsl:attribute name="selected">true</xsl:attribute>

</xsl:if>

女</option>

</select>

</td>

//定义一列,在该列上插入一个button控件,onclick 事件为自定义的方法,该方法传递当前单击的按纽

<td width="*">

<button onclick="openPersonRolePage(this)" style="width: 36; height: 21">角色</button>

</td>

</tr>

</table>

</xsl:template>

</xsl:stylesheet>


五、 数据接口的实现(见Org.jpg文件)

Org.JSP文件用来在服务器上运行Java的类与前台web页之间架起一座桥。取到中间件的接口作用。

这里分析部分代码:

<%@ page contentType="text/html; charset=GBK" %>

<%@ page import="java.sql.*" %>

<%@ page import="javax.naming.*" %>

<%@ page import="javax.sql.*" %>

<%@ page import="tool.*" %>

<%@ page import="orgNew.*" %>

<%@ page import="org.w3c.dom.*" %>

//上面主要是引用一些java类

<%

try{

 //request.setCharacterEncoding("GBK");

 Document doc = XmlTool.createDocumentFromRequest(request);

 //建立web面文档请求的文档对象

 Connection conn = ConnTool.getConnectionFromPool();

 //获取请求的方法名

 String mode=request.getParameter("mode");

 //out.println("ccc");

 //如果方法中没有其它参数则读取组织树数据

 if(mode == null){

/* int OrgId = Integer.parseInt(request.getParameter("id"));

String str = orgManager.getChildOrg(OrgId, conn);

out.println(str);

*/

 String str = orgManager.getTree(conn);

 //out.println(str);

 out.println(str);

}else if(mode.equals("createOrg")){

 //如果是createOrg方法则建立一个组织

 int parentOrgId = Integer.parseInt(request.getParameter("parentOrgId"));

 //取出传递来的第一个参数parentOrgId

 int OrgId = orgManager.createOrg(parentOrgId, conn);

 //调用orgManager 类的createOrg方法来建立一个组织

 out.println(OrgId);

 //返回结果

}

conn.close();

}

catch(Exception e){

 e.printStackTrace();

}

%>



六、 后台数据的实现

1. 数据结构的定义

这里,我们主要有三个表。一个是组织结构表,一个是人员表person,一个组织人员关联表orgPerson。组织结构表有OrgCode(组织代码)、OrgName(组织名称)、orgId(组织Id), parentOrgId(父Id)。人员表有personCode(人员代码)、personName(人员名称), sex(性别)、personId(人员Id)。orgPerson表有orgId, personId。

2. 数据库的连接

WEB应用程序常用MySQL作后台数据库,这是因为MySQL简单、高效。这里我们也用MySQL作为数据库。Java中用jdbc连接数据库。下面是连接数据库的CODE:

public static Connection getConnectionFromPool() throws Exception {

 Context ctx = new InitialContext();

 DataSource ds = (DataSource) ctx.lookup("java:/erpds");

 return ds.getConnection();

}

/**

* 取数据库链接对象

* @return Connection 数据库链接对象

* @throws Exception

*/

/*

public static Connection getDirectConnection() throws Exception {

 Class.forName("com.sybase.jdbc2.jdbc.SybDriver");

 String url = "jdbc:sybase:Tds:19.64.13.16:4100/wydb?charset=iso_1";

 String user = "sa";

 String password = "2860008";

 Connection conn = DriverManager.getConnection(url, user, password);

 return conn;

}

*/


. 业务逻辑层的实现

后台开发我们用Java类来实现。这里我们开发了一个orgNew包,类名为orgManager。此类封装了与数据库操作有关的方法。通过main可调试程序的正确性。

这里给出了新增加一个组织的全部代码和通过XML取得树结构信息的代码,树结构通过递归实现。

package orgNew;// Java类所打的包

import tool.*;

import java.sql.*;

import java.util.*; // 引用Java类的

public class orgManager {

 public orgManager() { }

 public static void main(String[] args) throws Exception {

Connection conn = tool.ConnTool.getDirectConnection();// 引用数据访问类

conn.setAutoCommit(false);

orgManager orgManager1 = new orgManager();

orgManager1.createOrg(0, conn); //测试建立组织是否正确

 }

 //建立一个组织

 public static int createOrg(int parentOrgId, Connection conn) throws

 Exception {

String sql = "insert into Org (OrgName, parentOrgId) values('新组织', ?)";

PreparedStatement pstat = conn.prepareStatement(sql);

pstat.setInt(1, parentOrgId);

pstat.executeUpdate();

pstat.close();

Statement stat = conn.createStatement();

String sql2 = "select max(OrgId) from Org";

ResultSet rs = stat.executeQuery(sql2);

rs.next();

int OrgId = rs.getInt(1);

rs.close();

stat.close();

System.out.println(OrgId);

return OrgId;

 }

}

//通过递归得到组织信息的XML格式的数据

public static String getTree(Connection conn) throws

Exception {

 StringBuffer ret = new StringBuffer();//定义可缓冲的字符流

 ret.append("<?xml version='1.0' encoding='gb2312'?><tree id='0'>");//定义XML格式的头信息

 ret.append(" <item child='1' text='组织' id='1' >");//插入结点体。注树结点以item为标记

 ret.append(getChildTree(1, conn));

 ret.append("</item>");//结点体结束标记

 ret.append("</tree>");//树结束标记

 return ret.toString();//返回字符流

}

public static String getChildTree(int OrgId, Connection conn) throws

Exception {

 StringBuffer ret = new StringBuffer();

 String sql = "select a.OrgId, a.OrgName, a.OrgCode,count(b.parentOrgId) from Org a " +

"left join Org b on a.OrgId = b.parentOrgId " +

"where a.parentOrgId = ? " +

"group by a.OrgId, a.OrgName";

 PreparedStatement pstat = conn.prepareStatement(sql);

 pstat.setInt(1, OrgId);

 ResultSet rs = pstat.executeQuery();

 while (rs.next()) {

int childOrgId = rs.getInt(1);

String childOrgName = rs.getString(2);

String childOrgCode = rs.getString(3);

if (childOrgCode == null) {

 childOrgCode = " ";

}

if (childOrgName == null) {

 childOrgName = "新组织";

}

int childCount = rs.getInt(3);

if (childCount > 0) {

 childCount = 1;

}

ret.append("<item child='" + childCount + "' text='" + childOrgName +

"' id='" +childOrgId + "' code='"+childOrgCode+"'>");

ret.append(getChildTree(childOrgId, conn));

ret.append("</item>");

 }

 rs.close();

 pstat.close();

 return ret.toString();

}

其它代码见orgManager.java文件。

七、 总结

本文件通过一个实例全面介绍了Ajax开发的各个细节。通过与J2ee的结合来实现三层分布式开发的层次划分,后台与前端的调用。数据的读取、访问及展现。

通过这个实例,我们可见,Ajax使WEB中的界面与应用分离。数据与呈现分离的分离,有利于分工合作、减少非技术人员对页面的修改造成的WEB应用程序错误、提高效率、也更加适用于现在的发布系统。也可以把以前的一些服务器负担的工作转嫁到客户端,利于客户端闲置的处理能力来处理。

Ajax是传统WEB应用程序的一个转变。以前是服务器每次生成HTML页面并返回给客户端(浏览器)。Ajax理念的出现,揭开了无刷新更新页面时代的序幕,并有代替传统web开发中采用form(表单)递交方式更新web页面的趋势,可以算是一个里程碑。

总之,Ajax适用于交互较多,频繁读数据,数据分类良好的WEB应用。

posted on 2006-04-20 09:21 糊涂 阅读(717) 评论(0)  编辑  收藏 所属分类: 【AJAX】

只有注册用户登录后才能发表评论。


网站导航: