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