dine是什么意思| 气虚血虚吃什么中成药| 暑假什么时候结束| 妇科检查白细胞酯酶阳性是什么意思| 打招呼是什么意思| 牡蛎和生蚝有什么区别| 七月三号是什么日子| 潜能是什么意思| 孕妇吃核桃对胎儿有什么好处| 少一个肾有什么影响| 伥鬼是什么意思| 减肥期间吃什么最好| 同房子宫疼痛什么原因| 丰都为什么叫鬼城| 喝水不排尿是什么原因| 什么水解渴| 智齿长什么样子图片| 狗为什么喜欢吃人屎| 补液是什么意思| 马桶什么牌子好| 小狗可以吃什么| 什么海里没有鱼| 点读笔什么牌子好| 什么是roi| 什么是心律失常| 什么鬼大家都喜欢| 吃什么对嗓子好| 天亮是什么时辰| 甲流是什么| 夏天穿什么衣服| 阿飞是什么意思| 生物钟是什么| 语迟则人贵是什么意思| 话唠是什么意思| 吃什么会食物中毒| 左手小指疼痛预兆什么| 花可以组什么词| 哺乳期吃什么奶水多| 安全起见是什么意思| 海豹是什么动物| 什么是矿物质| 十月十四是什么星座| 什么榴莲最好吃| 七情六欲什么意思| 钓鲤鱼用什么饵料| 缺钙会导致什么| 六扇门是什么意思| 贫血会引起什么症状| 膳食是什么| 酮体是什么| 全麦是什么意思| 青鱼和草鱼有什么区别| 4月27日是什么星座| 心肌受损会出现什么症状| 香港电话前面加什么| ppi是什么意思啊| 什么地响| 为什么会尿频尿急| 嫁妆是什么意思| 万宝龙属于什么档次| 梦见打官司预示着什么| 吃什么可以来月经最快最有效| 宝宝爱出汗是什么原因| 1月底是什么星座| 书房字画写什么内容好| total什么意思| 摩羯座是什么动物| 农历六月十四是什么日子| 文化底蕴是什么意思| 做梦梦见剪头发是什么意思| 等字五行属什么| 甲功七项能查出什么病| 牙疼是什么病的前兆| 急性会厌炎吃什么药| 履历是什么意思| 高中什么时候分文理科| 王字加一笔是什么字| 诺如病毒是什么病| 反常是什么意思| 十月23日是什么星座| lotus是什么意思| 广东话扑街是什么意思| 安宫牛黄丸治什么病| 肺气肿吃什么药最有效| 什么是圆周率| 月经期间喝酒有什么危害| 醋酸生育酚是什么东西| 04年的猴是什么命| 抽烟是什么感觉| 中度贫血吃什么补血最快| 凌晨4点是什么时辰| 小便绿色是什么原因| 网监是干什么的| 九月九日是什么日子| 疏肝解郁是什么意思| 胆碱酯酶低是什么原因| lotus是什么意思| ibm是什么| 吃什么水果补气血| ab是什么血型| 七十岁是什么之年| 委曲求全是什么生肖| 孕中期宫缩是什么感觉| 胃恶心想吐是什么原因| 蚊子吃什么| 血沉高是什么意思| 血小板压积偏高是什么意思| jps是什么意思| 第一次世界大战是什么时候| 铁蛋白是什么| 嘴里有粘液是什么原因| 食道反流吃什么药| 什么什么龙什么| 春秋大梦是什么意思| 羊水指数和羊水深度有什么区别| 6月16日是什么日子| 吃什么主食减肥最快| 8月10日什么星座| 后卫是什么意思| 胃疼吃什么药最管用| 就诊卡号是什么| 乙肝看什么科| 孕妇吃花胶对胎儿有什么好处| 质控是什么意思| 尿蛋白高不能吃什么食物| 倒立对身体有什么好处| 脚臭是什么原因引起的| 吃什么对肺最好| 蚩尤是什么| 米线是什么做的| 脚趾麻木是什么病先兆| 喝茶为什么睡不着觉| 肌无力有什么症状| 尿常规白细胞3个加号什么意思| 为什么分泌物是褐色的| 乳房肿胀是什么原因| 薄谷开来为什么杀人| 厘清和理清的区别是什么| 唇系带短有什么影响| 头晕是什么原因引起| 静心是什么意思| 老油条什么意思| 用什么泡脚可以脸上祛斑| 二网是什么意思| 阴道炎应该吃什么药| 2016年属什么| 玳瑁色是什么颜色| 指甲上白色月牙代表什么| ost是什么意思| 绿色加蓝色是什么颜色| 七叶子是什么意思| 发烧喝什么饮料比较好| 四物汤什么时候喝最好| 过敏不能吃什么| 狗是什么生肖| 白头发多吃什么| qt是什么意思| 脾虚湿盛吃什么药| 鸡蛋壳薄是什么原因| 十灵日是什么意思| 5月7号是什么星座| 臀纹不对称有什么影响| 内疚是什么意思| maxrieny是什么品牌| 林俊杰的粉丝叫什么| 志趣相投是什么意思| 喜鹊吃什么食物| 空腹洗澡有什么危害| 轻度郁症有什么表现| 肺气肿吃什么药最有效| 什么弓什么箭| 为什么一喝牛奶就拉肚子| 果实属于什么器官| 亲子鉴定需要什么材料| 避孕套有什么牌子| 珍珠鸟吃什么食物| 拉屎屁股疼是什么原因| 7月23日什么星座| 女人下面水多是什么原因| 黑色的猫是什么品种| vol是什么意思| 方阵是什么意思| 身上湿气重吃什么药| 桃胶有什么功效与作用| runosd是什么牌子的手表| 肌肉痉挛吃什么药| ac是什么元素| 壁是什么意思| 72年属什么的生肖| 女性为什么不适合喝茉莉花茶| 心阳虚吃什么药| 早餐吃什么好| 副处长是什么级别| 什么帽子不能戴| 梦见小黑蛇是什么预兆| 什么是快闪| 包皮什么年龄割最好| 脚趾头麻木是什么原因引起的| 低血糖看什么科室| 心肌梗塞是什么原因造成的| 三点水加亘念什么| ak是什么| 失眠吃什么药| 类风湿挂什么科室| 亚历山大王什么档次| 3.1是什么星座| 现在什么最赚钱| 心脏不好挂什么科室| 糜烂性胃炎可以吃什么蔬菜| 什么店可以买到老鼠药| 宫颈多发纳氏囊肿是什么意思| 艾草有什么作用| 资生堂适合什么年龄段| 甲亢可以吃什么| 什么牌子的氨糖好| 小酌怡情下一句是什么| 静谧什么意思| 桑叶有什么功效和作用| 吃什么能排结石| 杭盖是什么意思| 口苦吃什么中成药| 10月16日是什么星座| 血小板高有什么危害| 酚氨咖敏片的别名叫什么| 肺栓塞是什么意思| 忐忑不安是什么意思| 脑梗前兆是什么症状| 水饮是什么意思| 五官立体是什么意思| 老豆是什么意思| 乳腺4a是什么意思| 什么的搏斗| 医院规培是什么意思| 血光之灾是什么意思| 虫至念什么| 什么叫做流年| 眉毛里面有痣代表什么| kappa是什么牌子| 自古红颜多薄命是什么意思| 屋尘螨是什么东西| 贱货是什么意思| 看破红尘什么意思| 爱是什么排比句| 什么菊花茶降火最好| 生长激素由什么分泌| 尿酸高是什么原因引起的| 肚子上方中间疼是什么部位| 陈皮不能和什么一起吃| 宫内膜回声不均匀是什么意思| 择日不如撞日什么意思| beauty是什么意思| 64年属什么的| 骨骼惊奇什么意思| 面首是什么| 3岁属什么生肖| 七月三十是什么星座| 皮肤病用什么药膏好| 上海市市委书记是什么级别| 小腿发麻是什么原因| 张学良为什么不回大陆| 什么颜色加什么颜色是紫色| 文静是什么意思| 98年虎是什么命| 梦见蝉是什么意思| 百度

