php下載pdf轉存本地的實作方法:先建立html頁面程式碼以及script.js程式碼;然後建立本地讀取pdf檔的PHP程式碼;最後把jquery庫檔引進來,進行遠端下載即可。
本文操作環境:Windows7系統、PHP7.1版,DELL G3電腦
PHP ajax 遠端下載PDF檔案儲存在本機伺服器
在一些時候我們想ajax方式來保存一些PDF文件,尤其是它放在遠端伺服器上,並且是保存在我們自己的伺服器上存儲,這個時候我們需要寫一段程式來幫助我們完成這個工作,本文介紹了PHP 遠端下載PDF檔案保存在本地伺服器本地化,需要的朋友可以參考下:
html頁面代碼如下:
<!DOCTYPE html> <html> <head> <script data-require="jquery@2.1.1" data-semver="2.1.1" src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" href="style.css" /> <script src="jquery.binarytransport.js"></script> <script src="script.js"></script> </head> <body> <button>download pdf</button> </body> </html>
script. js程式碼如下:
$(function() { $("button").click(function() { $.ajax({ url: "http://lch.bat.com/aa.pdf", type: "GET", dataType: 'binary', success: function(result) { var blob = new Blob([result], {type:"application/pdf"}); var data = new FormData(); data.append('file', blob); $.ajax({ type: 'POST', url: 'http://lch.demo.com/read.php', data: data, processData: false, contentType: false, success: function (arg) { alert('下载成功'); } }) } }); }); });
jquery.binarytransport.js程式碼如下:
/** * * jquery.binarytransport.js * * @description. jQuery ajax transport for making binary data type requests. * @version 1.0 * */ // use this transport for "binary" data type $.ajaxTransport("+binary", function(options, originalOptions, jqXHR){ // check for conditions and support for blob / arraybuffer response type if (window.FormData && ((options.dataType && (options.dataType == 'binary')) || (options.data && ((window.ArrayBuffer && options.data instanceof ArrayBuffer) || (window.Blob && options.data instanceof Blob))))) { return { // create new XMLHttpRequest send: function(_, callback){ // setup all variables var xhr = new XMLHttpRequest(), url = options.url, type = options.type, // blob or arraybuffer. Default is blob dataType = options.responseType || "blob", data = options.data || null; xhr.addEventListener('load', function(){ var data = {}; data[options.dataType] = xhr.response; // make callback and send data callback(xhr.status, xhr.statusText, data, xhr.getAllResponseHeaders()); }); xhr.open(type, url, true); xhr.responseType = dataType; xhr.send(data); }, abort: function(){ jqXHR.abort(); } }; } });
再來看看我的本地讀取pdf檔的程式碼:
<?php /** * Created by PhpStorm. * User: LCA * Date: 2020/9/28 * Time: 9:44 */ //header('Access-Control-Allow-Origin: *'); // 响应类型 header('Access-Control-Allow-Methods:*'); // 响应头设置 header('Access-Control-Allow-Headers:content-type,token,id'); header("Access-Control-Request-Headers: Origin, X-Requested-With, content-Type, Accept, Authorization"); if(isset($_FILES['file'])){ $fname = "cc.pdf"; move_uploaded_file($_FILES['file']['tmp_name'], "/htdocs/demo/" . $fname); echo "写入成功"; }
最後把jquery庫檔案引進來,遠端下載後,本地即可以開啟和原始檔案內容一模一樣,不會出現亂碼了。
推薦學習:《PHP影片教學》
以上是php怎麼下載pdf 轉存本地的詳細內容。更多資訊請關注PHP中文網其他相關文章!