2011-09-03 36 views
5

Tôi gặp khó khăn khi sử dụng dữ liệu được tạo bằng phương thức todataurl() của canvas. Hiện tại mã của tôi gửi dữ liệu kết quả đến máy chủ php của tôi sử dụng phương thức file_put_contents() để tạo một tệp để lưu trữ dữ liệu đó. Bây giờ nếu tôi cắt và dán kết quả sai ngữ pháp từ tập tin vào một thẻ hình ảnh src nó hoạt động tốt và hiển thị đúng cách vì vậy tôi giả định cho đến nay tất cả mọi thứ là đào.Giải mã canvas todataURL

Nhưng tôi tiếp tục gặp sự cố khi cố gắng sử dụng mã trong JS. Tôi đã thử phương pháp base64_decode của php nhưng vẫn nhận được các tập tin currupt. Tôi đã tìm thấy mã này:

<?php 
    $encodedData = str_replace(' ','+',$encodedData); 
    $decocedData = base64_decode($encodedData); 

và vẫn nhận các tệp bị gián đoạn. Lý tưởng nhất là tôi muốn tạo một tệp .png với nó nhưng tôi sẽ giải quyết để xử lý lại tệp dữ liệu trong JS. Bất kỳ trợ giúp đánh giá rất nhiều.

+0

Bạn chỉ cần phải đọc kiểu MIME (có thể là cố định/biết) và mã hóa (có thể là không có) để giải thích các dữ liệu, đó là tiêu chuẩn Base64. Sẽ không có bất kỳ khoảng trống nào để thay thế nếu bạn đã mã hóa URL dữ liệu nhập trước đó. [PHP-FileUpload] (https://github.com/delight-im/PHP-FileUpload) có ['DataUriUpload'] (https://github.com/delight-im/PHP-FileUpload/blob/023f812226673ac9e0696d8a3579bb7380606dda/ src/DataUriUpload.php) thành phần thực hiện tất cả điều này một cách tự động. Tài liệu được mô tả [tại đây] (https://github.com/delight-im/PHP-FileUpload/tree/023f812226673ac9e0696d8a3579bb7380606dda#data-uri-uploads). – caw

Trả lời

12

Dường như bạn phải loại bỏ tiêu đề được thêm vào dữ liệu hình ảnh theo hàm toDataURL(). Về phía khách hàng, bạn có thể lột tiêu đề như thế này:

.. 
var data=canvas.toDataURL(); 
var output=data.replace(/^data:image\/(png|jpg);base64,/, ""); 
// now send "output" to the server 
.. 

Về việc sử dụng máy chủ bên này:

<?php 
    $decocedData = base64_decode($encodedData); 
?> 
+3

Đó là hữu ích, đây là những gì tôi đã kết thúc làm nếu có ai cần làm tương tự trong tương lai: \t $ backGround = substr ($ backGround, 22); \t $ backGround = str_replace ('', '+', $ backGround); \t $ backGround = base64_decode ($ backGround); \t file_put_contents ("currentBG1.png ", $ backGround); – joel

+0

cũng cần thêm jpeg vào biểu thức chính quy: var output = data.replace (/^data: image \/(png | jpg | jpeg); base64, /," "); – dickyj

3

Trong kịch bản java gửi kết quả từ canvas.toDataURL() trên những trình duyệt hơn hỗ trợ phương thức này với loại "image/png" mặc định.

var imageInfo = canvas.toDataURL(); 
// now send "imageInfo" to the server 

cách trực tiếp để tạo ra các tập tin png:

<?php 
$imageInfo = imageInfoFromBrowser(); // Your method to get the data 
$image = fopen($imageInfo, 'r'); 
file_put_contents("fileName.png", $image); 
fclose($image); 
?> 

tôi đã làm việc này trong PHP 5.3/Windows, cho phiên bản khác, vui lòng kiểm tra.

Mẫu dữ liệu hình ảnh để thử nghiệm trên PHP.

$imageInfo = "" 
+0

Nếu điều này không thành công cho bạn, vui lòng đăng môi trường PHP của bạn.Thêm –

+0

canvas.toDataUrl() ... đây là gì? – realtebo

+1

'canvas.toDataUrl()' được sử dụng ví dụ trên [fabric.js] (http: // Bạn có thể lấy canvas của mình thông qua JavaScript 'var imageInfo = document.getElementById (" yourid "). toDataURL();' hoặc thông qua JQuery 'var imageInfo = $ (" # yourid "). toDataURL() ; ' Giải pháp này được đăng bởi @ DanielDeLeón hoạt động như một sự quyến rũ. Cảm ơn bạn, – ptCoder

2

Lưu ý quan trọng khác là bạn phải chuyển đổi khoảng trống thành ô tô. Nếu bạn không làm điều đó, các dữ liệu được giải mã là hỏng:

$encodedData = str_replace(' ','+',$encodedData); 
$decocedData = base64_decode($encodedData); 

Bạn có thể đọc thêm tại http://www.php.net/manual/en/function.base64-decode.php

0

giải pháp khác không làm việc cho tôi.

này hoạt động:

//image sample 
$baseFromJavascript = ""; 

// remove the part that we don't need from the provided image and decode it 
$data = base64_decode(preg_replace('#^data:image/\w+;base64,#i', '', $baseFromJavascript));