SQL解析工具jsqlParser

百度 代表作品有《闯关东》《走西口》《穆桂英挂帅》等,在《穆桂英挂帅》中她与罗晋爱的惊天动地,两人的恋情也延伸到了戏外,期间因戏生情的姐弟恋不断传出。

1. Maven依赖

<dependency>
<groupId>com.github.jsqlparser</groupId>
<artifactId>jsqlparser</artifactId>
<version>4.5</version>
</dependency>
2. SQL校验
@Override
    public boolean validAdvancedSql(String advancedSql, List<String> allowedColumns) {
        if (StringUtils.isBlank(advancedSql)) {
            return true;
        }

        // 允许的查询操作符不能为空
        Map<String, String> queryOperatorMap = aptSurveyLogService.getSysDictDataByType("advanced_query_operator");
        if (CollectionUtils.isEmpty(queryOperatorMap)) {
            return false;
        }

        Set<String> allowedOperators = queryOperatorMap.keySet();
        // 构建完整SQL语句进行解析
        String sql = String.format("SELECT id FROM table WHERE %s", advancedSql);
        try {
            Select statement = (Select) CCJSqlParserUtil.parse(sql);
            PlainSelect plain = (PlainSelect) statement.getSelectBody();

            return validateExpression(plain.getWhere(), allowedColumns, allowedOperators);
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }
    }

    /**
     * 校验SQL中where语句是否合法
     *
     * @param expression sql表达式
     * @param allowedColumns 允许的列
     * @param allowedOperators 允许的操作符
     * @return 是否合法
     */
    private boolean validateExpression(Expression expression, List<String> allowedColumns, Set<String> allowedOperators) {
        if (expression instanceof AndExpression || expression instanceof OrExpression) {
            // 处理AND/OR逻辑表达式
            BinaryExpression binaryExpr = (BinaryExpression) expression;
            return validateExpression(binaryExpr.getLeftExpression(), allowedColumns, allowedOperators) && validateExpression(binaryExpr.getRightExpression(), allowedColumns, allowedOperators);
        } else if (expression instanceof Parenthesis) {
            // 处理括号表达式
            return validateExpression(((Parenthesis) expression).getExpression(), allowedColumns, allowedOperators);
        } else if (expression instanceof NotExpression) {
            // 处理Not条件
            return validateExpression(((NotExpression) expression).getExpression(), allowedColumns, allowedOperators);
        } else if (expression instanceof ComparisonOperator) {
            // 处理比较操作符
            ComparisonOperator comparison = (ComparisonOperator) expression;
            // 验证左操作数是否为合法列名
            if (!(comparison.getLeftExpression() instanceof Column)) {
                return false;
            }

            String columnName = ((Column) comparison.getLeftExpression()).getColumnName();
            if (!CollectionUtils.isEmpty(allowedColumns) && !allowedColumns.contains(columnName)) {
                return false;
            }

            // 验证操作符
            return allowedOperators.contains(comparison.getStringExpression());
        } else if (expression instanceof InExpression) {
            // 处理IN表达式
            InExpression inExpr = (InExpression) expression;
            if (!(inExpr.getLeftExpression() instanceof Column)) {
                return false;
            }

            String columnName = ((Column) inExpr.getLeftExpression()).getColumnName();
            if (!CollectionUtils.isEmpty(allowedColumns) && !allowedColumns.contains(columnName)) {
                return false;
            }

            return allowedOperators.contains(inExpr.isNot() ? "NOT IN" : "IN");
        } else if (expression instanceof LikeExpression) {
            // 处理LIKE表达式
            LikeExpression likeExpr = (LikeExpression) expression;
            if (!(likeExpr.getLeftExpression() instanceof Column)) {
                return false;
            }

            String columnName = ((Column) likeExpr.getLeftExpression()).getColumnName();
            if (!CollectionUtils.isEmpty(allowedColumns) && !allowedColumns.contains(columnName)) {
                return false;
            }

            return allowedOperators.contains(likeExpr.isNot() ? "NOT LIKE" : "LIKE");
        } else if (expression instanceof IsNullExpression) {
            // 处理IS NULL/IS NOT NULL
            IsNullExpression isNullExpr = (IsNullExpression) expression;
            if (!(isNullExpr.getLeftExpression() instanceof Column)) {
                return false;
            }

            String columnName = ((Column) isNullExpr.getLeftExpression()).getColumnName();
            if (!CollectionUtils.isEmpty(allowedColumns) && !allowedColumns.contains(columnName)) {
                return false;
            }

            return allowedOperators.contains(isNullExpr.isNot() ? "IS NOT NULL" : "IS NULL");
        } else if (expression instanceof Between) {
            // 处理BETWEEN
            Between betweenExpr = (Between) expression;
            if (!(betweenExpr.getLeftExpression() instanceof Column)) {
                return false;
            }

            String columnName = ((Column) betweenExpr.getLeftExpression()).getColumnName();
            if (!CollectionUtils.isEmpty(allowedColumns) && !allowedColumns.contains(columnName)) {
                return false;
            }

            return allowedOperators.contains("BETWEEN");
        } else {
            return false;
        }
    }

 

