Typora中自定义命令上传图片

Typora是我经常用的一款Markdown编辑器,简洁的风格、实用的功能,口碑真的很赞。最近发现Typora支持自定义上传图片的功能,原先上传图片需要使用第三方应用,比如iPicuPic等,现在有了自定义功能就能上传图片到任意图床了。功能如下图:

149

于是就打算自己写一个上传脚本,先看下Typora文档说明

311

重点红色框中已经标出来了,上传后的返回结果需要这种格式,Typora才能识别是否上传成功。这里图床,我使用了SM.MS,用了很久了,不担心跑路。看接口

515

如果Authorization不传,就是匿名的。

好了,现在上代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#!/bin/bash
# Author: bilberry
# Date: 2021-05-04
# 公众号:正义的程序猿

arr=()
for img_path in "$@"
do
res=$(curl -s --location --request POST 'https://sm.ms/api/v2/upload' \
--header 'Content-Type: multipart/form-data' \
--form 'smfile=@'"${img_path}")

success=`echo $res | python3 -c "import sys, json; r=json.load(sys.stdin)['success']; print(r);"`

if [ "$success" == 'True' -o "$usccess" == 'true' ]
then
r=`echo $res | python3 -c "import sys, json; r=json.load(sys.stdin)['data']['url']; print(r);"`
arr[${#arr[@]}]=$r
fi
done

if [ ${#arr[@]} -eq $# -a $# -gt 0 ]
then
echo 'Upload Success:'
for a in "${arr[@]}"
do
echo $a
done
else
echo 'Upload Failed'
fi

代码就是这样,shell脚本是我现学的,不是很复杂,当然也有一些特殊情况没有考虑,比如SM.MS上传了重复的图片,会返回如下内容:

1
2
3
4
5
6
7
{
"success": false,
"code": "image_repeated",
"message": "Image upload repeated limit, this image exists at: https://i.loli.net/2021/05/04/qbrdwglp5k7cKDZMjv.png",
"images": "https://i.loli.net/2021/05/04/qbrdwglp5k7cKDZMjv.png",
"RequestId": "2FDCAB12-972E-4871-AFC8-921552C02AF5"
}

接口返回的是JSON格式,shell处理JSON还比较麻烦,这里我直接调用了python处理,当然还有其他方法:比如:

  • 使用awksed
  • 第三方库jq
  • 调用其他脚本解析器,如pythonnodephp

最后剩下Typora上的配置,看上面的第一张图,Command里面是shell脚本的文件位置,然后可以测试了:

5860

如果看到Validation Succeed就说明上传成功了,现在当我们Command+V复制一张图片进来时,会自动将图片上传到SM.MS,真的方便了很多,写作本来就应该这么简单嘛!

至此,上面就是我今天要讲的如何使用Typora的自定义功能上传图片到sm.ms,稍微修改shell代码还能将图片上传到七牛云、阿里云、又拍云等。

文章首发:https://xydida.com/2021/5/4/Tools/custom-image-uploader-in-Typora/

本文系原创,转载请注明出处。


参考: