kindeditor 加入七牛云上传

七牛云上传主要有两种:

  1. 服务端上传
  2. 前端上传,前端又分两种返回方式:

    1).重定向返回,可以解决ajax跨域的问题

    2).回调返回,七牛云先向服务端要返回数据,再由七牛云返回前端,解决不支持重定向的请求方式,比如小程序上传

本次使用的是 七牛云 php sdk;

composer require qiniu/php-sdk

  

在Kindeditor/php 下添加 config.php 主要是配置参数

<?php
error_reporting(0);

defined(‘ROOT_PATH‘) || define(‘ROOT_PATH‘, dirname(__DIR__).‘/‘);
defined(‘QINIU_ACCESS_KEY‘) || define(‘QINIU_ACCESS_KEY‘, ‘‘);
defined(‘QINIU_SECRET_KEY‘) || define(‘QINIU_SECRET_KEY‘, ‘‘);
defined(‘QINIU_TEST_BUCKET‘) || define(‘QINIU_TEST_BUCKET‘, ‘七牛云空间名‘);
defined(‘QINIU_BUCKET_DOMAIN‘) || define(‘QINIU_BUCKET_DOMAIN‘, ‘七牛云空间网址‘);

defined(‘CALLBACK_URL‘) || define(‘CALLBACK_URL‘, ‘域名/kindeditor/php/callBack.php‘);
defined(‘RETURN_URL‘) || define(‘RETURN_URL‘, ‘域名/kindeditor/php/returnBack.php‘);

require_once ROOT_PATH."vendor/autoload.php";

  

在Kindeditor/php 下添加 qiniu_token.php 主要是生成上传用的 token

<?php
use Qiniu\Auth;

require_once __DIR__."/config.php";

// 构建鉴权对象
$auth = new Auth(QINIU_ACCESS_KEY, QINIU_SECRET_KEY);

$data = [
    ‘returnUrl‘ => RETURN_URL,
];
if (isset($_REQUEST[‘is_call‘])) {
   $data = [
      ‘callbackUrl‘ => CALLBACK_URL,
      ‘callbackBody‘ => ‘key=$(key)&hash=$(etag)&w=$(imageInfo.width)&h=$(imageInfo.height)‘
   ];
}
// 生成上传 Token
$token = $auth->uploadToken(QINIU_TEST_BUCKET, null, 3600, $data);

echo json_encode([
   ‘error‘ => 0,
   ‘token‘ => $token
]);

  

在Kindeditor/php 下添加 callBack.php  主要是回调用

<?php
use Qiniu\Auth;

