搭建图床服务

这里利用CloudFlare搭建免费的图床服务

cf-image-hosting

部署Pages

$ git clone https://github.com/ifyour/cf-image-hosting.git
$ cd cf-image-hosting
$ npm install && npm run deploy

部署成功后会显示如下信息

设置自定义域名

点击左侧Workers和Pages ,选择cf-image-hosting

设置自定义域成功后则能在部署概览看到自定义的域名

点击自定义域名后则能跳转到具体的上传图片页面

至此,免费的图床服务搭建成功。

Typora自定义脚本上传图片

目前只在mac上做了验证。

官方文档说明

官方文档对自定义脚本有如下说明:

Typora自定义脚本

You could config a custom command to upload images, using tools that is not listed in above options, or even write your own tools / scripts. Typora will append all images that needs to be uploaded after the custom command you filled.

您可以使用上述选项中未列出的工具,甚至编写自己的工具/脚本,配置自定义命令来上传图片。Typora 会在你填写的自定义命令后追加所有需要上传的图片。

Then, Typora will fetch image urls from the last N lines of the standard output of your custom command. (N is the number of images to upload).

然后,Typora 会从自定义命令标准输出的最后 N 行中获取图片网址。(N 是要上传的图片数量)。

For example, if you write a tool upload-image.sh, then you can input [some path]/upload-image.sh in the command filed. Typora will call [some path]/upload-image.sh "image-path-1" "image-path-2" to upload two images located in image-path-1 and image-path-2. Then the command may return something like:

例如,如果你编写了一个工具 upload-image.sh ,那么你可以在命令文件中输入 [some path]/upload-image.sh 。Typora 将调用 [some path]/upload-image.sh "image-path-1" "image-path-2" 来上传位于 image-path-1image-path-2 中的两张图片。然后,命令可能会返回如下内容

Upload Success:
http://remote-image-1.png
http://remote-image-2.png

Then Typora will get the two remote image url from the output, and replace the original local images used in the Markdown document.

然后,Typora 将从输出中获取两个远程图片 url,并替换 Markdown 文档中使用的原始本地图片。

You could click the “Test Uploader” button to verify your custom commands.

您可以点击 "测试上传程序 "按钮来验证您的自定义命令。

编写脚本

  1. 赋予脚本执行权限:保存脚本后,需要给脚本赋予执行权限。在终端运行以下命令:

    chmod +x upload_image.sh
  2. 运行脚本:在终端中运行脚本,并传递多个图片路径作为参数。例如:

    ./upload_image.sh path/to/your/image1.jpg path/to/your/image2.jpg
脚本说明:
  1. 参数检查:检查是否传递了至少一个图片路径参数。如果没有传递参数,则打印用法信息并退出。
  2. 迭代处理每个图片文件:对每个传递的图片路径参数进行迭代处理。
  3. 文件检查:检查每个图片文件是否存在。如果文件不存在,则打印错误信息并继续处理下一个文件。
  4. 上传图片:使用curl命令将每个图片文件作为file参数上传到指定的API,并将响应存储在RESPONSE变量中。
  5. 解析响应:使用jq命令解析JSON响应并提取所有src参数的内容。如果jq解析失败,则打印错误信息并继续处理下一个文件。
  6. 打印结果:逐个打印成功上传后的每个src参数内容,即每张图片的URL。

这个脚本会处理每个传递的图片文件,上传后解析并打印每个图片的URL。对于每个图片,如果上传失败或解析失败,会打印相应的错误信息,并继续处理下一个图片文件。

脚本内容:
#!/bin/bash

# 自定义URL部分
base_url="https://img.itweeks.xyz" # 检查是否安装了jq
if ! command -v jq &>/dev/null; then
echo "Error: jq is not installed. Please install jq before running this script. "
echo "You can install jq using the following command:"
echo "brew install jq [macOS]"
exit 1
fi # 用于存储图片URL的数组
image_urls=() # 循环读取参数
for file_path in "$@"; do
# 发送上传图片请求,关闭curl输出
response=$(curl --location --request POST "${base_url}/upload" \
--header 'User-Agent: Apifox/1.0.0 (https://apifox.com)' \
--form "file=@\"${file_path}\"" \
--silent) # 添加 --silent 选项以关闭输出 # 检查请求是否成功
if [ $? -eq 0 ]; then
# 解析返回的JSON并拼接图片URL
img_url="${base_url}$(echo "$response" | jq -r '.[0].src')" # 存储图片URL到数组
image_urls+=("${img_url}")
else
# 请求失败,输出错误信息并退出脚本
echo "Upload Failed"
exit 1
fi
done # 所有请求成功后输出成功信息
echo "Upload Success" # 输出所有图片URL
for url in "${image_urls[@]}"; do
echo "${url}"
done
调用示例:
~/soft /Users/mulyzhou/soft/upload-image.sh "/Applications/Typora.app/Contents/Resources/TypeMark/assets/icon/icon_512x512.png" "/Applications/Typora.app/Contents/Resources/TypeMark/assets/icon/icon_256x256.png"
https://image.itweeks.xyz/file/213fb10821a7758807733.png
https://image.itweeks.xyz/file/78332611766cef414f192.png

