创建并进入项目
$ mkdir markdown-images-to-qiniu$ cd markdown-images-to-qiniu
安装七牛官方的扩展
$ composer require qiniu/PHP-sdk
实现思路很简单
● 读取 makrdown 文件
● 正则匹配出所有的图片
● 依次上传图片
● 将文章图片的地址替换为图床地址
● 保存替换后的文章
以下是具体的实现,首先在项目目录下创建脚本 index.PHP,
<?PHPrequire '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);
使用
$ PHP index.PHP test.md总结
以上是内存溢出为你收集整理的PHP脚本实现Markdown文章上传到七牛图床全部内容,希望文章能够帮你解决PHP脚本实现Markdown文章上传到七牛图床所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)