PHP sdk文檔處理常用代碼示例解析
主要是:ppt文件轉(zhuǎn)為pdf文件,pdf文件轉(zhuǎn)圖片(png)。
描述一下需求:上傳PPT或者PDF文件到七牛,最終轉(zhuǎn)換為圖片。文件上傳部分的功能已經(jīng)講過了,這里說一下轉(zhuǎn)換處理的部分。
文檔類型
因?yàn)槠吲U麄€(gè)的文件存儲系統(tǒng)中文件類型并不靠后綴來區(qū)分,而是有它自己的 文件類型(mineType),所以在堆bucket中的資源進(jìn)行處理的時(shí)候,首先要判斷minetype。
多次的測試結(jié)果表明,pdf文件上傳后的minetype一為application/pdf,而ppt上傳后的類型就比較多了,通過jssdk上傳,以及直接在七牛上傳,上傳后綴為ppt、pptx的結(jié)果都有可能不一樣。最終總結(jié)出如下的幾種類型:
application/vnd.openxmlformats-officedocument.presentationml.presentation
application/zip
application/vnd.ms-powerpoint
application/ppt
application/x-ole-storage
這里的文檔類型判斷PHP-SDK已經(jīng)提供了,是BucketManager這個(gè)類。
//使用方式
$bucketManager = new BucketManager($this->getAuth());//getAuth()方法見七牛php-sdk使用-文件上傳
$mineTypeInfo = $bucketManager->stat(bucketName, 七牛資源名);
$mimeType = $mineTypeInfo[0]['mimeType'];
持久化處理
七牛的服務(wù)都是通過http請求附加不同的參數(shù)來實(shí)現(xiàn)的,比如我們處理剪裁一張圖片,或者獲取視頻某一秒的截圖,在我們的頁面中可以直接使用src=http://qiniu.com.cn?xxx這種方式,就能得到我們想要結(jié)果,但有的時(shí)候我們需要把處理的結(jié)果保存到我們的bucket中,這個(gè)就是持久化處理了。
根據(jù)sdk封裝一個(gè)持久化處理的方法,用到的sdk類為PersistentFop:
/**
* 文件持久化處理
* @param $key 七牛資源名
* @param $pfop 對資源進(jìn)行的數(shù)據(jù)處理操作的命令
* @param $bucket bucketName
* @return persistentId
*/
public function persistentOps($key,$bucket,$pfop,$notifyUrl='',$check=true)
{
header('Access-Control-Allow-Origin:*');
$auth = $this->getAuth();
$persistOps = new PersistentFop($auth,$bucket,$this->qiniu_image_pipeline,$notifyUrl);
list($id,$error) = $persistOps->execute($key,$pfop);
if($check){
//可暫時(shí)忽略,用來檢查資源持久化處理狀態(tài)
$result = $this->checkStatus($id,$persistOps);
}else{
$result = true;
}
return $result;
}
PPT轉(zhuǎn)PDF
使用到的持久化出來命令為:$pfop[] = 'yifangyun_preview/v2|saveas/'.$key;,這里使用的是七牛的第三方文檔轉(zhuǎn)換服務(wù),因?yàn)槠吲V暗膐dconv/pdf已經(jīng)不再更新維護(hù)了,而且出現(xiàn)過轉(zhuǎn)為pdf排版出現(xiàn)遮擋以及亂碼等問題,所以改為使用億方云的服務(wù)。
這里面saveas,即保存為一個(gè)新的資源,$key需要做一下說明,按照七牛的要求必須是:
$key = \Qiniu\base64_urlSafeEncode(bucketName.':'.$sourceName);
如果不按照規(guī)則進(jìn)行encode,無法保存成功。base64_urlSafeEncode,sdk functions.php中已經(jīng)存在。
有了原始的key,saveas的key,以及pfop持久化處理命令,就可以調(diào)用persistentOps方法了:
$result = $this->persistentOps($sourceName,$bucketName,$pfop);
pfop可以是一個(gè)數(shù)組,包含多個(gè)處理命令。
PDF轉(zhuǎn)圖片PNG
因?yàn)闆]有PPT轉(zhuǎn)圖片這條路,所以只能先轉(zhuǎn)PDF。
用到的pfop命令:
odconv/png/page/頁碼/density/150/quality/80|saveas/'.$key;
參數(shù)包括頁碼,質(zhì)量,像素密度等,還有更多的參數(shù)可以查閱文檔。所以這里我們首先要獲取PDF文檔的總頁數(shù)。使用到的接口命令是:
//odconv/png/info
$url = 'http://'.$this->qiniu_image_domain.'/'.$sourceName.'.pdf?odconv/png/info';
//url部分就是七牛資源可以訪問的完整鏈接,?后面就是要用到的命令
使用curl去請求這個(gè)鏈接,會返回json數(shù)據(jù),里面會包含page_num成員。
有了page_num,就可以構(gòu)造pfop數(shù)組了。
public function pdf2PngPfop($page,$sourceName)
{
$pfop = [];
$pngName = $sourceName;//原圖
for($i=1;$i<=$page;$i++){
$randName = $pngName.'_'.$i.'.png';//原圖
$key = \Qiniu\base64_urlSafeEncode($this->bucket_for_image.':'.$randName);
$pfop[] = 'odconv/png/page/'.$i.'/density/150/quality/80|saveas/'.$key;
}
return $pfop;
}
然后調(diào)用:
$res = $this->persistentOps($sourceName.'.pdf',$this->bucket_for_image,$pfop,'',false);
note:在處理比較大的文檔,例如一個(gè)PPT有100多頁,那PHP運(yùn)行等待七牛的結(jié)果返回再進(jìn)行數(shù)據(jù)的保存就可能會超時(shí),一個(gè)解決方案,是指定回調(diào)url,persistentOps的倒數(shù)第二個(gè)參數(shù)就是回調(diào)url,當(dāng)文檔轉(zhuǎn)換完成的時(shí)候,七牛會向這個(gè)地址發(fā)起一個(gè)請求,后續(xù)的圖片鏈接保存操作我們交給回調(diào)來做。
tips: 如果對每個(gè)pfop命令都指定回調(diào)地址,對我們的(普通)業(yè)務(wù)服務(wù)器也會造成些許的請求壓力,所以我的做法是給最后一頁的PDF轉(zhuǎn)圖片命令添加回調(diào)url。
回調(diào)地址函數(shù)
public function actionQiniuCallback()
{
$notifyBody = file_get_contents('php://input');
$notifyBodyArray = json_decode($notifyBody,true);
$topicId = Yii::$app->request->get('topicId');
$totalPage = Yii::$app->request->get('totalPage');//pdf頁數(shù)
$key = $notifyBodyArray['inputKey'];//這個(gè)是pdf文件的key
//業(yè)務(wù)代碼
...
}
總結(jié)
php來做這個(gè)文檔轉(zhuǎn)換七牛七牛遇到的一個(gè)主要問題就是超時(shí)的問題,所以我們可以把轉(zhuǎn)換的過程拆解,在數(shù)據(jù)庫中保存處理狀態(tài),然后用定時(shí)任務(wù)來自動處理。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
利用PHP繪圖函數(shù)實(shí)現(xiàn)簡單驗(yàn)證碼功能的方法
下面小編就為大家?guī)硪黄肞HP繪圖函數(shù)實(shí)現(xiàn)簡單驗(yàn)證碼功能的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10
PHP 枚舉類型的管理與設(shè)計(jì)知識點(diǎn)總結(jié)
在本篇文章里小編給大家整理的是關(guān)于PHP 枚舉類型的管理與設(shè)計(jì)知識點(diǎn)總結(jié),需要的朋友們可以學(xué)習(xí)參考下。2020-02-02
ThinkPHP框架結(jié)合Ajax實(shí)現(xiàn)用戶名校驗(yàn)功能示例
這篇文章主要介紹了ThinkPHP框架結(jié)合Ajax實(shí)現(xiàn)用戶名校驗(yàn)功能,涉及thinkPHP使用ajax與后臺控制交互、數(shù)據(jù)庫查詢、判定等相關(guān)操作技巧,需要的朋友可以參考下2019-07-07
PHP基礎(chǔ)學(xué)習(xí)之流程控制的實(shí)現(xiàn)分析
本篇文章介紹了,PHP基礎(chǔ)學(xué)習(xí)之流程控制的實(shí)現(xiàn)分析。需要的朋友參考下2013-04-04
CI框架入門示例之?dāng)?shù)據(jù)庫取數(shù)據(jù)完整實(shí)現(xiàn)方法
這篇文章主要介紹了CI框架入門示例的數(shù)據(jù)庫取數(shù)據(jù)完整實(shí)現(xiàn)方法,包含了配置、建表與實(shí)現(xiàn)MVC的完整過程,需要的朋友可以參考下2014-11-11
Discuz論壇標(biāo)題和底部去掉版權(quán)信息實(shí)例講解
這篇文章主要介紹了Discuz論壇標(biāo)題和底部去掉版權(quán)信息實(shí)例講解,有正好遇到這個(gè)問題但是不知道修改哪個(gè)文件的同學(xué)可以跟著操作下,可以節(jié)省很多不必要的時(shí)間2021-03-03
mysqli_set_charset和SET NAMES使用抉擇及優(yōu)劣分析
盡量使用mysqli_set_charset(mysqli:set_charset)而不是SET NAMES, 當(dāng)然, 這個(gè)內(nèi)容在PHP手冊中也有敘及, 但是卻沒有解釋為什么,接下來為您揭下神秘面紗2013-01-01
PHP實(shí)現(xiàn)簡單網(wǎng)站訪客統(tǒng)計(jì)的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于PHP實(shí)現(xiàn)簡單網(wǎng)站訪客統(tǒng)計(jì)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01

