【NAS】搭建 Chevereto 图床 & Typora 上传指南

【NAS】搭建 Chevereto 图床 & Typora 上传指南

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

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

搭建 Chevereto 图床

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

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

利用 Python 实现 Typora 图片上传

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

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

#!/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 保存配置

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

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

Typora 中进行相应设置

配置如下

image-20200917091935002

其中的上传代码为,下面是我的配置,注意在使用的时候,将 Python 地址、代码地址、配置文件地址作相应的替换。

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

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

posted @ 2020-10-26 12:39  Easonshi  阅读(1573)  评论(0编辑  收藏  举报