2369059705@qq.com
2023-05-27 6f6e5c91056f0d5ebde632f27443b76bffac1aef
解决了文档权限问题
已修改2个文件
39 ■■■■ 文件已修改
src/main/java/com/product/file/config/CmnConst.java 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/product/file/service/DocumentService.java 38 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/product/file/config/CmnConst.java
@@ -26,6 +26,7 @@
    public static final String product_oa_DOCUMENT_LOG = "product_oa_document_log";        // 文档操作日志表
    public static final String PRODUCT_SYS_PRINT_TEMPLATE_RECORD = "product_sys_print_template_reocrd";// 打印模板记录表
    public static final String PRODUCT_SYS_STAFFS = "product_sys_staffs";
    public static final String TABLE_PRODUCT_SYS_ORG_LEVELS = "product_sys_org_levels";// 组织机构表
    public static final String ATTACHMENT_CAPACITY = "attachment_capacity";
    public static final String RESULT = "result";
src/main/java/com/product/file/service/DocumentService.java
@@ -21,6 +21,8 @@
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
@@ -222,8 +224,16 @@
        baseDao.add(dataTableEntity);
    }
    public boolean verifyOrgExist(String org, Integer user_id) {
    public boolean verifyOrgExist(String org) {
        Integer user_id = SpringMVCContextHolder.getCurrentUser().getUser_id();
        String code = SpringMVCContextHolder.getCurrentUser().getCurrentStaff().getString("tricode");
        //获取所有上级编码
        String[] superior_code = new String[code.split("-").length - 1];
        for (int i = 0; i < code.split("-").length - 1; i++) {
            superior_code[i] = code.substring(0, code.length() - ((i + 1) * 4));
        }
        String this_user = String.valueOf(user_id);
        SpringMVCContextHolder.getCurrentUser().getLanguageCode();
        String[][] orgArr = BaseUtil.decomposesMultipleTypeValues(org);
        String[] user = orgArr[3];
        if (null != user) {
@@ -235,14 +245,28 @@
        }
        String[] level = orgArr[0];
        String[] dept = orgArr[1];
        String[] post = orgArr[2];
        // List<String> list = Arrays.asList(a);  --OK
        // List<String> list = Arrays.asList("A","B","C"); --OK
        // list.add("F"); --UnsupportedOperationException
        // list.remove("A"); --UnsupportedOperationException
        // list.set(1,"javaee");--OK (因为是把数组转为集合,其本质还是数组,数组长度固定不变,但内容可以改变)
        // 结论:虽然可以把数组转为集合,但是集合长度不能改变
        List list = new ArrayList();
        ;
        if (null != level) {
            DataTableEntity org_level_uuid = baseDao.listTable(CmnConst.PRODUCT_SYS_STAFFS, BaseUtil.buildQuestionMarkFilter("org_level_uuid", level, true) + " and user_id=?", new String[]{this_user});
            if (org_level_uuid.getRows() > 0) return true;
            list.addAll(Arrays.asList(level));
        }
        if (null != dept) {
            DataTableEntity dept_uuid = baseDao.listTable(CmnConst.PRODUCT_SYS_STAFFS, BaseUtil.buildQuestionMarkFilter("dept_uuid", dept, true) + " and user_id=?", new String[]{this_user});
            if (dept_uuid.getRows() > 0) return true;
            list.addAll(Arrays.asList(dept));
        }
        String[] level_dept = new String[list.size()];
        list.toArray(level_dept);
        String[] post = orgArr[2];
        if (level_dept.length != 0) {
            DataTableEntity org_level_uuid = baseDao.listTable(CmnConst.TABLE_PRODUCT_SYS_ORG_LEVELS, BaseUtil.buildQuestionMarkFilter("uuid", level_dept, true) + " and " + BaseUtil.buildQuestionMarkFilter("org_level_code", superior_code, true), new String[]{});
            if (org_level_uuid.getRows() > 0) return true;
        }
        if (null != post) {
            DataTableEntity post_uuid = baseDao.listTable(CmnConst.PRODUCT_SYS_STAFFS, BaseUtil.buildQuestionMarkFilter("job_post_uuid", post, true) + " and user_id=?", new String[]{this_user});
@@ -265,7 +289,7 @@
            //String key = "%,140,%";
            DataTableEntity dataTableEntity = new DataTableEntity();
            FieldSetEntity org = baseDao.getFieldSetByFilter(CmnConst.product_oa_DIRECTORY_RIGHTS, "directory_uuid=?", new String[]{directory_uuid}, false);
            if (verifyOrgExist(org.getString("storage_uuid"), user_id)) {
            if (verifyOrgExist(org.getString("storage_uuid"))) {
                StringBuffer sql = new StringBuffer();
                sql.append(" SELECT  substring_index(substring_index(a.rigths,',',b.help_topic_id+1),',',-1) fun FROM  product_oa_directory_rights a ")
                        .append(" INNER join   mysql.help_topic b on b.help_topic_id < (length(a.rigths) - length(replace(a.rigths,',',''))+1) ")