社区
Community β
今早起来发现vps的ip被墙了,😭
(多次测试发现时墙时不墙)
不过说到这个,用github+vercel+自定义域名部署博客的一个好处就是能绕过墙
之前看到有人在问怎么在手机上实现obsidian的待办提醒,有一个正在开发的项目值得关注,原理是单独开发一个配套的app,定期扫描手机本地的ob库中的文件,然后用这个app走安卓的通知
Obsidian 实现复制时自动上传图片到图床
【QuickAdd脚本】带图复制-自动上传图片到图床 – 经验分享 – Obsidian 中文论坛
我新开一个库可以用,但是在主力库里就不行,报错为
QuickAdd: (ERROR) failed to run user script 带
图复制.Error:
The “path" argument must be of type string.
Received undlefined
这个问题很奇怪,我在新开的空白ob库里没有遇见,但是在主力库就有这个问题。
怎么排查问题?
- 尝试删除js脚本后再执行命令,看看是不是脚本的问题——删除后报错找不到脚本,看来不是这个问题。
然后我想为什么空白库是对的,多半是插件或者设置的问题,然后我把脚本发给kimi,kimi分析到一个关键点,就是文件路径。
于是我发现问题了:试用的时候发现一个问题:
如果内部链接类型
设置为基于当前笔记的相对路径
,脚本会报错
QuickAdd: (ERROR) failed to run user script 带图 复制.Error: The “path" argument must be of type string. Received undefined
采用绝对路径也会有同样问题。改为尽量短路径就正常了。
用chatgpt修复这个bug(还得是chatgpt哇),修复版的脚本为:
const path = require('path');
const quickAddApi = app.plugins.plugins.quickadd.api;
const { editor, file, containerEl } = app.workspace.activeEditor;
const url = "http://127.0.0.1:36677/upload";
module.exports = async () => {
const files = app.vault.getFiles();
let selection = "";
let content = "";
selection = editor.getSelection();
console.log("Selected text:", selection);
for (let line of selection.split("n")) {
let embed = "";
if (line) {
embed = matchSelectionEmbed(line);
}
console.log("Matched embed:", embed);
if (embed && /.(png|jpg|jpeg|gif|bmp)$/.test(embed)) {
let wikiPath = getFilePath(files, embed); // 匹配Wiki链接
if (!wikiPath) {
new Notice(`❌无法找到文件: ${embed}`);
console.log(`❌无法找到文件: ${embed}`);
continue;
}
// 获取绝对路径
const imgPath = app.vault.adapter.getFullPath(wikiPath);
console.log("Image path:", imgPath);
const data = await uploadFiles([imgPath], url);
if (data.success) {
const imgWiki = `![[${embed}]]`;
const imgLink = `![${embed}](${data.result})`;
line = line.replace(imgWiki, imgLink);
} else {
new Notice(`❌上传 ${path.basename(imgPath)} 图片失败`);
console.log(`❌上传 ${path.basename(imgPath)} 图片失败`);
}
}
content += line + "n";
}
console.log("Final content:", content);
copyToClipboard(content)
new Notice(`✅复制成功`);
};
// 获取文件路径函数
function getFilePath(files, baseName) {
let matchingFiles = files.filter(f => {
const fullPath = f.path;
console.log(`Comparing ${fullPath} with ${baseName}`);
return fullPath.endsWith(baseName);
});
if (matchingFiles.length === 0) {
console.log(`No files matched for: ${baseName}`);
return undefined;
}
return matchingFiles[0].path;
}
function matchSelectionEmbed(text) {
const regex = /![[?([^]]*?)(|.*)?]]?(?([^)n]*))?/;
const matches = text.match(regex);
if (!matches) return;
if (matches[3]) return decodeURIComponent(matches[3]);
if (matches[1]) return decodeURIComponent(matches[1]);
}
async function uploadFiles(imagePathList, url) {
const response = await requestUrl({
url: url,
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify({ list: imagePathList }),
});
const data = response.json; // 直接访问 `json` 属性,而不是调用 `json()` 方法
return data;
};
function copyToClipboard(extrTexts) {
const txtArea = document.createElement('textarea');
txtArea.value = extrTexts;
document.body.appendChild(txtArea);
txtArea.select();
if (document.execCommand('copy')) {
console.log('copy to clipboard.');
} else {
console.log('fail to copy.');
}
document.body.removeChild(txtArea);
}
使用方法
- 安装插件quickadd
- 在quickadd中设置脚本存放目录
Template Folder Path
,然后在对应目录下新建带图复制.js
,把代码粘贴进去 - 新建一个宏,选择刚刚新建的脚本
- 安装piclist,配置好图床
- 在obsidian中选中要分享的文本,其中需要包含要上传的图片,然后ctrl+p使用脚本
- 粘贴即可
直接把图片上传到github
用 github publisher 插件能把图片上传到 github,但是图片在文章中的格式是 [[]]
的 wiki 链接,因此我们需要通过正则的方式来转换格式。
参考这篇文章 obsidian图片链接转换成markdown语法,不关闭wiki链接_obsidian图片显示变成链接-CSDN博客
同时上面这个方法还可以解决这个问题:obsidian 粘贴进来的图片名字会自动带空格,如 Pasted image 20240806221817.png
最后发布后就能看到在 github 是可以正常查看图片了,但是为了同步到其他平台,可以批量的在图片路径前面加上 https://github.com/dangehub/github2wp/blob/main/_posts
方法也很简单,就是搜索 assets/
,然后替换为 https://github.com/dangehub/github2wp/blob/main/_posts/assets/
- 但是为什么同步到 wordpress 的文章里图片没有了?
同步到 wp 的是 html 代码:
<p><img alt="" src="https://github.com/dangehub/github2wp/blob/main/_posts/assets/Pasted%20image%2020240806214536.png" /></p>
直接访问这个链接是对的,但是这段 html 代码不能正常工作。
比如放到 obsidian 中:
上面的分隔线中就是这段 html 代码,无法显示图像。为什么?
去调试台看了下,报错 (失败)net::ERR_BLOCKED_BY_ORB
,这是跨域问题
但是都没人说 github 的图片会限制跨域,检查之后发现 https://github.com/dangehub/github2wp/blob/b85405e3ef0c15a3caf57a038a545e0842d43996/_posts/assets/Pasted%20image%2020240806214536.png
指向的不是图片本身,https://github.com/dangehub/github2wp/blob/b85405e3ef0c15a3caf57a038a545e0842d43996/_posts/assets/Pasted%20image%2020240806214536.png?raw=true
才是图片本身,替换为这个链接就好了。
即用 png?raw=true
替换 png
突然发现微软e5开发者账号从5T变成1T了…
股市沉浮韭菜斩,
清香一缕祈平安。
红盘绿影刀起落,
再割三茬心更坚。
TAG获奖年度游戏 | 我的年度游戏 |
2014(首届) | |
龙腾世纪:审判 | – |
2015 | |
巫师3:狂猎 | – |
2016 | |
神秘海域4、Inside | |
2017 | |
塞尔达传说:旷野之息 | – |
2018 | |
荒野大镖客:救赎2 | |
2019 | |
只狼:影逝二度 | – |
2020 | |
半衰期:爱莉克斯 | |
2021 | |
双人成行 | – |
2022 | |
艾尔登法环 | – |
2023 | |
博德之门3 | – |
2024 | |
黑神话:悟空 |
TGA大部分年份还算公正,少部分时候就是个野鸡奖,权当看个乐子就行。
想过今年底会很难,没想到会这么难…
大鹏一日同风起,扶摇直上九万里。
Xbox平台摆烂,PlayStation平台萎靡,哄抬价格,也许未来装一台高显卡全固态的SteamOS主机摆客厅才是家用主机的最优解。
审计查问题可以用放大镜🔍,甚至可以用显微镜🔬。但是,千万别戴着有色眼镜👓。
生活就像这趟飞行,偶有阴云,但总能看到希望的光芒。🌅✈️
虫和鸟
故事不长,也不难讲,脸红相识,眼红散场。
不曾再你巅峰时慕名而来 也未曾在你低谷时离你而去
如果忘记你那么容易,那我爱你干嘛!
你怕不怕,这辈子就是上辈子所说的下辈子?
见或不见 亦很挂念
你在心里 亦于面前