html上傳圖片資料到伺服器,php接收儲存圖片

來源:互聯網
上載者:User

很多時候,我們需要把web端的圖片資料或者canvas裡面的畫面儲存到伺服器上。html5已經提供了可用的介面。


Canvas的toDataURL方法,可以將canvas上的畫布資料匯出成字串格式。我們只需要再把字串傳輸給伺服器就可以了。

如果圖片是img標籤的,怎麼辦呢?

很簡單,canvas提供了drawImage方法,用於把img或者其他canvas的資料畫到自己的畫布上。

下面,我們看看用戶端的代碼:

var cc = window.document.getElementById("egretCanvas");var cc2 = document.createElement("canvas");cc2.setAttribute("width", "320");cc2.setAttribute("height", "514");var ctx = cc2.getContext("2d");ctx.drawImage(cc, 0, 0, 320, 514);
var imgdata: string = cc2["toDataURL"]();


這樣匯出後的字串,含有首碼“data:image/png;base64,”,所以我們需要把這個首碼去掉

imgdata = imgdata.substring(22); 

然後把字串傳給伺服器,這裡我們選擇使用php語言來接收資料並儲存圖片。


$imgurl = str_replace(' ', '+', $_REQUEST['image']);
先把字串中的空格替換成"+"號。


$savePath = "../images/123.png";$image = base64_decode($image);file_put_contents($savePath,$image);

php拿到資料後,需要進行base64解碼,才能儲存成圖片。



以上就介紹了html上傳圖片資料到伺服器,php接收儲存圖片,包括了方面的內容,希望對PHP教程有興趣的朋友有所協助。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.