在使用 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