本次的这个工具。
它可以一行命令把你所有 Markdown
写的内容中的图片全部替换为新的图床。
运行效果如下:
使用
可以直接在这个地址下载 jar 包运行:github.com/crossoverJi…
当然也可以下载源码编译运行:
git clone https://github.com/crossoverJie/blog.toolbox mvn clean package java -jar nows-0.0.1-SNAPSHOT.jar --app.downLoad.path=/xx/img /xx/xx/path 100
看运行方式也知道,其实就是用 SpringBoot
写了一个工具用于批量下载文中出现的图片同时上传后完成替换。
- 其中
app.downLoad.path
是用于将下载的图片保存到本地磁盘的目录。
/xx/xx/path
则是扫描.md
文件的目录,会递归扫描所有出所有文件。
- 100 则是需要替换文件的数量,默认是按照文件修改时间排序。
如果自己的图片较多的话还是有几个坑需要注意下。
线程数量
默认是启动了两个线程去遍历文件、上传下载图片、更新文本等内容,其中的网络 IO 其实挺耗时的,所以其实可以适当的多开些线程来提高任务的执行效率。
但线程过多也许会触发图床的保护机制,同时也和自己电脑配置有关,这个得结合实际情况考虑了。
所以可以通过 --app.thread=6
这样的参数来调整线程数量。
图床限制
这个是图片过多一定是大概率出现的,上传请求的频次过高很容易被限流封 IP。
{"code":"error","msg":"Upload file count limit. Time left 1027 second."}
目前来看是封 IP 居多,所以可以通过走代理、换网络的方式来解决。
当然如果是自搭图床可以无视。
重试
由于我使用的是免费图床,上传过程中偶尔也会出现上传失败的情况,因此默认是有 5 次重试机制的;如果五次都失败了那么大概率是 IP 被封了。
即便是 ip 被封后只要换了新的 ip 重新执行程序它会自动过滤掉已经替换的图片,不会再做无用功,这点可以放心。
图片保存
默认情况下,下载的图片会保存在本地,我也建议借此机会自己本地都缓存一份,同时名字还和文中的名字一样,避免今后图床彻底挂掉后连恢复的机会都没有。
总结
这个程序的代码就没怎么讲了,确实也挺简单,感兴趣的可以自己下来看看。
目前功能也很单一,自用完全够了;看后续大家是否还有其他需求再逐渐完善吧,比如:
- 图床上传失败自动切换到可用图床。
- 整体处理效率提升。
- 任务执行过程中更好的进度展现等。
再次贴一下源码地址: