在使用 Markdown 编写文章之后,经常需要发布到不同的平台,这里会遇到一个问题,文章的图片需要手动的进行上传,管理起来非常不方便,因此,强烈建议将图片统一上传到图床中,这样的话一篇文章就可以轻松的同步到各大平台上面了。下面,用 PHP 来实现该功能,选用 七牛云 作为图床
创建并进入项目
1
2
3
|
$ mkdir markdown-images-to-qiniu
$ cd markdown-images-to-qiniu
|
安装七牛官方的扩展
1
|
$ composer require qiniu/php-sdk
|
实现思路很简单
● 读取 makrdown 文件
● 正则匹配出所有的图片
● 依次上传图片
● 将文章图片的地址替换为图床地址
● 保存替换后的文章
以下是具体的实现,首先在项目目录下创建脚本 index.php,
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
<?php
require 'vendor/autoload.php' ;
use Qiniu\Auth;
use Qiniu\Storage\UploadManager;
// 1. 读取 `makrdown` 文件
$file = $argv [1];
if (! file_exists ( $file ) ){
return "找不到文件{$file}" ;
}
$orginalContent = file_get_contents ( $file );
// 2. 正则匹配出所有的图片
preg_match_all(
'/\!\[.*\]\(.+\)/' ,
$orginalContent ,
$matches ,
PREG_PATTERN_ORDER
);
$mdImageArr = $matches [0];
if (! count ( $mdImageArr ) ){
return "无需上传图片" ;
}
// 3. 依次上传图片
$accessKey = '你的 AccessKey' ;
$secretKey = '你的 SecretKey' ;
$bucket = '你的七牛空间名' ; // eg. mindgeek
$url = "空间所绑定的域名" ; // eg. http://qiniu.site.com
$auth = new Auth( $accessKey , $secretKey );
$token = $auth ->uploadToken( $bucket );
$uploadMgr = new UploadManager();
$content = $orginalContent ;
foreach ( $mdImageArr as $image ) {
$start = mb_strpos( $image , '](' ) + 2;
$localPath = mb_substr( $image , $start , -1);
$extension = pathinfo ( $localPath )[ 'extension' ];
$uploadPath = uniqid(). "." . $extension ;
list( $ret , $error ) = $uploadMgr ->putFile( $token , $uploadPath , $localPath );
if (! $error ){
// 4. 将文章图片的地址替换为图床地址
$content = str_replace ( $localPath , $url . $uploadPath , $content );
echo "{$uploadPath} 上传成功。\n" ;
} else {
echo "{$uploadPath} 上传失败。\n" ;
}
}
// 5. 保存替换后的文章
file_put_contents ( $file , $content );
|
使用
1
|
$ php index.php test.md
|
以上就是PHP脚本实现Markdown文章上传到七牛图床的详细内容,如果大家还有任何补充的内容可以联系服务器之家小编。
原文链接:https://www.php.cn/php-weizijiaocheng-442418.html