克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
MIT

WeTool 工具箱

WeTool是一款基于JavaFX开发的轻量级、简洁、可插件式扩展的通用工具箱。

主要功能

  • 文件批量重命名
  • 剪贴板历史
  • JSON路径语法测试
  • 识别文件编码,文件编码转换
  • 二维码的解码与生成
  • 随机字符生成器
  • 支持自定义插件路径,支持手动加载插件
  • 支持插件隔离加载
  • 支持事件的发布与订阅(查看内置事件
  • 插件管理面板
  • Windows虚拟桌面触发角
  • 支持数据库连接(查看配置属性
  • 支持监听鼠标键盘
  • 支持暴露HTTP服务
  • 支持暗黑模式
  • 支持开启HTTP文件浏览服务(默认端口8189,未指定暴露的文件路径时会弹窗选择)
  • 更多功能来插件库查看哦

下载与使用

运行环境:需安装有Java11及以上版本

下载WETOOL-1.6.0.ZIP
查看更新历史
自己打包(或者下载上面的ZIP包)
git clone https://gitee.com/code4everything/wetool.git
cd wetool
mvn package [-D javafx.platform=[win|mac|linux]]
运行(windows和mac平台双击对应jar包即可运行)
# windows平台
javaw -jar ./wetool.jar
# mac或linux平台
java -jar ./wetool.jar &

说明:运行软件需安装有Java11及以上版本,另外日志文件保存路径:${user.home}/logs/wetool/wetool.log

插件的安装(使用Ctrl+Shift+P打开插件面板即可安装插件)

如果是自己手动下载的插件,那么将插件放到当前工作目录的plugins目录下,重启程序即可

运行截图

wetool

wetool

wetool

搜索框

搜索框可以搜索本应用内工具(包括插件),搜索工具时输入关键字然后按空格触发下拉框,选择对应的工具回车即可。

搜索框还支持执行命名,目前支持的命令如下:

  • hutool: 需要安装 hutool-cli ,安装完成记得重启wetool,同时支持无关键字触发,如 hutool random-uuid 可去掉hutool前缀变为 random-uuid
  • env: 查看环境变量,如:env HUTOOL_PATH
  • go: 用内置浏览器打开网页,如:go baidu.com
  • file-browser: 开启http文件浏览服务,如:file-browser 80:get/file/*, file-browser get/* c:\Users

使用小技巧

  • HTTP文件上传服务,首先在配置文件中设置上传文件的保存目录,然后浏览器打开 文件上传页面
  • 使用全局快捷键 Ctrl+Alt+Shift+Enter 显示或隐藏主界面
  • 应用内使用快捷键 Ctrl+数字 选中指定位置的选项卡,数字 9 表示选中最后一个
  • 关闭指定位置的选项卡:Alt+数字,数字 9 表示关闭最后一个
  • 关闭所有未选中选项卡:Ctrl+Shift+F4
  • 快捷键 Ctrl+P 搜索应用内工具,键入空格后搜索,回车执行相应的动作
  • 隐藏主界面:按 Esc 取消窗体内控件的焦点,再按 Esc 隐藏窗体
  • 关闭选中的选项卡:方法一,使用快捷键 Ctrl+F4;方法二,按 Esc 取消窗体内控件的焦点,按 X 键关闭TAB
  • 快速聚焦到指定控件:1. 按 Esc 取消窗体内控件的焦点,2. 输入要聚焦控件的大概位置(如:6),3. 按 Enter 快速聚焦到该位置的控件

配置文件说明

程序会在启动时根据当前的系统名称加载当前工作目录下与之对应的配置文件we-config-{}.json, 其中{}可以为winmaclin分别对应WindowsMac以及Linux平台,如上述文件不存在,那么将加载默认的配置文件we-config.json, 如果配置文件加载失败,程序将放弃运行,直接退出。

数据库配置:在配置文件中新增 dbConnections 字段,如其名,该字段为数组类型,数组中每个元素的配置属性请参考Druid,建议把name字段填上,便于识别,示例如下:

{
    /*其他配置属性*/
    /*................*/
    "dbConnections": [
        {
            "name": "test",
            "url": "jdbc:mysql://localserver:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=Asia/Shanghai",
            "username": "root",
            "password": "root",
            "initialSize": "1",
            "keepAlive": true
        },
        {
            "name": "local_prod",
            "url": "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=Asia/Shanghai",
            "username": "test",
            "password": "test",
            "initialSize": "0",
            "minEvictableIdleTimeMillis": 600000
        }
    ]
}

使用开发版本

下载项目源代码

git clone https://gitee.com/code4everything/wetool.git
git clone https://gitee.com/code4everything/wetool-plugin.git

安装依赖库

cd /your_path/wetool-plugin
git checkout develop
cd wetool-plugin-support
mvn clean install

打包可执行jar包

cd /your_path/wetool
git checkout develop
cd bin
python package.py

可执行jar包会打包到项目的根目录下。

开发说明

所需环境

  • JDK 11.0.5
  • Maven 3.6
  • Scene Builder 2.0
  • IDEA 2019.3
  • Lombok
  • Git

开发调试过程中,建议运行WeApplicationTest主类, 而不是运行主类WeApplication, 运行WeApplication类时产生的日志数据会被输出到文件中,而WeApplicationTest则只会输出到终端,并且会输出debug日志,方便开发调试。

插件开发

没有你需要的功能?没关系,一分钟快速了解插件的开发过程:传送门

结语

关于插件的支持,纯粹是为了减轻本工具包的负担,毕竟本工具的宗旨是轻量级、轻量级、轻量级,而某些只会在特定场景下使用的功能则以插件的方式加载进来,可以极大缩减本工具包的大小,而不至于臃肿。

如果你觉得这个项目还不错,可将鼠标移动至Star处,轻轻点一下,以示支持哦^_^

欢迎提Issue,Pull Request,大家一起交流学习。

The MIT License (MIT) Copyright (c) 2018 easepan Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

简介

一款基于JavaFX开发的轻量级、简洁、可插件式扩展的通用工具箱 展开 收起
Java
MIT
取消

发行版

暂无发行版

贡献者

全部

近期动态

不能加载更多了
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化