deptmgr.java
来自「一个用java编写的功能强大的OA系统」· Java 代码 · 共 245 行
JAVA
245 行
package com.redmoon.oa.dept;import java.sql.*;import javax.servlet.http.*;import cn.js.fan.db.*;import cn.js.fan.security.*;import cn.js.fan.util.*;import cn.js.fan.web.*;import org.apache.log4j.*;import java.util.Vector;import java.util.Iterator;import cn.js.fan.module.cms.IDirectory;public class DeptMgr { String connname = ""; Logger logger = Logger.getLogger(DeptMgr.class.getName()); public DeptMgr() { connname = Global.defaultDB; if (connname.equals("")) logger.info("Directory:默认数据库名不能为空"); } public boolean AddRootChild(HttpServletRequest request) throws ErrMsgException { int child_count = 0, orders = 1, parent_orders = 1, islocked = 0; String root_code = "", name = "", code = "", parent_code = "-1"; int parent_layer = 1; boolean isParentRoot = false; name = ParamUtil.get(request, "name", false); if (name == null) throw new ErrMsgException("名称不能为空!"); code = ParamUtil.get(request, "code", false); if (code == null) throw new ErrMsgException("编码不能为空!"); String description = ParamUtil.get(request, "description"); root_code = code; String insertsql = "insert into directory (code,name,parent_code,description,orders,root_code,child_count,layer) values ("; insertsql += StrUtil.sqlstr(code) + "," + StrUtil.sqlstr(name) + "," + StrUtil.sqlstr(parent_code) + "," + StrUtil.sqlstr(description) + "," + orders + "," + StrUtil.sqlstr(root_code) + "," + child_count + ",1)"; logger.info(insertsql); if (!SecurityUtil.isValidSql(insertsql)) throw new ErrMsgException("请勿输入非法字符如;号等!"); int r = 0; RMConn conn = new RMConn(connname); try { r = conn.executeUpdate(insertsql); } catch (SQLException e) { logger.error(e.getMessage()); throw new ErrMsgException("请检查编码" + code + "是否重复!"); } return r == 1 ? true : false; } public boolean AddChild(HttpServletRequest request) throws ErrMsgException { int child_count = 0, orders = 1, parent_orders = 1, islocked = 0; String root_code = "", name = "", code = "", parent_code = ""; name = ParamUtil.get(request, "name", false); if (name == null) throw new ErrMsgException("名称不能为空!"); code = ParamUtil.get(request, "code").trim(); if (code.equals("")) throw new ErrMsgException("编码不能为空!"); if (!StrUtil.isSimpleCode(code)) throw new ErrMsgException("编码请使用字母、数字、-或_!"); parent_code = ParamUtil.get(request, "parent_code").trim(); if (parent_code.equals("")) throw new ErrMsgException("父结点不能为空!"); String description = ParamUtil.get(request, "description"); int type = ParamUtil.getInt(request, "type"); DeptDb lf = new DeptDb(); lf.setName(name); lf.setCode(code); lf.setParentCode(parent_code); lf.setDescription(description); lf.setType(type); DeptDb dd = getDeptDb(parent_code); return dd.AddChild(lf); } public void del(String delcode) throws ErrMsgException { DeptUserDb du = new DeptUserDb(); int count = du.list(delcode).size(); if (count>0) throw new ErrMsgException("该部门下有" + count + "名人员,请先将人员安排至其它部门再删除!"); DeptDb lf = getDeptDb(delcode); lf.del(lf); } public synchronized boolean update(HttpServletRequest request) throws ErrMsgException { String code = ParamUtil.get(request, "code", false); String name = ParamUtil.get(request, "name", false); String description = ParamUtil.get(request, "description"); boolean isHome = ParamUtil.get(request, "isHome").equals("true") ? true : false; int type = ParamUtil.getInt(request, "type"); if (code == null || name == null) { throw new ErrMsgException("code与name项必填!"); } String parentCode = ParamUtil.get(request, "parentCode"); DeptDb leaf = getDeptDb(code); if (code.equals(parentCode)) { throw new ErrMsgException("请选择正确的父节点!"); } if (!parentCode.equals(leaf.getParentCode())) { DeptDb lf = getDeptDb(parentCode); while (lf!=null && !lf.getCode().equals(lf.ROOTCODE)) { String pCode = lf.getParentCode(); if (pCode.equals(leaf.getCode())) throw new ErrMsgException("不能将其子节点更改为父节点"); lf = getDeptDb(pCode); } } leaf.setName(name); leaf.setDescription(description); leaf.setIsHome(isHome); leaf.setType(type); boolean re = false; if (parentCode.equals(leaf.getParentCode())) { logger.info("update:name=" + name); re = leaf.save(); } else re = leaf.save(parentCode); return re; } public synchronized boolean move(HttpServletRequest request) throws ErrMsgException { String code = ParamUtil.get(request, "code", false); String direction = ParamUtil.get(request, "direction", false); if (code == null || direction == null) { throw new ErrMsgException("编码与方向项必填!"); } DeptDb dd = getDeptDb(code); return dd.move(direction); } public DeptDb getDeptDb(String code) { DeptDb dd = new DeptDb(); return dd.getDeptDb(code); } public DeptDb getBrother(String code, String direction) throws ErrMsgException { DeptDb dd = getDeptDb(code); return dd.getBrother(direction); } public Vector getChildren(String code) throws ErrMsgException { DeptDb dd = getDeptDb(code); return dd.getChildren(); } public void repairLeaf(DeptDb lf) { Vector children = lf.getChildren(); lf.setChildCount(children.size()); Iterator ir = children.iterator(); int orders = 1; while (ir.hasNext()) { DeptDb lfch = (DeptDb)ir.next(); lfch.setOrders(orders); lfch.save(); orders ++; } int layer = 2; String parentCode = lf.getParentCode(); if (lf.getCode().equals(lf.ROOTCODE)) { layer = 1; } else { if (parentCode.equals(lf.ROOTCODE)) layer = 2; else { while (!parentCode.equals(lf.ROOTCODE)) { DeptDb parentLeaf = getDeptDb(parentCode); if (parentLeaf == null || !parentLeaf.isLoaded()) break; else { parentCode = parentLeaf.getParentCode(); } layer++; } } } lf.setLayer(layer); lf.save(); } public void repairTree(DeptDb leaf) throws Exception { repairLeaf(leaf); Vector children = getChildren(leaf.getCode()); int size = children.size(); if (size == 0) return; Iterator ri = children.iterator(); while (ri.hasNext()) { DeptDb childlf = (DeptDb) ri.next(); repairTree(childlf); } DeptCache dc = new DeptCache(); dc.removeAllFromCache(); }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?