https://image.itweeks.xyz/file/213fb10821a7758807733.png

https://image.itweeks.xyz/file/78332611766cef414f192.png

这两行输出即是上传成功后回显图片的地址,一定要这样直接输出,中间不能输出别的信息,不然typora无法解析

Typora配置脚本

点击设置 - 图像 - 上传服务选择自定义命令 - 命令选择脚本路径 如/Users/mulyzhou/soft/upload-image.sh

点击验证图片上传选项

显示验证成功后则代表配置成功。

使用Telegraph-Image

使用上述方式部署后发现无法查看图片上传历史记录,这里采用另外一种部署方式。

Telegraph-Image

手把手教程

简单 3 步,即可部署本项目,拥有自己的图床

1.Fork 本仓库 (注意:必须使用 Git 或者 Wrangler 命令行工具部署后才能正常使用,文档)

2.打开 Cloudflare Dashboard,进入 Pages 管理页面,选择创建项目,选择连接到 Git 提供程序

  1. 按照页面提示输入项目名称,选择需要连接的 git 仓库,点击部署站点即可完成部署

特性

1.无限图片储存数量,你可以上传不限数量的图片

2.无需购买服务器,托管于 Cloudflare 的网络上,当使用量不超过 Cloudflare 的免费额度时,完全免费

3.无需购买域名,可以使用 Cloudflare Pages 提供的*.pages.dev的免费二级域名,同时也支持绑定自定义域名

4.支持图片审查 API,可根据需要开启,开启后不良图片将自动屏蔽,不再加载

5.支持后台图片管理,可以对上传的图片进行在线预览,添加白名单,黑名单等操作

绑定自定义域名

在 pages 的自定义域里面,绑定 cloudflare 中存在的域名,在 cloudflare 托管的域名,自动会修改 dns 记录

开启图片审查

1.请前往https://moderatecontent.com/ 注册并获得一个免费的用于审查图像内容的 API key

2.打开 Cloudflare Pages 的管理页面,依次点击设置环境变量添加环境变量

3.添加一个变量名称ModerateContentApiKey为你刚刚第一步获得的API key,点击保存即可

注意:由于所做的更改将在下次部署时生效,你或许还需要进入部署页面,重新部署一下该本项目

开启图片审查后,因为审查需要时间,首次的图片加载将会变得缓慢,之后的图片加载由于存在缓存,并不会受到影响

设置图片管理功能

1、支持图片管理功能,默认是关闭的,如需开启请部署完成后前往后台依次点击设置->函数->KV 命名空间绑定->编辑绑定->变量名称填写:img_url KV 命名空间 选择你提前创建好的 KV 储存空间,开启后访问 http(s)/你的域名/admin 即可打开后台管理页面

变量名称 KV 命名空间
img_url 选择提前创建好的 KV 储存空间

2、后台管理页面新增登录验证功能,默认也是关闭的,如需开启请部署完成后前往后台依次点击设置->环境变量->为生产环境定义变量->编辑变量 添加如下表格所示的变量即可开启登录验证

变量名称
BASIC_USER = <后台管理页面登录用户名称>
BASIC_PASS = <后台管理页面登录用户密码>

