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 + -
显示快捷键?