require_once __DIR__."/config.php";
$_body = file_get_contents(‘php://input‘);
$auth = new Auth(QINIU_ACCESS_KEY, QINIU_SECRET_KEY);
//回调的contentType
$contentType = ‘application/x-www-form-urlencoded‘;
//回调的签名信息,可以验证该回调是否来自七牛
$authorization = $_SERVER[‘HTTP_AUTHORIZATION‘];
$isQiniuCallback = $auth->verifyCallback($contentType, $authorization, CALLBACK_URL, $_body);
if (!$isQiniuCallback) {
    echo json_encode([
        ‘error‘ => 2,
        ‘message‘ => ‘验证失败‘
    ]);
    die();
}

$body = $_POST;
$qiniu_url = QINIU_BUCKET_DOMAIN;
if (!empty($body[‘key‘])) {
    echo json_encode([
        ‘error‘ => 0,
        ‘url‘ => $qiniu_url.$body[‘key‘]
    ]);
    die();
}
echo json_encode([
    ‘error‘ => 1,
    ‘message‘ => ‘视频上传出错‘
]);

  

在Kindeditor/php 下添加 returnBack.php  主要是重定向接收地址

<?php
use Qiniu\Auth;

require_once __DIR__."/config.php";
$upload_ret = base64_decode($_GET[‘upload_ret‘]);
$upload_ret = json_decode($upload_ret, true);
$qiniu_url = QINIU_BUCKET_DOMAIN;
if (!empty($upload_ret[‘key‘])) {
    echo json_encode([
        ‘error‘ => 0,
        ‘url‘ => $qiniu_url.$upload_ret[‘key‘]
    ]);
    die();
}
echo json_encode([
    ‘error‘ => 1,
    ‘message‘ => ‘视频上传出错‘
]);

  

接下来是前端更改,我改的时视频上传

Kindeditor/plugins/media/media.js

KindEditor.plugin(‘media‘, function(K) {
	var self = this, name = ‘media‘, lang = self.lang(name + ‘.‘),
		allowMediaUpload = K.undef(self.allowMediaUpload, true),
		allowFileManager = K.undef(self.allowFileManager, false),
		formatUploadUrl = K.undef(self.formatUploadUrl, true),
		extraParams = K.undef(self.extraFileUploadParams, {
			‘token‘: ‘‘//添加token
		}),
		filePostName = K.undef(self.filePostName, ‘file‘), //更改文件上传名
		uploadJson = K.undef(self.uploadJson, ‘https://up.qbox.me‘); //更改上传地址,我用的时华东区的空间使用https 

		....

			function getQToken() {
				$.getJSON(‘/includes/kindeditor/php/qiniu_token.php‘, function (data) {
					K(‘[name="token"]‘, div).val(data.token);
				});
			}
                        // 获取设置上传token
			getQToken();

			if (allowMediaUpload) {
				var uploadbutton = K.uploadbutton({
					button : K(‘.ke-upload-button‘, div)[0],
					fieldName : filePostName,
					extraParams : extraParams,
					url : uploadJson,//去除添加参数
					afterUpload : function(data) {
            ...
});

 

这要就可以上传视频到七牛云了。

?

时间: 2024-07-29 08:29:44

kindeditor 加入七牛云上传的相关文章

七牛云上传视频并截取第一帧为图片(js实现)

本文出自APICloud官方论坛, 感谢论坛版主 东冥羽的分享. 七牛云上传视频并截取第一帧作为视频的封面图. 使用js上传,模块videoPlayer截取第一帧(有专门的截图模块,但是我使用的有点问题,可能是视频源的问题:canvas也能截取,但是有点小bug,比如会截成黑色或白色的图片). 上传一个和上传多个视频 demo运行点这里 需要参数:token值,七牛云域名 *逻辑: 上传一个视频: 点击上传按钮,获取token值,选中视频后开始上传.input file会获取文件的大小,文件名等

七牛云上传工具

三年前刚接触七牛云的时候,由于官方没有客户端上传工具,就用 Java 写了一个图形化的上传工具,纯属个人兴趣.后来公司项目使用了七牛云,就重新调整了一下代码,分享给有需要的人. 一.开发初衷 看到 Mac 上有几个不错的支持七牛上传的工具,发现 Windows 下并没有,而且七牛官方有现成的 API,就想自己尝试做一个出来,正好自己是安卓开发,就用 Java 写了一个,不管什么系统,只要装了 Java 即可运行. 软件是一个 jar 包,拖拽上传,很适合产品和设计的同学上传开发素材. 系统要求:

关于使用elementUI直传七牛云上传 and 下载踩坑

这几天一直研究七牛云的,,由于本人对elementUI框架的不熟悉,,踩了很多坑. 首先需要注册一个七牛云,最近快赶上双十一,所以七牛云新用户价格低廉500G*6个月只用了一分钱,废话不多说直接上代码. 先说说上传 前端使用elementUI的<el-upload>组件: <el-upload action="http://upload-z2.qiniup.com" :http-request="sliderRequest" :name="

thinkphp 中 使用七牛云上传

利用七牛云私有空间存储文件 第一步,注册七牛云,创建空间,将空间设为私有 需要记下的东西: AK,SK,bucket 第二步配置ThinkPHP 在config.php添加 'UPLOAD_SITEIMG_QINIU'=>array( 'maxSize'=>5*1024*1024,//文件大小 'rootPath'=>'./', 'saveName'=>array('uniqid',''), 'driver'=>'Qiniu', 'driverConfig'=>arra

iOS 七牛云上传并获取图片----【客户端】

       最近做了七牛云存储的有关内容,涉及到与后台交互获取验证的token,无奈,后台自命清高,不与理会,没办法呀,于是自己搞呗.首先呢在在七牛上注册一个账号,然后呢添加一个存储空间这时候空间名是用来识别存储空间的位置,而地区的选择则是设置存储七牛服务器的位置,那么选择一个公开空间免费试用就可以了~~        创建好账号就是查看官方文档编写demo的流程了,顺便附带一个下载地址:http://developer.qiniu.com/code/v7/sdk/objc.html    下

PHP阿里云OSS,七牛云 上传文件

来源:http://my.oschina.net/rain21/blog/477019 七牛云 PHPSDK下载:http://pan.baidu.com/s/1o69TGcM 7.X版本: DEMO: <?php require_once './vendor/autoload.php';   use Qiniu\Auth; use Qiniu\Storage\BucketManager; use Qiniu\Storage\UploadManager;   $accessKey = 'acce

七牛云上传视频如何有效做到节省空间

在上传视频的时候,我们通常会保存到第三方[七牛云]平台.不过大多数程序员在系统后台上传视频后,一般都是保存到了本地,如果视频非常多或者视频容量特别大的情况下,那么我们的服务器迟早有一天会满,为了节省空间,下面教大家再上传视频时,如何以有效的节省服务器空间,一般情况下会把这些文件存到第三方,也就是需要我们下载qiniusdk,把qiniusdk放如Vendor目录下. 这里我们以课程视频为例子,实现的hmtl源代码如下:<tr> <td class="text">

七牛上传视频添加到队列时视频大小是否添加

最近在做视频分析的项目,遇到了一些关于七牛上传视频文件的问题. 当 选择的视频文件 大于 本地剩余空间 时,则取消上传. 'FilesAdded': function(up, files) { plupload.each(files, function(file,index) { //重点在这里 var fileSize=0; for(var i=0;i<files.length;i++){ fileSize+= Math.ceil(files[i].size/1024/1024); }; //

iOS 客户端获取七牛上传token

一.官方参考文档: 1.上传策略http://developer.qiniu.com/article/developer/security/put-policy.html 2.上传凭证(即uptoken)http://developer.qiniu.com/article/developer/security/upload-token.html 3.下载凭证http://developer.qiniu.com/article/developer/security/download-token.h