当然你也可以不设置这两个值,这样访问后台管理页面时将无需验证,直接跳过登录步骤,这一设计使得你可以结合 Cloudflare Access 进行使用,实现支持邮件验证码登录,Microsoft 账户登录,Github 账户登录等功能,能够与你域名上原有的登录方式所集成,无需再次记忆多一组后台的账号密码,添加 Cloudflare Access 的方式请参考官方文档,注意需要保护路径包括/admin 以及 /api/manage/*

Typora设置自定义脚本上传图片的更多相关文章

  1. linux设置 自定义脚本开机启动

    本文原创,转载请标明出处 https://blog.csdn.net/qq2531246791/article/details/89036084 一. 赋予可执行权限 chmod +x /etc/rc ...

  2. C#如何在DataGridViewCell中自定义脚本编辑器

    上一篇博文探讨了如何自定义DataGridViewColumn实现一个TreeViewColumn来在DataGridView控件中显示TreeView控件,其实我们还可以继续发挥想象,自定义其他的列 ...

  3. SharePoint 2013 设置自定义布局页

    在SharePoint中,我们经常需要自定义登陆页面.错误页面.拒绝访问等:不知道大家如何操作,以前自己经常在原来页面改或者跳转,其实SharePoint为我们提供了PowerShell命令,来修改这 ...

  4. ArcMap自定义脚本工具制作

    原文 ArcMap自定义脚本工具制作 在制图的前期,一般需要做一些数据的整理,如图层合并.裁剪等工作.虽然在ArcMap中也有提供对应的工具,但使用起来需要点技巧.如批量裁剪,虽然可以实现,但出来的结 ...

  5. 在nagios中使用nrpe自定义脚本

    nrpe的安装    tar xvfz nrpe-2.13.tar.gz cd nrpe-2.13 ./configure make all make install-plugin make inst ...

  6. [系统集成] RT(Request Tracker)执行自定义脚本及发送微信、短信的实现方法

    RT(Request Tracker)是一个基于 Perl 语言的开源状态跟踪和工作流系统,支持审批.权限管理等功能,中文化支持的也不错,可以作为企业的流程审批系统使用.可惜的是,该系统在国内使用的不 ...

  7. 关于自定义脚本rc.local里开机不启动的问题--以tomcat和perl相关的脚本为例

    本文将自己遇到的一些自定义脚本加入开机启动项却不成功的问题加以说明,花费了我很长时间才得以解决,当然也多谢了自己朋友的帮忙,正是因为他们的提醒,最后才找到了解决的办法,谢谢他们!!!! 系统是cent ...

  8. 适用于 Windows 的自定义脚本扩展

    自定义脚本扩展在 Azure 虚拟机上下载并执行脚本. 此扩展适用于部署后配置.软件安装或其他任何配置/管理任务. 可以从 Azure 存储或 GitHub 下载脚本,或者在扩展运行时将脚本提供给 A ...

  9. DD-WRT自定义脚本更新花生壳DDNS

    N年以前买了一个tp-link 841n v7,一直用的还算可以吧,除了不定期重启路由器,不然网速慢的龟爬啊!这也是TP原厂固件的通病,于是刷了DD-WRT,话说DD确实很爽,除了功能强大之外,而且很 ...

  10. xmake从入门到精通12:通过自定义脚本实现更灵活地配置

    xmake是一个基于Lua的轻量级现代化c/c++的项目构建工具,主要特点是:语法简单易上手,提供更加可读的项目维护,实现跨平台行为一致的构建体验. 本文主要详细讲解下,如何通过添加自定义的脚本,在脚 ...

随机推荐

  1. Squid设置用户名密码

    在ubutnu上设置squid代理认证 为了在Ubuntu上设置Squid代理身份验证,您需要对Squid配置文件进行以下一些调整: 生成Squid代理身份验证密码 htpasswd是两种可用于生成代 ...

  2. awk 处理 Git 提交信息生成 Release Note

    发布软件时通常都会写 Release Note,但每次从头手打也有点累,可以考虑从 Git 的提交历史中自动生成. Git 提交信息一般是三段式结构,段落之间使用空行隔开: <subject&g ...

  3. pikachu 基于表单的暴力破解(一)

    Burte Force(暴力破解)概述 "暴力破解"是一攻击具手段,在web攻击中,一般会使用这种手段对应用系统的认证信息进行获取. 其过程就是使* 用大量的认证信息在认证接口进行 ...

  4. 轻量级网络-CSPNet 论文解读

    摘要 1,介绍 2,相关工作 3,改进方法 3.1,Cross Stage Partial Network 3.2,Exact Fusion Model 4,实验 4.1,实验细节 4.2,消融实验 ...

  5. 2-3 C++复合类型

    目录 2.3.1 引用(References) 2.3.2 指针(Pointers) 关于指针 指针操作 其它事项 空指针的三种表示 void* 指针 易混淆的符号 指针的值(地址)的四种状态 对比与 ...

  6. LeetCode128 最长连续序列

    最长连续序列 题目链接:LeetCode128 描述 给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度. 请你设计并实现时间复杂度为 O(n) 的算法 ...

  7. (1) Pytorch深度学习—数值处理

    (1)Pytorch--数值处理 参考于李沐"动手学深度学习"系列以及网上各路大佬的博客资料,感谢大家的分享,如错改,如侵删. torch中的数值处理 数值处理是深度学习中极其重要 ...

  8. windows下git安装以及基本使用

    Git的基本使用 Windows下Git的基本使用与操作 安装Git 这个是一个git的windows系统的命令行版本 https://git-scm.com/downloads 安装 tortois ...

  9. 手搓党分享:用Air700E开发板+毫米波雷达,搓一个睡眠监测仪!

    ​ 只能说,看到这个大佬分享的睡眠监测仪,手上的手环瞬间不香了... 用Air700E开发板+毫米波雷达,手搓一个开箱即用的睡眠监测仪,不花冤枉钱! 一.项目原理及硬件制作 毫米波是指频率范围从30- ...

  10. 【FAQ】Harmo【FAQ】HarmonyOS SDK 闭源开放能力 — 公共模块

    1.问题描述: 文档哪里能找到所有的权限查看该权限是用户级的还是系统级的. 解决方案: 您好,可以看一下下方链接是否可以解决问题: https://developer.huawei.com/consu ...