The important thing in life is to have a great aim , and the determination

常用链接

统计

IT技术链接

保险相关

友情链接

基金知识

生活相关

最新评论

利用AJAX+J2EE开发组织机构管理系统(转载)五

五、 数据接口的实现(见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;
}
*/

  3. 业务逻辑层的实现

  后台开发我们用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页面的趋势,可以算是一个里程碑。

posted on 2006-12-05 21:38 鸿雁 阅读(182) 评论(0)  编辑  收藏