侧边栏壁纸
博主头像
落叶人生博主等级

走进秋风,寻找秋天的落叶

  • 累计撰写 130562 篇文章
  • 累计创建 28 个标签
  • 累计收到 9 条评论
标签搜索

目 录CONTENT

文章目录

ThinkPHP5+UEditor图片上传到阿里云对象存储OSS功能示例

2022-07-07 星期四 / 0 评论 / 0 点赞 / 39 阅读 / 5434 字

本文实例讲述了ThinkPHP5+UEditor图片上传到阿里云对象存储OSS。分享给大家供大家参考,具体如下:ThinkPHP5使用富文本UEditor,将富文本编辑框内上传在本地的图片,修改到阿里云对象存储OSSTh

本文实例讲述了ThinkPHP5+UEditor图片上传到阿里云对象存储OSS。分享给大家供大家参考,具体如下:

ThinkPHP5使用富文本UEditor,将富文本编辑框内上传在本地的图片,修改到阿里云对象存储OSS

ThinkPHP5加载UEditor ···· 略

UEditor下载:https://ueditor.baidu.com/website/download.html

(或本站下载:https://www.jb51.net/codes/56667.html

阿里云对象存储SDK下载:https://github.com/aliyun/aliyun-oss-php-sdk

一、配置项

ueditor目录:/public/static/admin/lib/ueditor/1.4.3
OSS配置文件目录:/application/config/oos.php
OSS SDK目录:/extend/oos

二、代码

1、OSS配置文件

.
<?phpreturn [  'endpoint' => 'xxxx',  'accessKeyId' => 'xxxxxxxxxxx',  'accessKeySecret' => 'xxxxxxxxxxxxxxxxxxxxxxxxxx',  'bucket' => 'xxxxx',  'uploadurl' => 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', //个人配置用,上传图片访问头部完整链接];
.

2、在UEditor下写入Oos.class.php控制器

*注:本人用的是相对路径,请自行对照自己的目录结构替换掉文件引入地址

.
<?phprequire_once realpath(dirname(__FILE__) . '/../../../../../../../') . '/extend/oos/autoload.php';use OSS/OssClient;use OSS/Core/OssException;class Oos{  protected $oos = null;  protected $bucket = null;  //获取OOS客户端  protected function getOssClient(){    if($this->oos === null){      $config = require realpath(dirname(__FILE__) . '/../../../../../../../') .'/application/config/oos.php';      $this->bucket = $config['bucket'];      try {        $this->oos = new OssClient($config['accessKeyId'], $config['accessKeySecret'], $config['endpoint'], false);      } catch (OssException $e) {        printf(__FUNCTION__ . "creating OssClient instance: FAILED/n");        printf($e->getMessage() . "/n");        return null;      }    }    return $this->oos;  }  //上传  public function upload($file,$save){    $config = require realpath(dirname(__FILE__) . '/../../../../../../../') .'/application/config/oos.php';    $save = 'upload/'.$save;    $ossClient = $this->getOssClient();    if (is_null($ossClient)) exit('链接存储失败');    $result = $ossClient->uploadFile($this->bucket, $save, $file);    return !empty($result['x-oss-request-id']);  }}
.

3、修改UEditor 上传图片的PHP文件/public/static/admin/lib/ueditor/1.4.3/php/action_crawler.php

.
<?php/** * 抓取远程图片 * User: Jinqn * Date: 14-04-14 * Time: 下午19:18 */set_time_limit(0);include("Uploader.class.php");include("Oos.class.php");// 引入oss对象$oos_config = require realpath(dirname(__FILE__) . '/../../../../../../../') .'/application/config/oos.php';$oos = new Oos();/* 上传配置 */$config = array(  "pathFormat" => $CONFIG['catcherPathFormat'],  "maxSize" => $CONFIG['catcherMaxSize'],  "allowFiles" => $CONFIG['catcherAllowFiles'],  "oriName" => "remote.png");$fieldName = $CONFIG['catcherFieldName'];/* 抓取远程图片 */$list = array();if (isset($_POST[$fieldName])) {  $source = $_POST[$fieldName];} else {  $source = $_GET[$fieldName];}foreach ($source as $imgUrl) {  $item = new Uploader($imgUrl, $config, "remote");  $info = $item->getFileInfo();  $year = date('Ymd',time());//图片路径 (年/月) 自己设置  $img_name = time().rand(1,1000).$info['type'];  $bos_url = "ueditor_upload/xinjieshi/image/$year/$img_name";//用作保存的图片路径和名字  $oos->upload($_SERVER['DOCUMENT_ROOT'].'/'.$info['url'],$bos_url);  array_push($list, array(    "state" => $info["state"],    "url" => $oos_config['uploadurl'].$bos_url,    "size" => $info["size"],    "title" => htmlspecialchars($info["title"]),    "original" => htmlspecialchars($info["original"]),    "source" => htmlspecialchars($imgUrl)  ));}/* 返回抓取数据 */return json_encode(array(  'state'=> count($list) ? 'SUCCESS':'ERROR',  'list'=> $list));
.

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

广告 广告

评论区