2011-09-03 15 views
5

डीकोडिंग मुझे कैनवास की todataurl() विधि के साथ बनाए गए डेटा का उपयोग करने में कठिनाई हो रही है। वर्तमान में मेरा कोड परिणामस्वरूप डेटा को मेरे php सर्वर पर भेजता है जो उस डेटा को संग्रहीत करने के लिए फ़ाइल बनाने के लिए file_put_contents() विधि का उपयोग करता है। अब अगर मैं फ़ाइल से परिणामी gibberish को एक छवि टैग में कट और पेस्ट करता हूं तो यह ठीक काम करता है और ठीक से प्रदर्शित करता है, इसलिए मुझे लगता है कि अब तक सब कुछ peachy है।एक कैनवास todataURL

लेकिन जब मैं जेएस में कोड का उपयोग करने का प्रयास करता हूं तो मैं मुद्दों में भागता रहता हूं। मैंने php की base64_decode विधि को आजमाया है लेकिन दूषित फ़ाइलों को जारी रखा है। मुझे यह कोड मिला:

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

और अभी भी दूषित फाइलें मिलीं। आदर्श रूप से मैं इसके साथ एक .png फ़ाइल बनाना चाहता हूं लेकिन मैं जेएस में फिर से डेटा फ़ाइल को संसाधित करने के लिए बसूंगा। किसी भी मदद की बहुत सराहना की।

+0

आप बस MIME प्रकार (शायद तय/जाना जाता है) और एन्कोडिंग (शायद कोई नहीं) डेटा की व्याख्या करने के, जो मानक Base64 है पढ़ने के लिए। यदि आप पहले इनपुट को यूआरएल-एन्कोड करते हैं तो वहां कोई स्थान नहीं बदला जाएगा। [PHP-fileUpload] (https://github.com/delight-im/PHP-FileUpload) में एक ['DataUriUpload'] है (https://github.com/delight-im/PHP-FileUpload/blob/023f812226673ac9e0696d8a3579bb7380606dda/ src/dataUriUpload.php) घटक जो यह सब स्वचालित रूप से करता है। यह दस्तावेज किया गया है [यहां] (https://github.com/delight-im/PHP-FileUpload/tree/023f812226673ac9e0696d8a3579bb7380606dda#data-uri-uploads)। – caw

उत्तर

12

ऐसा लगता है कि आपको toDataURL() फ़ंक्शन द्वारा छवि डेटा पर प्रीपेड किए गए शीर्षलेख से छुटकारा पाना होगा। उन ब्राउज़रों पर)

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

यह सहायक था, अगर मैं भविष्य में ऐसा करने की ज़रूरत है तो मैं यह कर रहा हूं: \t $ backGround = substr ($ backGround, 22); \t $ backGround = str_replace ('', '+', $ back ग्राउंड); \t $ backGround = base64_decode ($ backGround); \t file_put_contents ("currentBG1।पीएनजी ", $ बैकग्राउंड); – joel

+0

नियमित अभिव्यक्ति में जेपीईजी भी जोड़ना होगा: var output = data.replace (/^डेटा: छवि \/(पीएनजी | जेपीजी | जेपीईजी); बेस 64, /," "); – dickyj

3

जावा स्क्रिप्ट में canvas.toDataURL (से परिणाम भेज:

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

सर्वर साइड उपयोग इस पर: क्लाइंट पक्ष पर आप इस तरह हैडर बंद पट्टी कर सकते हैं डिफ़ॉल्ट रूप से "छवि/पीएनजी" के साथ इस विधि का समर्थन करने के लिए।

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

प्रत्यक्ष रास्ता png फ़ाइल बनाने के लिए:

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

मैं/विंडोज, दूसरे संस्करण के लिए, कृपया जाँच पीएचपी 5.3 में यह काम कर रहे है।

PHP पर परीक्षण के लिए छवि डेटा नमूना।

$imageInfo = "" 
+0

यदि यह आपके लिए असफल रहता है, तो कृपया अपना PHP वातावरण पोस्ट करें। धन्यवाद। –

+0

canvas.toDataUrl() ... यह क्या है? – realtebo

+1

'canvas.toDataUrl()' उदाहरण के लिए [fabric.js] (http: // fabricjs.com/) आप जावास्क्रिप्ट 'var imageInfo = document.getElementById ("yourid") के माध्यम से अपना कैनवास प्राप्त कर सकते हैं। toDataURL();' या JQuery 'var imageInfo = $ (" # yourid ") के माध्यम से। toDataURL() ; ' @ डैनियल डीलेन द्वारा पोस्ट किया गया यह समाधान एक आकर्षण की तरह काम करता है। धन्यवाद, – ptCoder

2

एक और महत्वपूर्ण नोट आपको ब्लैंक को प्लस में परिवर्तित करना है। आप ऐसा नहीं करते हैं, डीकोड डेटा दूषित है:

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

आप पढ़ सकते हैं और अधिक से http://www.php.net/manual/en/function.base64-decode.php

0

अन्य समाधान मेरे लिए काम नहीं किया।

यह काम करता है:

//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)); 
संबंधित मुद्दे