Skip to content

Obsidian 图床插件开发

b站视频

视频

本插件代码已开源

Github

下载模板

https://github.com/obsidianmd/obsidian-sample-plugin

Pasted image 20241220155042.png

在你仓库的文件夹下的 .obsidian 下新建文件夹 plugins , 下载自己的复制的模板项目

git clone https://github.com/bobostudio/imgur.git

执行 npm install && npm run dev

开启插件

Pasted image 20241220160133.png

设置项目

修改 manifest.json, 修正你自己插件的名称,ID,版本,描述,作者,作者链接,资金链接,是否桌面插件

json
{

    "id": "bobostudio-obsidian-imgur",

    "name": "Obsidian Imgur Plugin",

    "version": "1.0.0",

    "minAppVersion": "0.15.0",

    "description": "Upload images to Imgur from Obsidian.",

    "author": "bobostudio",

    "authorUrl": "https://github.com/bobostudio",

    "fundingUrl": "https://github.com/bobostudio",

    "isDesktopOnly": false

}

重启 obsidian 可以看到插件信息已更新

Pasted image 20241220161535.png

修改 main.ts

更换 MyPluginImgurPlugin

修改 onload 方法, 添加自己的插件逻辑

typescript
async onload() {
        await this.loadSettings();
        // This creates an icon in the left ribbon.
        const ribbonIconEl = this.addRibbonIcon(
            "dice",
            "Sample Plugin",
            (evt: MouseEvent) => {
                // Called when the user clicks the icon.
                new Notice("你的图床插件已启动!");
            }
        );
// 其他保持不变

重启 obsidian ,点击左边栏的骰子,可以看到插件已启动

Pasted image 20241220162606.png

添加自己的插件逻辑, 我这里使用腾讯云COS上传图片的主要代码

js
const filePath = 'temp-file-to-upload'; // 本地文件路径
cos.uploadFile({
    Bucket: 'examplebucket-1250000000', // 填入您自己的存储桶,必须字段
    Region: 'COS_REGION',  // 存储桶所在地域,例如 ap-beijing,必须字段
    Key: '1.jpg',  // 存储在桶里的对象键(例如1.jpg,a/b/test.txt),必须字段
    FilePath: filePath,                // 必须
    SliceSize: 1024 * 1024 * 5,     // 触发分块上传的阈值,超过5MB使用分块上传,非必须
    onTaskReady: function(taskId) {                   // 非必须
        console.log(taskId);
    },
    onProgress: function (progressData) {           // 非必须
        console.log(JSON.stringify(progressData));
    },
    // 支持自定义headers 非必须
    Headers: {
      'x-cos-meta-test': 123
    },
}, function(err, data) {
    if (err) {
      console.log('上传失败', err);
    } else {
      console.log('上传成功', data);
    }
});

开发注意事项

  1. 插件开发过程中需要提前运行 npm run dev,并且在修改代码后需要重新关闭后开启 让插件更新

  2. 查看 console.log , 在 obsidian 按快捷键 Ctrl+Shift+I

  3. 出现跨域问题,在桶列表的安全管理添加跨域访问 CORS 设置, app://obsidian.md

1734759312517-image.png

  1. 上传图片后无法访问图片地址需要去桶列表存储桶访问权限改为 公有读私有写

1734759639207-image.png

  1. 提交代码到自己的 Github 仓库,需要打包发布 Releases ,上传主要文件 main.jsmanifest.json

  2. 移除模板不必要的代码,Sample 开头的方法需要改成自己插件名称,不需要就去除,减少不必要的console.log

  3. 删除文件需要使用 app.fileManager.trashFile(),确保文件按照用户的偏好设置被删除

  4. 提交 PR 前,需要到 [community-plugins.json](Editing obsidian-releases/community-plugins.json at master · obsidianmd/obsidian-releases) 更新你的插件信息,必须与插件的 Github Releases 配置文件 manifest.json ID 与版本一致, 不要出现Obsidian,Plugins 等字样,不然提交 pr 不通过

json
  1. 最后坐等 Obsidian 官网审核

本文采用 署名-非商业性使用 4.0 国际 (CC BY-NC 4.0) 进行许可。

转载请注明出处:Obsidian 图床插件开发