diff --git a/assistTools/x-DecompilerWxApkgTool/build.gradle b/assistTools/x-DecompilerWxApkgTool/build.gradle index 924136e2b20939408d8e3a3b4337f10dc48e39af..212970b639c082c9a1d7e48ddd392556b9f75b86 100644 --- a/assistTools/x-DecompilerWxApkgTool/build.gradle +++ b/assistTools/x-DecompilerWxApkgTool/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') } diff --git a/assistTools/x-IdiomDataTool/build.gradle b/assistTools/x-IdiomDataTool/build.gradle index 0afef4a9b3eb3fb1431c565d27037bae85730142..ed39d2ff97d317e1866a4e955954498a0be77eb0 100644 --- a/assistTools/x-IdiomDataTool/build.gradle +++ b/assistTools/x-IdiomDataTool/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') implementation 'org.springframework:spring-jdbc:5.1.5.RELEASE' implementation 'com.h2database:h2:1.4.200' @@ -8,3 +7,9 @@ dependencies { group = 'com.xwintop' version = '0.0.1' description = 'x-IdiomDataTool' +//打jar包需要包含依赖的配置 +jar { + from { configurations.compileClasspath.findAll { it.name.contains("spring-jdbc") + || it.name.contains("h2") + }.collect { zipTree(it) } } +} diff --git a/assistTools/x-TextToSpeechTool/build.gradle b/assistTools/x-TextToSpeechTool/build.gradle index ef8ef03b7aa515e665a414a8332fdea4224f4ad0..c8b9d049051f21f9fcacc0797d8ffd6451d81a8d 100644 --- a/assistTools/x-TextToSpeechTool/build.gradle +++ b/assistTools/x-TextToSpeechTool/build.gradle @@ -1,9 +1,13 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') implementation 'com.baidu.aip:java-sdk:4.16.17' } group = 'com.xwintop' -version = '0.0.1' +version = '0.0.2' description = 'x-TextToSpeechTool' + +//打jar包需要包含依赖的配置 +jar { + from { configurations.compileClasspath.findAll { it.name.contains("java-sdk") }.collect { zipTree(it) } } +} diff --git a/build.gradle b/build.gradle index 165e866d5d36916a670f5a5f13a52ccf45559cfd..5705a780eb23abff4fb1acc839bd146457c6f5aa 100644 --- a/build.gradle +++ b/build.gradle @@ -12,7 +12,7 @@ //} plugins { - id "org.gradlex.extra-java-module-info" version "1.7" +// id "org.gradlex.extra-java-module-info" version "1.7" id "org.openjfx.javafxplugin" version "0.1.0" id 'idea' id 'application' @@ -21,6 +21,8 @@ plugins { subprojects { ext { springBootVersion = "2.7.18" + lombokVersion = "1.18.32" + javafxVersion = "21.0.3" } description 'xJavaFxTool' apply plugin: 'java' @@ -35,11 +37,11 @@ subprojects { repositories { maven { allowInsecureProtocol = true - url 'https://repo1.maven.org/maven2/' + url 'https://maven.aliyun.com/repository/public' } maven { allowInsecureProtocol = true - url 'https://maven.aliyun.com/repository/public' + url 'https://repo1.maven.org/maven2/' } maven { allowInsecureProtocol = true @@ -52,24 +54,24 @@ subprojects { [compileJava, compileTestJava, javadoc]*.options*.encoding = "UTF-8" dependencies { testImplementation 'org.junit.jupiter:junit-jupiter:5.10.2' - compileOnly('org.projectlombok:lombok:1.18.30') - annotationProcessor 'org.projectlombok:lombok:1.18.30' - testCompileOnly 'org.projectlombok:lombok:1.18.30' - testAnnotationProcessor 'org.projectlombok:lombok:1.18.30' -// api 'org.openjfx:javafx-controls:21.0.2' -// api 'org.openjfx:javafx-base:21.0.2' -// api 'org.openjfx:javafx-graphics:21.0.2' -// api 'org.openjfx:javafx-fxml:21.0.2' -// api 'org.openjfx:javafx-swing:21.0.2' -// api 'org.openjfx:javafx-media:21.0.2' -// api 'org.openjfx:javafx-web:21.0.2' + compileOnly("org.projectlombok:lombok:$lombokVersion") + annotationProcessor "org.projectlombok:lombok:$lombokVersion" + testCompileOnly "org.projectlombok:lombok:$lombokVersion" + testAnnotationProcessor "org.projectlombok:lombok:$lombokVersion" +// api "org.openjfx:javafx-controls:$javafxVersion" +// api "org.openjfx:javafx-base:$javafxVersion" +// api "org.openjfx:javafx-graphics:$javafxVersion" +// api "org.openjfx:javafx-fxml:$javafxVersion" +// api "org.openjfx:javafx-swing:$javafxVersion" +// api "org.openjfx:javafx-media:$javafxVersion" +// api "org.openjfx:javafx-web:$javafxVersion" } javafx { - version = "21.0.2" + version = "21.0.3" modules = ['javafx.controls', "javafx.graphics", 'javafx.fxml', 'javafx.media', 'javafx.swing', 'javafx.web'] // configuration = 'compileOnly' } - java { - modularity.inferModulePath = true - } +// java { +// modularity.inferModulePath = true +// } } \ No newline at end of file diff --git a/codeTools/x-CharsetDetectTool/build.gradle b/codeTools/x-CharsetDetectTool/build.gradle index fa6b8fe5f3e4ebc324977bc660fc36a17b6f4fb2..f9e984a5746422579ba04a38f94a4c392e1f8777 100644 --- a/codeTools/x-CharsetDetectTool/build.gradle +++ b/codeTools/x-CharsetDetectTool/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') implementation 'com.googlecode.juniversalchardet:juniversalchardet:1.0.3' } @@ -7,3 +6,8 @@ dependencies { group = 'com.xwintop' version = '0.0.1' description = 'x-CharsetDetectTool' + +//打jar包需要包含依赖的配置 +jar { + from { configurations.compileClasspath.findAll { it.name.contains("juniversalchardet") }.collect { zipTree(it) } } +} \ No newline at end of file diff --git a/codeTools/x-ColorCodeConverterTool/build.gradle b/codeTools/x-ColorCodeConverterTool/build.gradle index 60f9e42fdd497b400066a9fe989d1cb53378fc25..a44e406bc2252968c16cdfc2130faf7e0101c6cd 100644 --- a/codeTools/x-ColorCodeConverterTool/build.gradle +++ b/codeTools/x-ColorCodeConverterTool/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') } diff --git a/codeTools/x-EscapeCharacter/build.gradle b/codeTools/x-EscapeCharacter/build.gradle index 6fa4344a84dee10eb4fe102fedc21814d5a46251..e79f94f34e856b604a7facfbf62f4c4f1e6ebf1c 100644 --- a/codeTools/x-EscapeCharacter/build.gradle +++ b/codeTools/x-EscapeCharacter/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') // implementation 'org.apache.commons:commons-text:1.11.0' } diff --git a/codeTools/x-FileUnicodeTransformationTool/build.gradle b/codeTools/x-FileUnicodeTransformationTool/build.gradle index 8c726e60b0c20a7f24ec1c8c28dc6b3eb588c071..1d2a2f026b82c6deac992fc37a03bddcf0c334a1 100644 --- a/codeTools/x-FileUnicodeTransformationTool/build.gradle +++ b/codeTools/x-FileUnicodeTransformationTool/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') implementation 'com.googlecode.juniversalchardet:juniversalchardet:1.0.3' } @@ -8,7 +7,7 @@ group = 'com.xwintop' version = '0.0.1' description = 'x-FileUnicodeTransformationTool' -//打jar包需要的配置 +//打jar包需要包含依赖的配置 jar { from { configurations.compileClasspath.findAll { it.name.contains("juniversalchardet") }.collect { zipTree(it) } } } \ No newline at end of file diff --git a/codeTools/x-IdCardGenerator/build.gradle b/codeTools/x-IdCardGenerator/build.gradle index 0c8941b57c56ea1298ca0a06a3bfc8cf0b7edd75..c51e50f5339e593fdf95df3a4f575d8370331d2c 100644 --- a/codeTools/x-IdCardGenerator/build.gradle +++ b/codeTools/x-IdCardGenerator/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') } diff --git a/codeTools/x-RandomGeneratorTool/build.gradle b/codeTools/x-RandomGeneratorTool/build.gradle index 885832e770763de3fa7a78fd2b822e37aa87a1f7..6e454146b6bf1a30919f0d313ba3ceff14aca853 100644 --- a/codeTools/x-RandomGeneratorTool/build.gradle +++ b/codeTools/x-RandomGeneratorTool/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') } diff --git a/codeTools/x-RegexTester/build.gradle b/codeTools/x-RegexTester/build.gradle index c51d20e89c25e1c57ac1156d365dc4a43bf8da41..ae13d253adb442e2b401049b19ca281ade7d6fee 100644 --- a/codeTools/x-RegexTester/build.gradle +++ b/codeTools/x-RegexTester/build.gradle @@ -1,9 +1,13 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') implementation 'org.fxmisc.richtext:richtextfx:0.11.2' } group = 'com.xwintop' -version = '0.0.1' +version = '0.0.3' description = 'x-RegexTester' + +//打jar包需要包含依赖的配置 +jar { + from { configurations.compileClasspath.findAll { it.name.contains("richtextfx") }.collect { zipTree(it) } } +} \ No newline at end of file diff --git a/codeTools/x-WebSourcesTool/build.gradle b/codeTools/x-WebSourcesTool/build.gradle index 59fd89ade11cc36417f5fc1f1b247c09753081aa..8cf4acd1936e46e7da48aa409ea7f4a214c3b031 100644 --- a/codeTools/x-WebSourcesTool/build.gradle +++ b/codeTools/x-WebSourcesTool/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') implementation 'com.squareup.okhttp3:okhttp:4.12.0' } @@ -7,3 +6,8 @@ dependencies { group = 'com.xwintop' version = '0.0.1' description = 'x-WebSourcesTool' + +//打jar包需要包含依赖的配置 +jar { + from { configurations.compileClasspath.findAll { it.name.contains("okhttp") }.collect { zipTree(it) } } +} \ No newline at end of file diff --git a/debugTools/x-ActiveMqTool/build.gradle b/debugTools/x-ActiveMqTool/build.gradle index a2cf9f84f8a8d4b5d5c73caf310242451fa59dfe..cf78e88e145216a11d99048687e1e7a8653f574d 100644 --- a/debugTools/x-ActiveMqTool/build.gradle +++ b/debugTools/x-ActiveMqTool/build.gradle @@ -1,9 +1,13 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') implementation 'org.apache.activemq:activemq-broker:5.18.3' } group = 'com.xwintop' -version = '0.0.1' +version = '0.0.2' description = 'x-ActiveMqTool' + +//打jar包需要包含依赖的配置 +jar { + from { configurations.compileClasspath.findAll { it.name.contains("activemq-broker") }.collect { zipTree(it) } } +} \ No newline at end of file diff --git a/debugTools/x-CmdTool/build.gradle b/debugTools/x-CmdTool/build.gradle index 45e1ceb6f96eb5447cfdd7a89098b6680bb1ccb6..182196eda42de9d76270c6ea70627522ea8cefb8 100644 --- a/debugTools/x-CmdTool/build.gradle +++ b/debugTools/x-CmdTool/build.gradle @@ -1,5 +1,4 @@ dependencies { -// implementation 'com.xwintop:xcore:0.0.6' api project(':xcore') } diff --git a/debugTools/x-ExpressionParserTool/LICENSE b/debugTools/x-ExpressionParserTool/LICENSE new file mode 100644 index 0000000000000000000000000000000000000000..9e32cdef1625daed25cf365c865f01050877cff3 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/LICENSE @@ -0,0 +1,127 @@ + 木兰宽松许可证, 第2版 + + 木兰宽松许可证, 第2版 + 2020年1月 http://license.coscl.org.cn/MulanPSL2 + + + 您对“软件”的复制、使用、修改及分发受木兰宽松许可证,第2版(“本许可证”)的如下条款的约束: + + 0. 定义 + + “软件”是指由“贡献”构成的许可在“本许可证”下的程序和相关文档的集合。 + + “贡献”是指由任一“贡献者”许可在“本许可证”下的受版权法保护的作品。 + + “贡献者”是指将受版权法保护的作品许可在“本许可证”下的自然人或“法人实体”。 + + “法人实体”是指提交贡献的机构及其“关联实体”。 + + “关联实体”是指,对“本许可证”下的行为方而言,控制、受控制或与其共同受控制的机构,此处的控制是指有受控方或共同受控方至少50%直接或间接的投票权、资金或其他有价证券。 + + 1. 授予版权许可 + + 每个“贡献者”根据“本许可证”授予您永久性的、全球性的、免费的、非独占的、不可撤销的版权许可,您可以复制、使用、修改、分发其“贡献”,不论修改与否。 + + 2. 授予专利许可 + + 每个“贡献者”根据“本许可证”授予您永久性的、全球性的、免费的、非独占的、不可撤销的(根据本条规定撤销除外)专利许可,供您制造、委托制造、使用、许诺销售、销售、进口其“贡献”或以其他方式转移其“贡献”。前述专利许可仅限于“贡献者”现在或将来拥有或控制的其“贡献”本身或其“贡献”与许可“贡献”时的“软件”结合而将必然会侵犯的专利权利要求,不包括对“贡献”的修改或包含“贡献”的其他结合。如果您或您的“关联实体”直接或间接地,就“软件”或其中的“贡献”对任何人发起专利侵权诉讼(包括反诉或交叉诉讼)或其他专利维权行动,指控其侵犯专利权,则“本许可证”授予您对“软件”的专利许可自您提起诉讼或发起维权行动之日终止。 + + 3. 无商标许可 + + “本许可证”不提供对“贡献者”的商品名称、商标、服务标志或产品名称的商标许可,但您为满足第4条规定的声明义务而必须使用除外。 + + 4. 分发限制 + + 您可以在任何媒介中将“软件”以源程序形式或可执行形式重新分发,不论修改与否,但您必须向接收者提供“本许可证”的副本,并保留“软件”中的版权、商标、专利及免责声明。 + + 5. 免责声明与责任限制 + + “软件”及其中的“贡献”在提供时不带任何明示或默示的担保。在任何情况下,“贡献者”或版权所有者不对任何人因使用“软件”或其中的“贡献”而引发的任何直接或间接损失承担责任,不论因何种原因导致或者基于何种法律理论,即使其曾被建议有此种损失的可能性。 + + 6. 语言 + “本许可证”以中英文双语表述,中英文版本具有同等法律效力。如果中英文版本存在任何冲突不一致,以中文版为准。 + + 条款结束 + + 如何将木兰宽松许可证,第2版,应用到您的软件 + + 如果您希望将木兰宽松许可证,第2版,应用到您的新软件,为了方便接收者查阅,建议您完成如下三步: + + 1, 请您补充如下声明中的空白,包括软件名、软件的首次发表年份以及您作为版权人的名字; + + 2, 请您在软件包的一级目录下创建以“LICENSE”为名的文件,将整个许可证文本放入该文件中; + + 3, 请将如下声明文本放入每个源文件的头部注释中。 + + Copyright (c) [Year] [name of copyright holder] + [Software Name] is licensed under Mulan PSL v2. + You can use this software according to the terms and conditions of the Mulan PSL v2. + You may obtain a copy of Mulan PSL v2 at: + http://license.coscl.org.cn/MulanPSL2 + THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE. + See the Mulan PSL v2 for more details. + + + Mulan Permissive Software License,Version 2 + + Mulan Permissive Software License,Version 2 (Mulan PSL v2) + January 2020 http://license.coscl.org.cn/MulanPSL2 + + Your reproduction, use, modification and distribution of the Software shall be subject to Mulan PSL v2 (this License) with the following terms and conditions: + + 0. Definition + + Software means the program and related documents which are licensed under this License and comprise all Contribution(s). + + Contribution means the copyrightable work licensed by a particular Contributor under this License. + + Contributor means the Individual or Legal Entity who licenses its copyrightable work under this License. + + Legal Entity means the entity making a Contribution and all its Affiliates. + + Affiliates means entities that control, are controlled by, or are under common control with the acting entity under this License, ‘control’ means direct or indirect ownership of at least fifty percent (50%) of the voting power, capital or other securities of controlled or commonly controlled entity. + + 1. Grant of Copyright License + + Subject to the terms and conditions of this License, each Contributor hereby grants to you a perpetual, worldwide, royalty-free, non-exclusive, irrevocable copyright license to reproduce, use, modify, or distribute its Contribution, with modification or not. + + 2. Grant of Patent License + + Subject to the terms and conditions of this License, each Contributor hereby grants to you a perpetual, worldwide, royalty-free, non-exclusive, irrevocable (except for revocation under this Section) patent license to make, have made, use, offer for sale, sell, import or otherwise transfer its Contribution, where such patent license is only limited to the patent claims owned or controlled by such Contributor now or in future which will be necessarily infringed by its Contribution alone, or by combination of the Contribution with the Software to which the Contribution was contributed. The patent license shall not apply to any modification of the Contribution, and any other combination which includes the Contribution. If you or your Affiliates directly or indirectly institute patent litigation (including a cross claim or counterclaim in a litigation) or other patent enforcement activities against any individual or entity by alleging that the Software or any Contribution in it infringes patents, then any patent license granted to you under this License for the Software shall terminate as of the date such litigation or activity is filed or taken. + + 3. No Trademark License + + No trademark license is granted to use the trade names, trademarks, service marks, or product names of Contributor, except as required to fulfill notice requirements in Section 4. + + 4. Distribution Restriction + + You may distribute the Software in any medium with or without modification, whether in source or executable forms, provided that you provide recipients with a copy of this License and retain copyright, patent, trademark and disclaimer statements in the Software. + + 5. Disclaimer of Warranty and Limitation of Liability + + THE SOFTWARE AND CONTRIBUTION IN IT ARE PROVIDED WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED. IN NO EVENT SHALL ANY CONTRIBUTOR OR COPYRIGHT HOLDER BE LIABLE TO YOU FOR ANY DAMAGES, INCLUDING, BUT NOT LIMITED TO ANY DIRECT, OR INDIRECT, SPECIAL OR CONSEQUENTIAL DAMAGES ARISING FROM YOUR USE OR INABILITY TO USE THE SOFTWARE OR THE CONTRIBUTION IN IT, NO MATTER HOW IT’S CAUSED OR BASED ON WHICH LEGAL THEORY, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + + 6. Language + + THIS LICENSE IS WRITTEN IN BOTH CHINESE AND ENGLISH, AND THE CHINESE VERSION AND ENGLISH VERSION SHALL HAVE THE SAME LEGAL EFFECT. IN THE CASE OF DIVERGENCE BETWEEN THE CHINESE AND ENGLISH VERSIONS, THE CHINESE VERSION SHALL PREVAIL. + + END OF THE TERMS AND CONDITIONS + + How to Apply the Mulan Permissive Software License,Version 2 (Mulan PSL v2) to Your Software + + To apply the Mulan PSL v2 to your work, for easy identification by recipients, you are suggested to complete following three steps: + + i Fill in the blanks in following statement, including insert your software name, the year of the first publication of your software, and your name identified as the copyright owner; + + ii Create a file named “LICENSE” which contains the whole context of this License in the first directory of your software package; + + iii Attach the statement to the appropriate annotated syntax at the beginning of each source file. + + + Copyright (c) [Year] [name of copyright holder] + [Software Name] is licensed under Mulan PSL v2. + You can use this software according to the terms and conditions of the Mulan PSL v2. + You may obtain a copy of Mulan PSL v2 at: + http://license.coscl.org.cn/MulanPSL2 + THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE. + See the Mulan PSL v2 for more details. diff --git a/debugTools/x-ExpressionParserTool/README.md b/debugTools/x-ExpressionParserTool/README.md new file mode 100644 index 0000000000000000000000000000000000000000..98edd5f60ceb6883bdac97ecd4ea831d10b19947 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/README.md @@ -0,0 +1,26 @@ +ExpressionParserTool 表达式解析器调试工具 + +#### 项目简介: +ExpressionParserTool是使用javafx开发的一款表达式解析器调试工具,目前支持[SpringEL](https://docs.spring.io/spring-framework/docs/current/reference/html/core.html) 、[Velocity](http://velocity.apache.org/) 、[FreeMarker](http://freemarker.foofun.cn) 、[StringTemplate](https://www.stringtemplate.org) 、[Mvel](http://mvel.documentnode.com) 、[Aviator](http://fnil.net/aviator) 、[commons-jexl](http://commons.apache.org/proper/commons-jexl/index.html) 、[BeanShell](https://github.com/beanshell/beanshell) 、[QLExpress](https://github.com/alibaba/QLExpress) 等表达式引擎,支持在线调试运行脚本,及定时调度执行脚本。 + +#### 目前支持以下表达式引擎: +- [SpringEL](https://docs.spring.io/spring-framework/docs/current/reference/html/core.html) 是一个支持查询和操作运行时对象导航图功能的强大的表达式语言,不直接依赖于Spring,可独立使用 +- [Velocity](http://velocity.apache.org) 一个基于java的模板引擎(template engine)。它允许任何人仅仅简单的使用模板语言(template language)来引用由java代码定义的对象 +- [FreeMarker](http://freemarker.foofun.cn) 一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具 +- [StringTemplate](https://www.stringtemplate.org) 一种基于java的模板引擎库,可以用于生成源代码、web页面、电子邮件等多种样式的文本 +- [Mvel](http://mvel.documentnode.com) 是一个功能强大的基于Java应用程序的表达式语言 +- [Aviator](http://fnil.net/aviator) 是一个高性能、轻量级的java语言实现的表达式求值引擎,主要用于各种表达式的动态求值 +- [commons-jexl](http://commons.apache.org/proper/commons-jexl/index.html) 是一个表达式语言引擎,可以用来在应用或者框架中使用 +- [BeanShell](https://github.com/beanshell/beanshell) 是一个小型的、免费的、可嵌入的 Java 源代码解释器,具有对象脚本语言特性,用 Java 编写 +- [QLExpress](https://github.com/alibaba/QLExpress) 由阿里的电商业务规则、表达式(布尔组合)、特殊数学公式计算(高精度)、语法分析、脚本二次定制等强需求而设计的一门动态脚本引擎解析工具 + +**xJavaFxTool交流QQ群:== [387473650(此群已满)](https://jq.qq.com/?_wv=1027&k=59UDEAD) 请加群②[1104780992](https://jq.qq.com/?_wv=1027&k=bhAdkju9) ==** + +#### 环境搭建说明: +- 开发环境为jdk1.8,基于maven构建 +- 使用eclipase或Intellij Idea开发(推荐使用[Intellij Idea](https://www.jetbrains.com/?from=xJavaFxTool) ) +- 该项目为javaFx开发的实用小工具集[xJavaFxTool](https://gitee.com/xwintop/xJavaFxTool) 的插件,可在xJavaFxTool工具中下载使用。 +- 本项目使用了[lombok](https://projectlombok.org/) ,在查看本项目时如果您没有下载lombok 插件,请先安装,不然找不到get/set等方法 +- 依赖的[xcore包](https://gitee.com/xwintop/xcore) 已上传至git托管的maven平台,git托管maven可参考教程(若无法下载请拉取项目自行编译)。[教程地址:点击进入](http://blog.csdn.net/u011747754/article/details/78574026) + +![表达式解析器调试工具.png](images/表达式解析器调试工具.png) \ No newline at end of file diff --git a/debugTools/x-ExpressionParserTool/README_EN.md b/debugTools/x-ExpressionParserTool/README_EN.md new file mode 100644 index 0000000000000000000000000000000000000000..361b4d29a8cefb21c3175e02310846a4408199d0 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/README_EN.md @@ -0,0 +1 @@ +ExpressionParserTool \ No newline at end of file diff --git a/debugTools/x-ExpressionParserTool/build.gradle b/debugTools/x-ExpressionParserTool/build.gradle new file mode 100644 index 0000000000000000000000000000000000000000..93a501fae914a30378904c0d0ddbe5aaa9843b92 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/build.gradle @@ -0,0 +1,16 @@ +dependencies { + api project(':xcore') + implementation 'org.springframework:spring-expression:5.3.9' + implementation 'com.googlecode.aviator:aviator:5.2.7' + implementation 'org.mvel:mvel2:2.4.12.Final' + implementation 'org.apache.commons:commons-jexl3:3.2.1' + implementation 'org.apache-extras.beanshell:bsh:2.0b6' + implementation 'org.apache.velocity:velocity-engine-core:2.3' + implementation 'org.freemarker:freemarker:2.3.31' + implementation 'org.antlr:ST4:4.3.1' + implementation 'com.alibaba:QLExpress:3.2.0' +} + +group = 'com.xwintop' +version = '0.0.2' +description = 'x-ExpressionParserTool' \ No newline at end of file diff --git "a/debugTools/x-ExpressionParserTool/images/\350\241\250\350\276\276\345\274\217\350\247\243\346\236\220\345\231\250\350\260\203\350\257\225\345\267\245\345\205\267.png" "b/debugTools/x-ExpressionParserTool/images/\350\241\250\350\276\276\345\274\217\350\247\243\346\236\220\345\231\250\350\260\203\350\257\225\345\267\245\345\205\267.png" new file mode 100644 index 0000000000000000000000000000000000000000..b8a24fd229d1d114db565eb49ede2f8526f7fb2d Binary files /dev/null and "b/debugTools/x-ExpressionParserTool/images/\350\241\250\350\276\276\345\274\217\350\247\243\346\236\220\345\231\250\350\260\203\350\257\225\345\267\245\345\205\267.png" differ diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/ExpressionParserToolMain.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/ExpressionParserToolMain.java new file mode 100644 index 0000000000000000000000000000000000000000..37ee5c3bf07582a58a16278eee26ef090c3d9219 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/ExpressionParserToolMain.java @@ -0,0 +1,51 @@ +package com.xwintop.xJavaFxTool; + +import com.xwintop.xcore.util.javafx.JavaFxSystemUtil; +import javafx.application.Application; +import javafx.event.EventHandler; +import javafx.fxml.FXMLLoader; +import javafx.scene.Parent; +import javafx.scene.Scene; +import javafx.stage.Stage; +import javafx.stage.WindowEvent; +import lombok.extern.slf4j.Slf4j; + +import java.net.URL; +import java.util.ResourceBundle; + +@Slf4j +public class ExpressionParserToolMain extends Application { + public static void main(String[] args) { + try { + launch(args); + } catch (Exception e) { + e.printStackTrace(); + } + } + + @Override + public void start(Stage primaryStage) throws Exception { + FXMLLoader fXMLLoader = ExpressionParserToolMain.getFXMLLoader(); + ResourceBundle resourceBundle = fXMLLoader.getResources(); + Parent root = fXMLLoader.load(); + primaryStage.setResizable(true); + primaryStage.setTitle(resourceBundle.getString("Title")); +// primaryStage.getIcons().add(new Image("/images/icon.jpg")); + double[] screenSize = JavaFxSystemUtil.getScreenSizeByScale(0.74D, 0.8D); + primaryStage.setScene(new Scene(root, screenSize[0], screenSize[1])); + primaryStage.show(); + primaryStage.setOnCloseRequest(new EventHandler() { + @Override + public void handle(WindowEvent event) { + System.exit(0); + } + }); + } + + public static FXMLLoader getFXMLLoader() { + ResourceBundle resourceBundle = ResourceBundle.getBundle("locale.ExpressionParserTool"); + URL url = Object.class.getResource("/com/xwintop/xJavaFxTool/fxmlView/debugTools/ExpressionParserTool.fxml"); + FXMLLoader fXMLLoader = new FXMLLoader(url, resourceBundle); + return fXMLLoader; + } +} \ No newline at end of file diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/controller/debugTools/ExpressionParserToolController.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/controller/debugTools/ExpressionParserToolController.java new file mode 100644 index 0000000000000000000000000000000000000000..b3b3e8c8b71f1b5391db3c0728a41fd7de917221 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/controller/debugTools/ExpressionParserToolController.java @@ -0,0 +1,266 @@ +package com.xwintop.xJavaFxTool.controller.debugTools; + +import com.xwintop.xJavaFxTool.model.ExpressionParserToolTableBean; +import com.xwintop.xJavaFxTool.services.debugTools.ExpressionParserToolService; +import com.xwintop.xJavaFxTool.view.debugTools.ExpressionParserToolView; +import com.xwintop.xcore.util.javafx.JavaFxViewUtil; +import javafx.beans.value.ChangeListener; +import javafx.beans.value.ObservableValue; +import javafx.collections.FXCollections; +import javafx.collections.ListChangeListener; +import javafx.collections.ObservableList; +import javafx.event.ActionEvent; +import javafx.event.Event; +import javafx.fxml.FXML; +import javafx.scene.control.*; +import javafx.scene.control.cell.CheckBoxTableCell; +import javafx.scene.control.cell.PropertyValueFactory; +import javafx.scene.control.cell.TextFieldTableCell; +import javafx.scene.input.MouseButton; +import javafx.util.Callback; +import lombok.Getter; +import lombok.Setter; +import lombok.extern.slf4j.Slf4j; + +import java.net.URL; +import java.util.ResourceBundle; + +/** + * @ClassName: ExpressionParserToolController + * @Description: 表达式解析器工具类 + * @author: xufeng + * @date: 2021/9/12 22:52 + */ + +@Getter +@Setter +@Slf4j +public class ExpressionParserToolController extends ExpressionParserToolView { + private ExpressionParserToolService expressionParserToolService = new ExpressionParserToolService(this); + private ObservableList tableData = FXCollections.observableArrayList(); + private String[] quartzChoiceBoxStrings = new String[]{"简单表达式", "Cron表达式"}; + private String[] typeChoiceBoxStrings = new String[]{"SpringEl脚本", "SpringEl脚本文件", + "Aviator脚本", "Aviator脚本文件", "Jexl脚本", "Jexl脚本文件", "Mvel脚本", "Mvel脚本文件", + "BeanShell脚本", "BeanShell脚本文件", "Velocity脚本", "Velocity脚本文件", "FreeMarker脚本", + "FreeMarker脚本文件", "StringTemplate脚本", "StringTemplate脚本文件", "QLExpress脚本", "QLExpress脚本文件"}; + + @Override + public void initialize(URL location, ResourceBundle resources) { + initView(); + initEvent(); + initService(); + } + + private void initView() { + expressionParserToolService.loadingConfigure(); + orderTableColumn.setCellValueFactory(new PropertyValueFactory("order")); + orderTableColumn.setCellFactory(TextFieldTableCell.forTableColumn()); + orderTableColumn.setOnEditCommit((TableColumn.CellEditEvent t) -> { + t.getRowValue().setOrder(t.getNewValue()); + }); + + isEnabledTableColumn.setCellValueFactory(new PropertyValueFactory("isEnabled")); + isEnabledTableColumn.setCellFactory(CheckBoxTableCell.forTableColumn(isEnabledTableColumn)); + + scriptTableColumn.setCellValueFactory(new PropertyValueFactory("script")); + scriptTableColumn.setCellFactory(TextFieldTableCell.forTableColumn()); + scriptTableColumn.setOnEditCommit((TableColumn.CellEditEvent t) -> { + t.getRowValue().setScript(t.getNewValue()); + }); + + viewScriptTableColumn.setCellFactory((col) -> { + TableCell cell = new TableCell() { + @Override + public void updateItem(Boolean item, boolean empty) { + super.updateItem(item, empty); + this.setText(null); + this.setGraphic(null); + if (!empty) { + Button delBtn = new Button("查看"); + this.setContentDisplay(ContentDisplay.CENTER); + this.setGraphic(delBtn); + delBtn.setOnMouseClicked((me) -> { + ExpressionParserToolTableBean scriptEngineToolTableBean = tableData.get(this.getIndex()); + expressionParserToolService.showScriptAction(scriptEngineToolTableBean); + }); + } + } + }; + return cell; + }); + + typeTableColumn.setCellValueFactory(new PropertyValueFactory("type")); + typeTableColumn.setCellFactory( + new Callback, TableCell>() { + @Override + public TableCell call(TableColumn param) { + TableCell cell = new TableCell() { + @Override + protected void updateItem(String item, boolean empty) { + super.updateItem(item, empty); + this.setText(null); + this.setGraphic(null); + if (!empty) { + ChoiceBox choiceBox = new ChoiceBox(); + choiceBox.getItems().addAll(typeChoiceBoxStrings); + choiceBox.setValue(tableData.get(this.getIndex()).getType()); + choiceBox.valueProperty().addListener((obVal, oldVal, newVal) -> { + tableData.get(this.getIndex()).setType(newVal); + }); + this.setGraphic(choiceBox); + } + } + }; + return cell; + } + }); + + parameterTableColumn.setCellValueFactory(new PropertyValueFactory("parameter")); + parameterTableColumn.setCellFactory(TextFieldTableCell.forTableColumn()); + parameterTableColumn.setOnEditCommit((TableColumn.CellEditEvent t) -> { + t.getRowValue().setParameter(t.getNewValue()); + }); + + manualTableColumn.setCellFactory((col) -> { + TableCell cell = new TableCell() { + @Override + public void updateItem(Boolean item, boolean empty) { + super.updateItem(item, empty); + this.setText(null); + this.setGraphic(null); + if (!empty) { + Button delBtn = new Button("执行"); + this.setContentDisplay(ContentDisplay.CENTER); + this.setGraphic(delBtn); + delBtn.setOnMouseClicked((me) -> { + ExpressionParserToolTableBean scriptEngineToolTableBean = tableData.get(this.getIndex()); + expressionParserToolService.runAction(scriptEngineToolTableBean); + }); + } + } + }; + return cell; + }); + + isRunAfterActivateTableColumn + .setCellValueFactory(new PropertyValueFactory("isRunAfterActivate")); + isRunAfterActivateTableColumn.setCellFactory(CheckBoxTableCell.forTableColumn(isRunAfterActivateTableColumn)); + + runAfterActivateTableColumn + .setCellValueFactory(new PropertyValueFactory("runAfterActivate")); + runAfterActivateTableColumn.setCellFactory(TextFieldTableCell.forTableColumn()); + runAfterActivateTableColumn.setOnEditCommit((TableColumn.CellEditEvent t) -> { + t.getRowValue().setRunAfterActivate(t.getNewValue()); + }); + + remarksTableColumn.setCellValueFactory(new PropertyValueFactory("remarks")); + remarksTableColumn.setCellFactory(TextFieldTableCell.forTableColumn()); + remarksTableColumn.setOnEditCommit((TableColumn.CellEditEvent t) -> { + t.getRowValue().setRemarks(t.getNewValue()); + }); + + tableViewMain.setItems(tableData); + + quartzChoiceBox.getItems().addAll(quartzChoiceBoxStrings); + quartzChoiceBox.setValue(quartzChoiceBoxStrings[0]); + + typeChoiceBox.getItems().addAll(typeChoiceBoxStrings); + typeChoiceBox.setValue(typeChoiceBoxStrings[0]); + JavaFxViewUtil.setSpinnerValueFactory(intervalSpinner, 60, Integer.MAX_VALUE); + JavaFxViewUtil.setSpinnerValueFactory(repeatCountSpinner, -1, Integer.MAX_VALUE); + } + + private void initEvent() { + tableData.addListener((ListChangeListener.Change tableBean) -> { + try { + saveConfigure(null); + } catch (Exception e) { + log.error("保存配置失败", e); + } + }); + tableViewMain.setOnMouseClicked(event -> { + if (event.getButton() == MouseButton.SECONDARY) { + MenuItem menu_Copy = new MenuItem("复制选中行"); + menu_Copy.setOnAction(event1 -> { + ExpressionParserToolTableBean tableBean = tableViewMain.getSelectionModel().getSelectedItem(); + ExpressionParserToolTableBean tableBean2 = new ExpressionParserToolTableBean(tableBean.getPropertys()); + tableData.add(tableViewMain.getSelectionModel().getSelectedIndex(), tableBean2); + }); + MenuItem menu_Remove = new MenuItem("删除选中行"); + menu_Remove.setOnAction(event1 -> { + tableData.remove(tableViewMain.getSelectionModel().getSelectedItem()); + }); + MenuItem menu_RemoveAll = new MenuItem("删除所有"); + menu_RemoveAll.setOnAction(event1 -> { + tableData.clear(); + }); + tableViewMain.setContextMenu(new ContextMenu(menu_Copy, menu_Remove, menu_RemoveAll)); + } + }); + quartzChoiceBox.valueProperty().addListener(new ChangeListener() { + @Override + public void changed(ObservableValue observable, String oldValue, String newValue) { + if (quartzChoiceBoxStrings[0].equals(newValue)) { + cronTextField.setVisible(false); + simpleScheduleAnchorPane.setVisible(true); + } else if (quartzChoiceBoxStrings[1].equals(newValue)) { + cronTextField.setVisible(true); + simpleScheduleAnchorPane.setVisible(false); + } + } + }); + } + + private void initService() { + } + + @FXML + private void addItemAction(ActionEvent event) { + String id = "x" + String.valueOf(System.currentTimeMillis()).substring(7); + tableData.add(new ExpressionParserToolTableBean(id, isEnabledCheckBox.isSelected(), + scriptTextField.getText(), typeChoiceBox.getValue(), parameterTextField.getText(), false, " ", " ")); + } + + @FXML + private void saveConfigure(ActionEvent event) throws Exception { + expressionParserToolService.saveConfigure(); + } + + @FXML + private void otherSaveConfigureAction(ActionEvent event) throws Exception { + expressionParserToolService.otherSaveConfigureAction(); + } + + @FXML + private void loadingConfigureAction(ActionEvent event) { + expressionParserToolService.loadingConfigureAction(); + } + + @FXML + private void runQuartzAction(ActionEvent event) throws Exception { + if ("定时运行".equals(runQuartzButton.getText())) { + boolean isTrue = expressionParserToolService.runQuartzAction(quartzChoiceBox.getValue(), cronTextField.getText(), intervalSpinner.getValue(), + repeatCountSpinner.getValue()); + if (isTrue) { + runQuartzButton.setText("停止运行"); + } + } else { + boolean isTrue = expressionParserToolService.stopQuartzAction(); + if (isTrue) { + runQuartzButton.setText("定时运行"); + } + } + } + + @FXML + private void runAllAction(ActionEvent event) { + expressionParserToolService.runAllAction(); + } + + /** + * 父控件被移除前调用 + */ + public void onCloseRequest(Event event) throws Exception { + expressionParserToolService.stopQuartzAction(); + } +} \ No newline at end of file diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/job/ExpressionParserToolJob.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/job/ExpressionParserToolJob.java new file mode 100644 index 0000000000000000000000000000000000000000..ddb3f53bfcccd3f6757fe8b7a1919148456d0fc1 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/job/ExpressionParserToolJob.java @@ -0,0 +1,29 @@ +package com.xwintop.xJavaFxTool.job; + +import com.xwintop.xJavaFxTool.services.debugTools.ExpressionParserToolService; +import org.quartz.Job; +import org.quartz.JobExecutionContext; +import org.quartz.JobExecutionException; +import org.quartz.JobKey; + +/** + * @ClassName: ExpressionParserToolJob + * @Description: 表达式解析器调试工具Job + * @author: xufeng + * @date: 2021/9/12 22:52 + */ + +public class ExpressionParserToolJob implements Job{ + + @Override + public void execute(JobExecutionContext context) throws JobExecutionException { + ExpressionParserToolService expressionParserToolService = (ExpressionParserToolService) context.getMergedJobDataMap().get("Service"); + try { + expressionParserToolService.runAllAction(); + } catch (Exception e) { + e.printStackTrace(); + } + JobKey jobKey = context.getJobDetail().getKey(); + System.out.println("执行了"+jobKey); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/ExpressionParserScheduleManager.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/ExpressionParserScheduleManager.java new file mode 100644 index 0000000000000000000000000000000000000000..59ee140f6fbdcbfb08f1427d569bb9b95d94831c --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/ExpressionParserScheduleManager.java @@ -0,0 +1,87 @@ +package com.xwintop.xJavaFxTool.manager; + +import com.xwintop.xcore.util.javafx.TooltipUtil; +import lombok.Getter; +import lombok.Setter; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; +import org.quartz.*; +import org.quartz.impl.StdSchedulerFactory; + +/** + * @ClassName: ScheduleManager + * @Description: 自动任务管理类 + * @author: xufeng + * @date: 2018/1/25 16:35 + */ + +@Getter +@Setter +@Slf4j +public class ExpressionParserScheduleManager { + private SchedulerFactory sf = new StdSchedulerFactory(); + private String schedulerKeyGroup = "x"; + private String schedulerKeyName = "x" + System.currentTimeMillis(); + + public enum QuartzType { + SIMPLE //简单表达式 + , CRON //Cron表达式 + } + + public void runQuartzAction(Class jobClass, String quartzType, Object jobDataMap, String cronText, int interval, int repeatCount) throws Exception { + if ("简单表达式".equals(quartzType)) { + this.runQuartzAction(jobClass, jobDataMap, interval, repeatCount); + } else if ("Cron表达式".equals(quartzType)) { + if (StringUtils.isEmpty(cronText)) { + TooltipUtil.showToast("cron表达式不能为空。"); + throw new Exception("cron表达式不能为空。"); + } + this.runQuartzAction(jobClass, jobDataMap, cronText); + } + } + + public void runQuartzAction(Class jobClass, Object jobDataMap, int interval, int repeatCount) throws Exception { + runQuartzAction(jobClass, jobDataMap, QuartzType.SIMPLE, null, interval, repeatCount); + } + + public void runQuartzAction(Class jobClass, Object jobDataMap, String cronText) throws Exception { + runQuartzAction(jobClass, jobDataMap, QuartzType.CRON, cronText, 0, 0); + } + + public void runQuartzAction(Class jobClass, Object jobDataMap, QuartzType quartzType, String cronText, int interval, int repeatCount) throws Exception { + schedulerKeyGroup = jobClass.toString(); + schedulerKeyName = schedulerKeyGroup + System.currentTimeMillis(); + JobDetail jobDetail = JobBuilder.newJob(jobClass).withIdentity(schedulerKeyName, schedulerKeyGroup) + .build(); + jobDetail.getJobDataMap().put("Service", jobDataMap); + ScheduleBuilder scheduleBuilder = null; + if (QuartzType.SIMPLE.equals(quartzType)) { + scheduleBuilder = SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(interval)// 时间间隔 + .withRepeatCount(repeatCount);// 重复次数(将执行6次) + } else if (QuartzType.CRON.equals(quartzType)) { + if (StringUtils.isEmpty(cronText)) { + throw new Exception("cron表达式不能为空。"); + } + scheduleBuilder = CronScheduleBuilder.cronSchedule(cronText); + } + // 描叙触发Job执行的时间触发规则,Trigger实例化一个触发器 + Trigger trigger = TriggerBuilder.newTrigger()// 创建一个新的TriggerBuilder来规范一个触发器 + .withIdentity(schedulerKeyName, schedulerKeyGroup)// 给触发器一个名字和组名 + .startNow()// 立即执行 + .withSchedule(scheduleBuilder).build();// 产生触发器 + + // 运行容器,使用SchedulerFactory创建Scheduler实例 + Scheduler scheduler = sf.getScheduler(); + // 向Scheduler添加一个job和trigger + scheduler.scheduleJob(jobDetail, trigger); + if (!scheduler.isStarted()) { + scheduler.start(); + } + } + + public void stopQuartzAction() throws Exception { + Scheduler sched = sf.getScheduler(); + sched.unscheduleJob(new TriggerKey(schedulerKeyName, schedulerKeyGroup)); + sched.deleteJob(new JobKey(schedulerKeyName, schedulerKeyGroup)); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParser.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParser.java new file mode 100644 index 0000000000000000000000000000000000000000..2690b412f99a0c60b57d8084ee527bbeb9568e76 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParser.java @@ -0,0 +1,21 @@ +package com.xwintop.xJavaFxTool.manager.script; + +import java.io.File; +import java.util.Map; + +/** + * @ClassName: ExpressionParser + * @Description: 表达式解析器接口 + * @author: xufeng + * @date: 2021/9/12 22:50 + */ + +public interface ExpressionParser { + public Object eval(String script) throws Exception;//运行脚本并返回结果 + public Object eval(String script, Map vars) throws Exception;//带参数运行脚本并返回结果 + public Object eval(File scriptFile) throws Exception;//运行脚本文件并返回结果 + + public void exec(String script) throws Exception;//运行脚本 + public void exec(String script, Map vars) throws Exception;//带参数运行脚本 + public void exec(File scriptFile) throws Exception;//运行脚本文件 +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParserManager.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParserManager.java new file mode 100644 index 0000000000000000000000000000000000000000..cd67639042f826a9324a6ec631f6dcf6b20ab0c6 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParserManager.java @@ -0,0 +1,124 @@ +package com.xwintop.xJavaFxTool.manager.script; + +import com.xwintop.xJavaFxTool.manager.script.QLExpress.QLExpressEngine; +import com.xwintop.xJavaFxTool.manager.script.SpringEl.SpringElEngine; +import com.xwintop.xJavaFxTool.manager.script.aviator.AviatorEngine; +import com.xwintop.xJavaFxTool.manager.script.beanshell.BeanShellEngine; +import com.xwintop.xJavaFxTool.manager.script.freeMarker.FreeMarkerEngine; +import com.xwintop.xJavaFxTool.manager.script.mvel.MvelEngine; +import com.xwintop.xJavaFxTool.manager.script.jexl.JexlEngine; +import com.xwintop.xJavaFxTool.manager.script.stringTemplate.StringTemplateEngine; +import com.xwintop.xJavaFxTool.manager.script.velocity.VelocityEngine; +import lombok.Getter; +import lombok.Setter; +import lombok.extern.slf4j.Slf4j; + +import java.io.File; +import java.util.Map; + +/** + * @ClassName: ExpressionParserManager + * @Description: 表达式解析器管理类 + * @author: xufeng + * @date: 2021/9/12 22:51 + */ + +@Getter +@Setter +@Slf4j +public class ExpressionParserManager implements ExpressionParser { + private ExpressionParserType expressionParserType; + private ExpressionParser expressionParser = null; + + public ExpressionParserManager() { + } + + public ExpressionParserManager(String expressionParserType) { + this.expressionParserType = ExpressionParserType.getEnum(expressionParserType); + + } + + public ExpressionParserManager(ExpressionParserType expressionParserType) { + this.expressionParserType = expressionParserType; + } + + public ExpressionParser getExpressionParser() { + if (expressionParser == null) { + expressionParser = getEngineByName(this.expressionParserType); + } + return expressionParser; + } + + public static ExpressionParser getEngineByName(String scriptEngineType) { + return getEngineByName(ExpressionParserType.getEnum(scriptEngineType)); + } + + /** + * 根据类型获取脚本引擎 + */ + public static ExpressionParser getEngineByName(ExpressionParserType scriptEngineType) { + ExpressionParser scriptEngine = null; + switch (scriptEngineType) { + case SpringEl: + scriptEngine = new SpringElEngine(); + break; + case Aviator: + scriptEngine = new AviatorEngine(); + break; + case Jexl: + scriptEngine = new JexlEngine(); + break; + case Mvel: + scriptEngine = new MvelEngine(); + break; + case BeanShell: + scriptEngine = new BeanShellEngine(); + break; + case Velocity: + scriptEngine = new VelocityEngine(); + break; + case FreeMarker: + scriptEngine = new FreeMarkerEngine(); + break; + case StringTemplate: + scriptEngine = new StringTemplateEngine(); + break; + case QLExpress: + scriptEngine = new QLExpressEngine(); + break; + default: + break; + } + return scriptEngine; + } + + @Override + public Object eval(String script) throws Exception { + return getExpressionParser().eval(script); + } + + @Override + public Object eval(String script, Map vars) throws Exception { + return getExpressionParser().eval(script, vars); + } + + @Override + public Object eval(File scriptFile) throws Exception { + return getExpressionParser().eval(scriptFile); + } + + @Override + public void exec(String script) throws Exception { + getExpressionParser().exec(script); + } + + @Override + public void exec(String script, Map vars) throws Exception { + getExpressionParser().exec(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + getExpressionParser().exec(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParserType.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParserType.java new file mode 100644 index 0000000000000000000000000000000000000000..db8bf2147122e6df677a34c8d8ed67dbacf93ae6 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/ExpressionParserType.java @@ -0,0 +1,40 @@ +package com.xwintop.xJavaFxTool.manager.script; + +/** + * @ClassName: ExpressionParserType + * @Description: 表达式解析器类型 + * @author: xufeng + * @date: 2021/9/12 22:55 + */ + +public enum ExpressionParserType { + SpringEl("SpringEl"), + Aviator("Aviator"), + Jexl("Jexl"), + BeanShell("BeanShell"), + Mvel("Mvel"), + Velocity("Velocity"), + StringTemplate("StringTemplate"), + QLExpress("QLExpress"), + FreeMarker("FreeMarker"); + private String value; + + ExpressionParserType(String value) { + this.value = value; + } + + public String getValue() { + return value; + } + + public static ExpressionParserType getEnum(String value) { + ExpressionParserType e = null; + for (ExpressionParserType e1 : ExpressionParserType.values()) { + if (e1.value.equals(value)) { + e = e1; + break; + } + } + return e; + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/QLExpress/QLExpressEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/QLExpress/QLExpressEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..7865d2c19016e9bf02233bb4ac30046da92cf713 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/QLExpress/QLExpressEngine.java @@ -0,0 +1,59 @@ +package com.xwintop.xJavaFxTool.manager.script.QLExpress; + +import com.ql.util.express.DefaultContext; +import com.ql.util.express.ExpressRunner; +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.io.FileUtils; + +import java.io.File; +import java.nio.charset.StandardCharsets; +import java.util.Map; + +/** + * @ClassName: QLExpressEngine + * @Description: QLExpress脚本引擎 + * @author: xufeng + * @date: 2021/9/13 18:34 + */ + +@Slf4j +public class QLExpressEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map vars) throws Exception { + ExpressRunner runner = new ExpressRunner(); + DefaultContext context = new DefaultContext(); + if (vars != null) { + vars.forEach((o, o2) -> { + context.put(String.valueOf(o), o2); + }); + } + return runner.execute(script, context, null, true, false); + } + + @Override + public Object eval(File scriptFile) throws Exception { + String script = FileUtils.readFileToString(scriptFile, StandardCharsets.UTF_8); + return eval(script); + } + + @Override + public void exec(String script) throws Exception { + exec(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/SpringEl/SpringElEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/SpringEl/SpringElEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..b0061ac561eae438a0034af0957980e23f355079 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/SpringEl/SpringElEngine.java @@ -0,0 +1,62 @@ +package com.xwintop.xJavaFxTool.manager.script.SpringEl; + +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import org.apache.commons.io.FileUtils; +import org.springframework.expression.EvaluationContext; +import org.springframework.expression.Expression; +import org.springframework.expression.spel.standard.SpelExpressionParser; +import org.springframework.expression.spel.support.StandardEvaluationContext; + +import java.io.File; +import java.nio.charset.StandardCharsets; +import java.util.Map; + +/** + * @ClassName: SpringElEngine + * @Description: SpringEl表达式解析器 + * @author: xufeng + * @date: 2021/9/11 23:38 + */ + +public class SpringElEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map vars) throws Exception { + org.springframework.expression.ExpressionParser paser = new SpelExpressionParser();//创建表达式解析器 + //通过evaluationContext.setVariable可以在上下文中设定变量。 + EvaluationContext context = new StandardEvaluationContext(); + if (vars != null) { + vars.forEach((o, o2) -> { + context.setVariable(String.valueOf(o), o2); + }); + } + //解析表达式,如果表达式是一个模板表达式,需要为解析传入模板解析器上下文。 + Expression expression = paser.parseExpression(script); + return expression.getValue(context); + } + + @Override + public Object eval(File scriptFile) throws Exception { + String script = FileUtils.readFileToString(scriptFile, StandardCharsets.UTF_8); + return eval(script); + } + + @Override + public void exec(String script) throws Exception { + eval(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/aviator/AviatorEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/aviator/AviatorEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..0db3efb9a2060d62c54fd40d0ae3639ea17136ff --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/aviator/AviatorEngine.java @@ -0,0 +1,53 @@ +package com.xwintop.xJavaFxTool.manager.script.aviator; + +import com.googlecode.aviator.AviatorEvaluator; +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import org.apache.commons.io.FileUtils; + +import java.io.File; +import java.nio.charset.StandardCharsets; +import java.util.Map; + +/** + * @ClassName: AviatorEngine + * @Description: Aviator表达式解析器 + * @author: xufeng + * @date: 2021/9/12 10:43 + */ + +public class AviatorEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map ctx) throws Exception { + if (ctx == null) { + return AviatorEvaluator.execute(script); + } else { + return AviatorEvaluator.execute(script, ctx); + } + } + + @Override + public Object eval(File scriptFile) throws Exception { + String script = FileUtils.readFileToString(scriptFile, StandardCharsets.UTF_8); + return eval(script); + } + + @Override + public void exec(String script) throws Exception { + eval(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/beanshell/BeanShellEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/beanshell/BeanShellEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..8b7b0f5fd565ccd80df38a6002afb9c14c1493fc --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/beanshell/BeanShellEngine.java @@ -0,0 +1,62 @@ +package com.xwintop.xJavaFxTool.manager.script.beanshell; + +import bsh.EvalError; +import bsh.Interpreter; +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.io.FileUtils; + +import java.io.File; +import java.nio.charset.StandardCharsets; +import java.util.Map; + +/** + * @ClassName: BeanShellEngine + * @Description: BeanShell表达式引擎 + * @author: xufeng + * @date: 2021/9/12 14:49 + */ + +@Slf4j +public class BeanShellEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map vars) throws Exception { + Interpreter interpreter = new Interpreter(); + if (vars != null) { + vars.forEach((o, o2) -> { + try { + interpreter.set(String.valueOf(o), o2); + } catch (EvalError e) { + log.error("BeanShell设置属性失败!", e); + } + }); + } + return interpreter.eval(script); + } + + @Override + public Object eval(File scriptFile) throws Exception { + String script = FileUtils.readFileToString(scriptFile, StandardCharsets.UTF_8); + return eval(script); + } + + @Override + public void exec(String script) throws Exception { + exec(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/freeMarker/FreeMarkerEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/freeMarker/FreeMarkerEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..5045e7d64bd84f564bfcfd93678c5b47f7e6203a --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/freeMarker/FreeMarkerEngine.java @@ -0,0 +1,64 @@ +package com.xwintop.xJavaFxTool.manager.script.freeMarker; + +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import freemarker.cache.StringTemplateLoader; +import freemarker.template.Configuration; +import freemarker.template.Template; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.io.FileUtils; + +import java.io.File; +import java.io.StringWriter; +import java.nio.charset.StandardCharsets; +import java.util.Map; + +/** + * @ClassName: FreeMarkerEngine + * @Description: FreeMarker模板引擎 + * @author: xufeng + * @date: 2021/9/12 19:03 + */ + +@Slf4j +public class FreeMarkerEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map vars) throws Exception { + Configuration configuration = new Configuration(Configuration.VERSION_2_3_22); + StringTemplateLoader stringTemplateLoader = new StringTemplateLoader(); + Template template; + + stringTemplateLoader.putTemplate("freeMarker.ftl", script); + configuration.setTemplateLoader(stringTemplateLoader); + template = configuration.getTemplate("freeMarker.ftl"); + + StringWriter stringWriter = new StringWriter(); + template.process(vars, stringWriter); + return stringWriter.toString(); + } + + @Override + public Object eval(File scriptFile) throws Exception { + String script = FileUtils.readFileToString(scriptFile, StandardCharsets.UTF_8); + return eval(script); + } + + @Override + public void exec(String script) throws Exception { + exec(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/jexl/JexlEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/jexl/JexlEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..72d1f08fbb1630e08220a07bd74f9c402f050b7b --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/jexl/JexlEngine.java @@ -0,0 +1,58 @@ +package com.xwintop.xJavaFxTool.manager.script.jexl; + +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import org.apache.commons.io.FileUtils; +import org.apache.commons.jexl3.JexlBuilder; +import org.apache.commons.jexl3.JexlContext; +import org.apache.commons.jexl3.JexlExpression; +import org.apache.commons.jexl3.MapContext; + +import java.io.File; +import java.nio.charset.StandardCharsets; +import java.util.Map; + +/** + * @ClassName: JexlEngine + * @Description: Jexl表达式引擎 + * @author: xufeng + * @date: 2021/9/12 11:40 + */ + +public class JexlEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map vars) throws Exception { + org.apache.commons.jexl3.JexlEngine jexl = new JexlBuilder().create(); + // Create an expression + JexlExpression e = jexl.createExpression(script); + // Create a context and add data + JexlContext jc = new MapContext(vars); + // Now evaluate the expression, getting the result + return e.evaluate(jc); + } + + @Override + public Object eval(File scriptFile) throws Exception { + String script = FileUtils.readFileToString(scriptFile, StandardCharsets.UTF_8); + return eval(script); + } + + @Override + public void exec(String script) throws Exception { + exec(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/mvel/MvelEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/mvel/MvelEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..de08fea894a68b283a91970b168c5315bb1c63a9 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/mvel/MvelEngine.java @@ -0,0 +1,46 @@ +package com.xwintop.xJavaFxTool.manager.script.mvel; + +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import org.mvel2.MVEL; + +import java.io.File; +import java.util.Map; + +/** + * @ClassName: MvelEngine + * @Description: Mvel表达式解析器 + * @author: xufeng + * @date: 2021/9/12 10:42 + */ + +public class MvelEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map vars) throws Exception { + return MVEL.eval(script, vars); + } + + @Override + public Object eval(File scriptFile) throws Exception { + return MVEL.evalFile(scriptFile); + } + + @Override + public void exec(String script) throws Exception { + eval(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/stringTemplate/StringTemplateEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/stringTemplate/StringTemplateEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..40f099d938cf8f94a6b9eb7f2bb598f18fa3c227 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/stringTemplate/StringTemplateEngine.java @@ -0,0 +1,55 @@ +package com.xwintop.xJavaFxTool.manager.script.stringTemplate; + +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import org.apache.commons.io.FileUtils; +import org.stringtemplate.v4.ST; + +import java.io.File; +import java.nio.charset.StandardCharsets; +import java.util.Map; + +/** + * @ClassName: StringTemplateEngine + * @Description: StringTemplate模板引擎 + * @author: xufeng + * @date: 2021/9/12 21:58 + */ + +public class StringTemplateEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map vars) throws Exception { + ST st = new ST(script); + if (vars != null) { + vars.forEach((o, o2) -> { + st.add(String.valueOf(o), o2); + }); + } + return st.render(); + } + + @Override + public Object eval(File scriptFile) throws Exception { + String script = FileUtils.readFileToString(scriptFile, StandardCharsets.UTF_8); + return eval(script); + } + + @Override + public void exec(String script) throws Exception { + exec(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/velocity/VelocityEngine.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/velocity/VelocityEngine.java new file mode 100644 index 0000000000000000000000000000000000000000..aee2b77c82d09c73b62613515291a3460bb98df8 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/manager/script/velocity/VelocityEngine.java @@ -0,0 +1,59 @@ +package com.xwintop.xJavaFxTool.manager.script.velocity; + +import com.xwintop.xJavaFxTool.manager.script.ExpressionParser; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.io.FileUtils; +import org.apache.velocity.VelocityContext; + +import java.io.File; +import java.io.StringWriter; +import java.nio.charset.StandardCharsets; +import java.util.Map; + +/** + * @ClassName: VelocityEngine + * @Description: Velocity模板引擎 + * @author: xufeng + * @date: 2021/9/12 17:01 + */ + +@Slf4j +public class VelocityEngine implements ExpressionParser { + @Override + public Object eval(String script) throws Exception { + return eval(script, null); + } + + @Override + public Object eval(String script, Map ctx) throws Exception { + org.apache.velocity.app.VelocityEngine velocityEngine = new org.apache.velocity.app.VelocityEngine(); + velocityEngine.init(); + VelocityContext velocityContext = new VelocityContext(ctx); + StringWriter stringWriter = new StringWriter(); + if (!velocityEngine.evaluate(velocityContext, stringWriter, "VelocityEngine", script)) { + log.error("解析Velocity模板引擎失败!"); + } + return stringWriter.toString(); + } + + @Override + public Object eval(File scriptFile) throws Exception { + String script = FileUtils.readFileToString(scriptFile, StandardCharsets.UTF_8); + return eval(script); + } + + @Override + public void exec(String script) throws Exception { + eval(script, null); + } + + @Override + public void exec(String script, Map vars) throws Exception { + eval(script, vars); + } + + @Override + public void exec(File scriptFile) throws Exception { + eval(scriptFile); + } +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/model/ExpressionParserToolTableBean.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/model/ExpressionParserToolTableBean.java new file mode 100644 index 0000000000000000000000000000000000000000..c4738fbc5514d26a85df3f00b7cf31677def4ed3 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/model/ExpressionParserToolTableBean.java @@ -0,0 +1,125 @@ +package com.xwintop.xJavaFxTool.model; + +import javafx.beans.property.BooleanProperty; +import javafx.beans.property.SimpleBooleanProperty; +import javafx.beans.property.SimpleStringProperty; + +/** + * @ClassName: ScriptEngineToolTableBean + * @Description: 脚本调试工具表bean + * @author: xufeng + * @date: 2018/1/27 18:02 + */ + +public class ExpressionParserToolTableBean { + private SimpleStringProperty order;// 序列 + private SimpleBooleanProperty isEnabled;// 是否启用 + private SimpleStringProperty script;// 脚本 + private SimpleStringProperty type;// 执行类型 + private SimpleStringProperty parameter;// 参数 + private SimpleBooleanProperty isRunAfterActivate;// 是否执行触发事件 + private SimpleStringProperty runAfterActivate;// 执行后触发事件 + private SimpleStringProperty remarks;// 备注 + + public ExpressionParserToolTableBean(String order, Boolean isEnabled, String script, String type, String parameter, + Boolean isRunAfterActivate, String runAfterActivate, String remarks) { + this.order = new SimpleStringProperty(order); + this.isEnabled = new SimpleBooleanProperty(isEnabled); + this.script = new SimpleStringProperty(script); + this.type = new SimpleStringProperty(type); + this.parameter = new SimpleStringProperty(parameter); + this.isRunAfterActivate = new SimpleBooleanProperty(isRunAfterActivate); + this.runAfterActivate = new SimpleStringProperty(runAfterActivate); + this.remarks = new SimpleStringProperty(remarks); + } + + public ExpressionParserToolTableBean(String propertys) { + String[] strings = propertys.split("__", 8); + this.order = new SimpleStringProperty(strings[0]); + this.isEnabled = new SimpleBooleanProperty(Boolean.valueOf(strings[1])); + this.script = new SimpleStringProperty(strings[2]); + this.type = new SimpleStringProperty(strings[3]); + this.parameter = new SimpleStringProperty(strings[4]); + this.isRunAfterActivate = new SimpleBooleanProperty(Boolean.valueOf(strings[5])); + this.runAfterActivate = new SimpleStringProperty(strings[6]); + this.remarks = new SimpleStringProperty(strings[7]); + } + + public String getPropertys() { + return order.get() + "__" + isEnabled.get() + "__" + script.get() + "__" + type.get() + "__" + parameter.get() + + "__" + isRunAfterActivate.get() + "__" + runAfterActivate.get() + "__" + remarks.get(); + } + + public String getOrder() { + return order.get(); + } + + public void setOrder(String order) { + this.order.set(order); + } + + public BooleanProperty isEnabledProperty() { + return isEnabled; + } + + public Boolean getIsEnabled() { + return isEnabled.get(); + } + + public void setIsEnabled(Boolean isEnabled) { + this.isEnabled.set(isEnabled); + } + + public String getScript() { + return script.get(); + } + + public void setScript(String script) { + this.script.set(script); + } + + public String getType() { + return type.get(); + } + + public void setType(String type) { + this.type.set(type); + } + + public String getParameter() { + return parameter.get(); + } + + public void setParameter(String parameter) { + this.parameter.set(parameter); + } + + public BooleanProperty isRunAfterActivateProperty() { + return isRunAfterActivate; + } + + public Boolean getIsRunAfterActivate() { + return isRunAfterActivate.get(); + } + + public void setIsRunAfterActivate(Boolean isRunAfterActivate) { + this.isRunAfterActivate.set(isRunAfterActivate); + } + + public String getRunAfterActivate() { + return runAfterActivate.get(); + } + + public void setRunAfterActivate(String runAfterActivate) { + this.runAfterActivate.set(runAfterActivate); + } + + public String getRemarks() { + return remarks.get(); + } + + public void setRemarks(String remarks) { + this.remarks.set(remarks); + } + +} diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/services/debugTools/ExpressionParserToolService.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/services/debugTools/ExpressionParserToolService.java new file mode 100644 index 0000000000000000000000000000000000000000..3c70d3cb1b4c863ca1e9202ffd79c27c5f889a88 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/services/debugTools/ExpressionParserToolService.java @@ -0,0 +1,223 @@ +package com.xwintop.xJavaFxTool.services.debugTools; + +import com.alibaba.fastjson2.JSON; +import com.xwintop.xJavaFxTool.controller.debugTools.ExpressionParserToolController; +import com.xwintop.xJavaFxTool.job.ExpressionParserToolJob; +import com.xwintop.xJavaFxTool.manager.ExpressionParserScheduleManager; +import com.xwintop.xJavaFxTool.manager.script.ExpressionParserManager; +import com.xwintop.xJavaFxTool.model.ExpressionParserToolTableBean; +import com.xwintop.xcore.util.ConfigureUtil; +import com.xwintop.xcore.util.javafx.AlertUtil; +import com.xwintop.xcore.util.javafx.FileChooserUtil; +import com.xwintop.xcore.util.javafx.TooltipUtil; +import javafx.stage.FileChooser; +import lombok.Getter; +import lombok.Setter; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; + +import java.io.File; +import java.util.Map; + +/** + * @ClassName: ScriptEngineToolService + * @Description: 脚本引擎调试工具类 + * @author: xufeng + * @date: 2018/1/28 22:59 + */ + +@Getter +@Setter +@Slf4j +public class ExpressionParserToolService { + private ExpressionParserToolController expressionParserToolController; + private String fileName = "expressionParserToolConfigure.properties"; + private ExpressionParserScheduleManager scheduleManager = new ExpressionParserScheduleManager(); + + public ExpressionParserToolService(ExpressionParserToolController expressionParserToolController) { + this.expressionParserToolController = expressionParserToolController; + } + + /** + * @Title: runAllAction + * @Description: 运行所有动作 + */ + public void runAllAction() { + for (ExpressionParserToolTableBean scriptEngineToolTableBean : expressionParserToolController.getTableData()) { + if (scriptEngineToolTableBean.getIsEnabled()) { + runAction(scriptEngineToolTableBean); + } + } + } + + /** + * @Title: runAction + * @Description: 单独运行 + */ + public void runAction(ExpressionParserToolTableBean scriptEngineToolTableBean) { + String type = scriptEngineToolTableBean.getType(); + String script = scriptEngineToolTableBean.getScript(); + System.out.println("运行:" + type + " : " + script); + addLog("运行:" + type + " : " + script); + Map parameterMap = null; + if (StringUtils.isNotEmpty(scriptEngineToolTableBean.getParameter())) { + parameterMap = JSON.parseObject(scriptEngineToolTableBean.getParameter(), Map.class); + } + try { + Object log = null; + if (expressionParserToolController.getTypeChoiceBoxStrings()[0].equals(type)) {// SpringEl脚本 + log = new ExpressionParserManager("SpringEl").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[1].equals(type)) {// SpringEl脚本文件 + log = new ExpressionParserManager("SpringEl").eval(new File(script)); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[2].equals(type)) {// Aviator脚本 + log = new ExpressionParserManager("Aviator").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[3].equals(type)) {// Aviator脚本文件 + log = new ExpressionParserManager("Aviator").eval(new File(script)); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[4].equals(type)) {// Jexl脚本 + log = new ExpressionParserManager("Jexl").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[5].equals(type)) {// Jexl脚本文件 + log = new ExpressionParserManager("Jexl").eval(new File(script)); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[6].equals(type)) {// Mvel脚本 + log = new ExpressionParserManager("Mvel").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[7].equals(type)) {// Mvel脚本文件 + log = new ExpressionParserManager("Mvel").eval(new File(script)); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[8].equals(type)) {// BeanShell脚本 + log = new ExpressionParserManager("BeanShell").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[9].equals(type)) {// BeanShell脚本文件 + log = new ExpressionParserManager("BeanShell").eval(new File(script)); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[10].equals(type)) {// Velocity脚本 + log = new ExpressionParserManager("Velocity").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[11].equals(type)) {// Velocity脚本文件 + log = new ExpressionParserManager("Velocity").eval(new File(script)); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[12].equals(type)) {// FreeMarker脚本 + log = new ExpressionParserManager("FreeMarker").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[13].equals(type)) {// FreeMarker脚本文件 + log = new ExpressionParserManager("FreeMarker").eval(new File(script)); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[14].equals(type)) {// StringTemplate脚本 + log = new ExpressionParserManager("StringTemplate").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[15].equals(type)) {// StringTemplate脚本文件 + log = new ExpressionParserManager("StringTemplate").eval(new File(script)); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[16].equals(type)) {// QLExpress脚本 + log = new ExpressionParserManager("QLExpress").eval(script, parameterMap); + } else if (expressionParserToolController.getTypeChoiceBoxStrings()[17].equals(type)) {// QLExpress脚本文件 + log = new ExpressionParserManager("QLExpress").eval(new File(script)); + } + addLog(log); + //继续执行后触发任务 + if (scriptEngineToolTableBean.getIsRunAfterActivate()) { + for (ExpressionParserToolTableBean tableBean : expressionParserToolController.getTableData()) { + if (tableBean.getOrder().equals(scriptEngineToolTableBean.getRunAfterActivate())) { + runAction(tableBean); + break; + } + } + } + } catch (Exception e) { + log.error("运行脚本出错", e); + } + } + + + /** + * 向控制台添加日志信息 + * + * @param log 日志 + */ + public void addLog(Object log) { + if (log != null) { + this.getExpressionParserToolController().getLogTextArea().appendText("\n" + log.toString()); + } + } + + /** + * @Title: showScriptAction + * @Description: 查看脚本文件 + */ + public void showScriptAction(ExpressionParserToolTableBean scriptEngineToolTableBean) { + String type = scriptEngineToolTableBean.getType(); + String script = scriptEngineToolTableBean.getScript(); + System.out.println("查看:" + type + " : " + script); + try { +// if (scriptEngineToolController.getTypeChoiceBoxStrings()[0].equals(type)) {// 命令行 +// AlertUtil.showInfoAlert("脚本命令", script); +// } else if (scriptEngineToolController.getTypeChoiceBoxStrings()[1].equals(type)) {// 脚本文件 +// Runtime.getRuntime().exec("NotePad.exe " + script); +// } + if (type.contains("文件")) {// 命令行 + Runtime.getRuntime().exec("NotePad.exe " + script); + } else {// 脚本文件 + AlertUtil.showInfoAlert("脚本命令", script); + } + } catch (Exception e) { + log.error("查看脚本失败!!", e); + TooltipUtil.showToast("查看脚本失败!!" + e.getMessage()); + } + } + + public boolean runQuartzAction(String quartzType, String cronText, int interval, int repeatCount) throws Exception { + if ("简单表达式".equals(quartzType)) { + scheduleManager.runQuartzAction(ExpressionParserToolJob.class, this, interval, repeatCount); + } else if ("Cron表达式".equals(quartzType)) { + if (StringUtils.isEmpty(cronText)) { + TooltipUtil.showToast("cron表达式不能为空。"); + return false; + } + scheduleManager.runQuartzAction(ExpressionParserToolJob.class, this, cronText); + } + return true; + } + + public boolean stopQuartzAction() throws Exception { + scheduleManager.stopQuartzAction(); + return true; + } + + public void saveConfigure() throws Exception { + saveConfigure(ConfigureUtil.getConfigureFile(fileName)); + } + + public void saveConfigure(File file) throws Exception { + ConfigureUtil.getConfig(file).clear(); + for (int i = 0; i < expressionParserToolController.getTableData().size(); i++) { + ConfigureUtil.set(file, "tableBean" + i, expressionParserToolController.getTableData().get(i).getPropertys()); + } + TooltipUtil.showToast("保存配置成功,保存在:" + file.getPath()); + } + + public void otherSaveConfigureAction() throws Exception { + File file = FileChooserUtil.chooseSaveFile(fileName, new FileChooser.ExtensionFilter("All File", "*.*"), + new FileChooser.ExtensionFilter("Properties", "*.properties")); + if (file != null) { + saveConfigure(file); + TooltipUtil.showToast("保存配置成功,保存在:" + file.getPath()); + } + } + + public void loadingConfigure() { + loadingConfigure(ConfigureUtil.getConfigureFile(fileName)); + } + + public void loadingConfigure(File file) { + try { + expressionParserToolController.getTableData().clear(); + Map xmlConfigure = ConfigureUtil.getConfig(file); + for (Object t : xmlConfigure.keySet()) { + expressionParserToolController.getTableData().add(new ExpressionParserToolTableBean((String) xmlConfigure.get(t))); + } + } catch (Exception e) { + try { + log.error("加载配置失败:" + e.getMessage()); + TooltipUtil.showToast("加载配置失败:" + e.getMessage()); + } catch (Exception e2) { + } + } + } + + public void loadingConfigureAction() { + File file = FileChooserUtil.chooseFile(new FileChooser.ExtensionFilter("All File", "*.*"), + new FileChooser.ExtensionFilter("Properties", "*.properties")); + if (file != null) { + loadingConfigure(file); + } + } +} \ No newline at end of file diff --git a/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/view/debugTools/ExpressionParserToolView.java b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/view/debugTools/ExpressionParserToolView.java new file mode 100644 index 0000000000000000000000000000000000000000..7b32fb4d2b41240a28c1905cdb553e1e5fb42b1b --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/java/com/xwintop/xJavaFxTool/view/debugTools/ExpressionParserToolView.java @@ -0,0 +1,75 @@ +package com.xwintop.xJavaFxTool.view.debugTools; +import com.xwintop.xJavaFxTool.model.ExpressionParserToolTableBean; +import lombok.Getter; +import lombok.Setter; +import javafx.fxml.Initializable; +import javafx.fxml.FXML; +import javafx.scene.control.Button; +import javafx.scene.control.CheckBox; +import javafx.scene.control.ChoiceBox; +import javafx.scene.control.Spinner; +import javafx.scene.control.TableColumn; +import javafx.scene.control.TableView; +import javafx.scene.control.TextArea; +import javafx.scene.control.TextField; +import javafx.scene.layout.AnchorPane; + +/** + * @ClassName: ExpressionParserToolView + * @Description: 表达式解析器调试工具 + * @author: xufeng + * @date: 2021/9/12 22:56 + */ + +@Getter +@Setter +public abstract class ExpressionParserToolView implements Initializable { + @FXML + protected CheckBox isEnabledCheckBox; + @FXML + protected TextArea scriptTextField; + @FXML + protected ChoiceBox typeChoiceBox; + @FXML + protected TextArea parameterTextField; + @FXML + protected Button addItemButton; + @FXML + protected ChoiceBox quartzChoiceBox; + @FXML + protected TextField cronTextField; + @FXML + protected AnchorPane simpleScheduleAnchorPane; + @FXML + protected Spinner intervalSpinner; + @FXML + protected Spinner repeatCountSpinner; + @FXML + protected Button runQuartzButton; + @FXML + protected Button runAllButton; + @FXML + protected TableView tableViewMain; + @FXML + protected TableColumn orderTableColumn; + @FXML + protected TableColumn isEnabledTableColumn; + @FXML + protected TableColumn scriptTableColumn; + @FXML + protected TableColumn viewScriptTableColumn; + @FXML + protected TableColumn typeTableColumn; + @FXML + protected TableColumn parameterTableColumn; + @FXML + protected TableColumn manualTableColumn; + @FXML + protected TableColumn isRunAfterActivateTableColumn; + @FXML + protected TableColumn runAfterActivateTableColumn; + @FXML + protected TableColumn remarksTableColumn; + @FXML + protected TextArea logTextArea; +} \ No newline at end of file diff --git a/debugTools/x-ExpressionParserTool/src/main/resources/com/xwintop/xJavaFxTool/fxmlView/debugTools/ExpressionParserTool.fxml b/debugTools/x-ExpressionParserTool/src/main/resources/com/xwintop/xJavaFxTool/fxmlView/debugTools/ExpressionParserTool.fxml new file mode 100644 index 0000000000000000000000000000000000000000..eb4faa38817297a4e1b88b6d1a0dc420ee7eb252 --- /dev/null +++ b/debugTools/x-ExpressionParserTool/src/main/resources/com/xwintop/xJavaFxTool/fxmlView/debugTools/ExpressionParserTool.fxml @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + +