Typora--终于找到一个能够解决将csdn文章同步到hexo的完美编辑器(解决csdn图片防盗链导致无法直接复制文章的问题)。
个人博客:https://mmmmmm.me
源码:https://github.com/dataiyangu/dataiyangu.github.io
需求
- 能够将csdn的文章同步到自己的hexo博客(csdn有图片防盗链)
- 图片保存到本地文件夹(上传到云空间容易丢失)
- 最简便的操作
背景
之前用过hexo-admin,代码区和预览不同步,而且因为csdn的防盗链,所以只能从csdn复制,然后粘贴过去;hexoEditor(github)文件的名字必须和文章的名字一样,因为我的gitalk是根据文件名字创建issus的,中文会导致报错;mweb(用的最久)相对方便多了,直接将csdn文章粘贴过去,可是图片有外链,通过从csdn拖动图片到指定位置,方便了一点点。
新宠
告诉我,我的名字叫什么?大声点我听不见~
Typora
页面
我的是mac版:

具体相关下载安装以及操作的说明略。
神奇之处
看得见的优点
用md的语法写完回车,实时预览,而不是像其他一样左右分开的。
如何设置项目根目录
注意上图最上面
typora-root-url: ../../source
这个的意思是设置根目录,不然下面的图片是看不到的。
设置方法:编辑–》图片设置–》设置图片根目录
文章发布的时候这行要去掉,否则格式有问题
如何显示图片?
快捷键command+,打开设置–》编辑器–》复制到指定路径–》填写路径为images–》设置:
对本地位置的图片应用上述规则
对网络位置的图片应用上述规则
优先使用相对路径
这三项打上勾