posted @ 2025-08-05 11:52  如幻行云  阅读(9)  评论(0)    收藏  举报
尿蛋白高有什么危害 左肋骨下方隐隐疼痛是什么原因 放荡不羁爱自由什么意思 b型血为什么招蚊子 唏嘘是什么意思
瓜怂是什么意思 白骨精什么意思 胎囊是什么 县级干部是什么级别 提高免疫力吃什么维生素
spiderking是什么牌子 脑补是什么意思 印度古代叫什么 la是什么品牌 眷顾是什么意思
夜尿频多吃什么药效果好 1990年的马是什么命 痛风买什么药 磨玻璃结节影是什么意思 会考是什么意思
什么人容易得白血病hcv9jop4ns0r.cn 减肥吃什么药好hcv8jop9ns4r.cn 梦见自己头发白了是什么意思hcv9jop4ns6r.cn 什么是尿频hcv8jop1ns8r.cn 双性是什么意思hcv8jop0ns9r.cn
一什么见什么hcv9jop3ns7r.cn 农历七月初六是什么星座hcv8jop0ns6r.cn 宝宝为什么老是吐奶hcv8jop9ns2r.cn 高血糖吃什么降得快weuuu.com 酱油什么时候发明的hcv7jop9ns3r.cn
黄喉是牛的什么部位hcv9jop6ns6r.cn 一步之遥是什么意思imcecn.com 测智力去医院挂什么科hcv8jop0ns9r.cn pony什么意思hcv9jop1ns4r.cn 物流是什么hcv8jop7ns8r.cn
一点是什么时辰hcv8jop7ns7r.cn 95年属什么的生肖hcv8jop6ns0r.cn 什么是快捷支付hcv7jop6ns1r.cn 2015属什么生肖hcv7jop5ns0r.cn 美国为什么打朝鲜hcv9jop2ns3r.cn
百度