Markdown 新解决方案:Typora+本地备份+GitHub 图床 中,我给出的 Markdown 图片管理方案是采用本地备份加上 GitHub 同步的思路;简言之,为了保证图片的安全性采用了本地存储,需要进行分享的话将其中的图片连接改为 GitHub 图床,这种方案在稳定性上表现得很好,但是操作上到底还是有些繁琐(需要手动上传图片,并运行链接替换的代码)。

疫情在家,这样的方案也十分有效,最近回了学校,重新用起了 NAS,于是参考这篇文章 http://guiu.xyz/p/ab70f304.html 【已失效】,配合 Chevereto 探索了一套新的方案;相较于之前的那种,这里的优势在于配合代码实现了图片的自动上传,因此可以直接分享;但与此同时带来的问题在于,服务依赖于图床的稳定性,由于是自用的 NAS 所以相对来说还是可以的,用了一个多月下来体验不错(域名选择的话,直接用了 Synology 免费的那个 id.synology.me 还是比较可靠的)。

【20201119 更新:目前以全面转向 MWeb,参见 MWeb 入门指南

搭建 Chevereto 图床

图床搭建的话,可以参考这一篇 https://post.smzdm.com/p/a3gvxnon/ ,没什么好多说的,我把当时参考的链接放在下面。

搭建完成之后可以收获一个支持多账号的在线图床服务,可以自行探索,我不在用也就不多说了。

注意:另外,在默认配置下基于 API 上传的图片是会保存在奇怪的账号下,可以自行设定所需要保存的用户和相册地址,官方说明见 这里;我在 MWeb 入门指南 中也给出了设置方法。

利用 Python 实现 Typora 图片上传

原始方案来自 http://guiu.xyz/p/ab70f304.html 不过网页已失效,这里 有一个备份可供参考,下面也赘述一番。

在合适的文件夹下新建一个 upload.py 文件,内容如下(记得当时好像做了一点修改,原始的可参考上面的知乎链接)

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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#!/usr/bin/env python3
# -*- encoding: utf-8 -*-
# author: guiu
# data: 2020.2.28

import requests
import json
import mimetypes
import argparse
import sys

APP_DESC = """
一个上传图片到chevereto图床的命令行工具
"""

print(APP_DESC)
if len(sys.argv) == 1:
sys.argv.append('--help')

parser = argparse.ArgumentParser()
parser.add_argument('-s', '--source', type=str, nargs='+', help="", required=True)
parser.add_argument('-c', '--config', default="./config.json", help="读取配置文件", required=True)
args = parser.parse_args()

# 从参数中获取要上传的文件列表
img_list = args.source
# print(img_list)

def read_conf(path):
with open(path,"r",encoding="utf-8") as f:
confstr = f.read()
conf = json.loads(confstr)
return conf

def up_to_chevereto(img_list):
# 获得本地图片路径后,上传至图床并记录返回的json字段
for img in img_list:
# 先判断传过来的是本地路径还是远程图片地址
if "http" == img[:4]:
# 非本地图片的话可以考虑下载到本地再上传,但是没这个必要
print(img)
continue
else:
try:
res_json = upload(formatSource(img))
parse_response_url(res_json,img)
except:
print(img+"\t上传失败")

def upload(files):
# 图床api
# APIKey = "THERE PUT YOUR APIKEY"
conf = read_conf(args.config)
url = conf['url'] + "?key=" + conf['APIKEY']
r = requests.post(url, files=files)
return json.loads(r.text)

def formatSource(filename):
imageList = []
mime_type = mimetypes.guess_type(filename)[0]
imageList.append(
('source', (filename, open(filename, 'rb'), mime_type))
)
#print (imageList)
return imageList

def parse_response_url(json, img_path):
# 从返回的json中解析字段
if json['status_code'] != 200:
print("{}\tweb端返回失败,可能是APIKey不对. status_code {} .".format(
img_path, json['status_code'])
)
else:
img_url = json["image"]["url"]
print(img_url)

up_to_chevereto(img_list)

可以看到需要调用 Chevereto 的 APIKEY。需要在 Chevereto 的 仪表板-设置 中,在设置旁边的下列菜单中选择 API ,即可找到 key,默认有一个也可以自定义。

新建一个 config.json 保存配置

1
2
3
4
{
"APIKEY": "YOUR API KEY",
"url": "http://your_website/api/1/upload/"
}

注意将其中的 key 值和网址做相应的替换。

Typora 中进行相应设置

在图片部分选择插入后自动上传;在图片上传设置中的代码如下。下面是我的配置,注意在使用的时候,将 Python 地址、代码地址、配置文件地址作相应的替换。

1
~/miniconda3/bin/python ~/SynologyDrive/Markdown/upload.py -c ~/SynologyDrive/Markdown/config.json -s

不知道为什么直接用 python 不可以,只好写了个全地址,上传的速度还是可以的。