directory.java

来自「一个用java编写的功能强大的OA系统」· Java 代码 · 共 201 行

JAVA
201
字号
package com.redmoon.oa.netdisk;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;public class Directory {    String connname = "";    Logger logger = Logger.getLogger(Directory.class.getName());    public Directory() {        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 name = "", code = "", parent_code = "";        name = ParamUtil.get(request, "name").trim();        if (name == null || name.equals(""))            throw new ErrMsgException("名称不能为空!");        code = ParamUtil.get(request, "code").trim();        if (code.equals(""))            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");        String pluginCode = ParamUtil.get(request, "pluginCode");        Leaf lf = new Leaf();        lf = lf.getLeaf(code);        if (lf!=null && lf.isLoaded())            throw new ErrMsgException("已存在相同编码的节点:" + lf.getName());        lf = new Leaf();        lf.setName(name);        lf.setCode(code);        lf.setParentCode(parent_code);        lf.setDescription(description);        lf.setType(type);        lf.setPluginCode(pluginCode);        Leaf leaf = getLeaf(parent_code);        return leaf.AddChild(lf);    }    public void del(String delcode) throws ErrMsgException {        Leaf lf = getLeaf(delcode);        lf.del(lf);    }    public synchronized boolean update(HttpServletRequest request) throws            ErrMsgException {        String code = ParamUtil.get(request, "code");        String name = ParamUtil.get(request, "name");        String description = ParamUtil.get(request, "description");        boolean isHome = ParamUtil.get(request, "isHome").equals("true") ? true : false;        int type = ParamUtil.getInt(request, "type");        if (code.equals("") || name.equals("")) {            throw new ErrMsgException("编码和名称项必填!");        }        int templateId = ParamUtil.getInt(request, "templateId");        String parentCode = ParamUtil.get(request, "parentCode");        String pluginCode = ParamUtil.get(request, "pluginCode");        Leaf leaf = getLeaf(code);        leaf.setName(name);        leaf.setDescription(description);        leaf.setIsHome(isHome);        leaf.setType(type);        leaf.setTemplateId(templateId);        leaf.setPluginCode(pluginCode);        boolean re = false;        if (parentCode.equals(leaf.getParentCode()))            re = leaf.update();        else            re = leaf.update(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("编码与方向项必填!");        }        Leaf lf = new Leaf(code);        return lf.move(direction);    }    public Leaf getLeaf(String code) {        Leaf leaf = new Leaf();        return leaf.getLeaf(code);    }    public Leaf getBrother(String code, String direction) throws            ErrMsgException {        Leaf lf = getLeaf(code);        return lf.getBrother(direction);    }    public Vector getChildren(String code) throws ErrMsgException {        Leaf leaf = getLeaf(code);        return leaf.getChildren();    }        public String getSubLeaves(String parentCode, int layer) {        if (layer>2)            return "";        String str = "";        LeafChildrenCacheMgr lcc = new LeafChildrenCacheMgr(parentCode);        Vector v = lcc.getList();        Iterator ir = v.iterator();                while (ir.hasNext()) {            Leaf lf = (Leaf) ir.next();            if (layer==2) {                                  lcc = new LeafChildrenCacheMgr(lf.getCode());                 Iterator ir2 = lcc.getList().iterator();                 while (ir2.hasNext()) {                     lf = (Leaf) ir2.next();                     if (str.equals(""))                         str = StrUtil.sqlstr(lf.getCode());                     else                         str += "," + StrUtil.sqlstr(lf.getCode());                 }            }            else {                if (str.equals(""))                    str = StrUtil.sqlstr(lf.getCode());                else                    str += "," + StrUtil.sqlstr(lf.getCode());            }        }        return str;    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?