这里能够将csdn中的图片直接粘贴过去就是图中红圈中能够完美实现这个功能。
然后由于优先使用相对路径,即这里将source作为根路径,所以相对路径就是/images/xxxxx.png
2019-03-12更正:这里一定要设置相对路径
于是最终操作流程
option+command+3 选择打开文件-》打开_posts文件-》新建一个文件
- 编辑–》图片设置–》设置图片根目录(source)(因为需要根据根目录自动写出来下载图片到哪个路径)
出现
---
typora-root-url: ../../source
---
当然直接将这句话添加在头部应该也可以
2019-03-12更正:第一点的上面这部分不需要,因为上面图中设置优先使用相对路径,这句话已经没有用了
然后粘贴hexo文章头部信息(作者、分类、时间等 注意在粘贴的时候一定要切换成源代码模式,快捷键command+/ )因为其中有“-”符号,导致自己的data和catagory会自动table,具体报错信息文章末尾给出
- 直接将csdn文章粘贴过去(不用处理图片哦, 一定不要是源代码模式,否则无法自动下载图片 )
- 将根目录那句话删掉(否则hexo无法将md解析为html,格式错误), 当然,删除这句话,在Typora中图片无法显示可是在浏览器中打开是正常的,希望在Typora中阅读,当然可以载把这句话加上即可
---
typora-root-url: ../../source
---
2019-03-12更正:不加这句话也可以,因为上面图中设置优先使用相对路径,这句话已经没有用了,把图片全部设置成相对路径就可以载这个软件中看自己的文章了。
4. 在编辑器的上面修改文件名称和路径(_posts)
5. 完成
如果在粘贴hexo头部的时候不切换成源代码模式会报错如下:
ERROR Process failed: _posts/2019-03-03-1.md
YAMLException: bad indentation of a sequence entry at line 7, column 13:
categories:
^
at generateError (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:165:10)
at throwError (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:171:9)
at readBlockSequence (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:935:7)
at composeNode (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1363:45)
at readBlockMapping (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1062:11)
at composeNode (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1332:12)
at readDocument (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1492:3)
at loadDocuments (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1548:5)
at Object.load (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1569:19)
at parseYAML (/Users/leesin/Desktop/blog/node_modules/hexo-front-matter/lib/front_matter.js:80:21)
at parse (/Users/leesin/Desktop/blog/node_modules/hexo-front-matter/lib/front_matter.js:56:12)
at Promise.all.spread (/Users/leesin/Desktop/blog/node_modules/hexo/lib/plugins/processor/post.js:52:20)
at tryCatcher (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/util.js:16:23)
at Promise._settlePromiseFromHandler (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:509:35)
at Promise._settlePromise (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:569:18)
at Promise._settlePromise0 (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:614:10)
at Promise._settlePromises (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:694:18)
at Promise._fulfill (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:638:18)
at PromiseArray._resolve (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise_array.js:126:19)
at PromiseArray._promiseFulfilled (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise_array.js:144:14)
at PromiseArray._iterate (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise_array.js:114:31)
at PromiseArray.init [as _init] (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise_array.js:78:10)
ERROR Process failed: _posts/2019-03-03-1.md
YAMLException: bad indentation of a sequence entry at line 7, column 13:
categories:
^
at generateError (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:165:10)
at throwError (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:171:9)
at readBlockSequence (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:935:7)
at composeNode (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1363:45)
at readBlockMapping (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1062:11)
at composeNode (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1332:12)
at readDocument (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1492:3)
at loadDocuments (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1548:5)
at Object.load (/Users/leesin/Desktop/blog/node_modules/js-yaml/lib/js-yaml/loader.js:1569:19)
at parseYAML (/Users/leesin/Desktop/blog/node_modules/hexo-front-matter/lib/front_matter.js:80:21)
at parse (/Users/leesin/Desktop/blog/node_modules/hexo-front-matter/lib/front_matter.js:56:12)
at Promise.all.spread (/Users/leesin/Desktop/blog/node_modules/hexo/lib/plugins/processor/post.js:52:20)
at tryCatcher (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/util.js:16:23)
at Promise._settlePromiseFromHandler (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:509:35)
at Promise._settlePromise (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:569:18)
at Promise._settlePromise0 (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:614:10)
at Promise._settlePromises (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:694:18)
at Promise._fulfill (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise.js:638:18)
at PromiseArray._resolve (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise_array.js:126:19)
at PromiseArray._promiseFulfilled (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise_array.js:144:14)
at PromiseArray._iterate (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise_array.js:114:31)
at PromiseArray.init [as _init] (/Users/leesin/Desktop/blog/node_modules/bluebird/js/release/promise_array.js:78:10)
Typora--终于找到一个能够解决将csdn文章同步到hexo的完美编辑器(解决csdn图片防盗链导致无法直接复制文章的问题)。的更多相关文章
- php解决微信文章图片防盗链
解决微信文章图片防盗链 function actionWechatImg() { header('Content-type: image/jpg'); $url = $_GET['url']; $re ...
- Python爬取mn52网站美女图片以及图片防盗链的解决方法
防盗链原理 http标准协议中有专门的字段记录referer 一来可以追溯上一个入站地址是什么 二来对于资源文件,可以跟踪到包含显示他的网页地址是什么 因此所有防盗链方法都是基于这个Referer字段 ...
- ASCII,Unicode和UTF-8终于找到一个能完全搞清楚的文章了
前言 平时喜欢写东西,看博客,一直对编码有些懵,今天下午也不知道看到了什么,突然想了解下,就找到了这个文章,看完真的豁然开朗,这个必须留下来做纪念. 点击打开链接 1.ASCII 我们知道,计算机内部 ...
- (6)妈的终于找到能用的nehe sdk了
在网上下载了有十多个,终于找到一个能用的了 下面是下载地址: http://download.csdn.net/detail/jason_bourn/681620#comment 泪奔啊~
- Java:终于找到了在alloy中的JFileChooser中的弹出式菜单不显示文字的解决办法
alloy界面可以说是我写过的最漂亮的一种JAVA界面. 可惜不知为什么,至从几年前推出1.4版后,就再也没有更新了. 随着java版本的升级,一直很担心alloy有一天不再适用于java的最新版. ...
- 【转载】“error LNK1169: 找到一个或多个多重定义的符号”的解决方法
c++的小细节的地方 原文地址:https://blog.csdn.net/xiaosu123/article/details/5665729 问题描述如下: 有 三个源文件,A.h.B.cpp.C. ...
- “error LNK1169: 找到一个或多个多重定义的符号”的解决方法(转载)
解决方案: “error LNK1169: 找到一个或多个多重定义的符号”的解决方法(转载) 遇到的问题: 在.h头文件中采用namespace 命名空间报错 test.h namespace LMR ...
- error LNK1169 找到一个或多个多重定义的符号的解决方法
问题描述如下: 有 三个源文件,A.h.B.cpp.C.cpp. A.h是头文件,其中声明了三个变量a1.a2. a3. B.cpp是A.h中所声明的类的实现源代码,C.cpp是主程序文件.B.cpp ...
- 转载:“error LNK1169: 找到一个或多个多重定义的符号”的解决方法
转载来自:http://www.cnblogs.com/A-Song/archive/2012/03/23/2413782.html 问题描述如下: 有 三个源文件,A.h.B.cpp.C.cpp. ...
随机推荐
- Java中链接MS SQL 数据库用法详解
一.第一种方法: 使用JDBC-ODBC的桥方式 JDBC-ODBC桥连接器是用JdbcOdbc.class 和一个用于访问ODBC驱动程序的本地库实现的,对于Windows平台,该本地库是一个动态链 ...
- JCF——工具类
- ac自动机暴力跳fail匹配——hdu5880
很简单的题,ac自动机里再维护一个len表示每个状态的串长,用s去query时每到一个结点都要暴力跳fail,因为有可能这个结点不是,但是其fail是危险结点,找到一个就直接break 再用个差分数组 ...
- DNS域名服务器的搭建
父域的DNS(svr7): 可以解析父域名下保存的域名地址,即解析.tedu.cn下的域名 一.安装软件包bind.bind-chroot bind是DNS解析服务需要用到的服务软件包,bind- ...
- 用 Windows Live Writer 和 SyntaxHighlighter 插件写高亮代码
博客园内置支持SyntaxHighlighter代码着色,代码着色语法:<pre class='brush:编程语言'>代码</pre>. 需要注意的是:如何你使用Syntax ...
- Go 方法、接口
在 Go 中,类型可以定义接收此类型的函数,即方法.每个类型都有接口,意味着对那个类型定义了方法集合. 下面定义了结构体类型 S 以及它的两个方法: type S struct { i int ...
- Java-Class-@I:org.springframework.web.bind.annotation.PostMapping
ylbtech-Java-Class-@I:org.springframework.web.bind.annotation.PostMapping 1.返回顶部 2.返回顶部 1. package ...
- 树莓派安装raspbian
需要准备 Win32DiskImager-v0.6 2016-09-23-raspbian-jessie.img 右键管理员打开Win32DiskImager 选择上面的img文件,选择存储卡盘符,点 ...
- webogic基本使用
文章目录 启动 注入 部署应用: 访问 启动 /root/Oracle/Middleware/user_projects/domains/weblogic/bin/startWebLogic.sh 上 ...
- JUC源码分析-集合篇(八)DelayQueue
JUC源码分析-集合篇(八)DelayQueue DelayQueue 是一个支持延时获取元素的无界阻塞队列.队列使用 PriorityQueue 来实现. 队列中的元素必须实现 Delayed 接口 ...