2

我有一个我修改过的 phonegap 插件。Java 部分输出一个 base64 字符串:

package org.apache.cordova;

import java.io.ByteArrayOutputStream;
import java.io.File;

import org.apache.cordova.api.Plugin;
import org.apache.cordova.api.PluginResult;
import org.json.JSONArray;

import android.annotation.TargetApi;
import android.graphics.Bitmap;
import android.os.Environment;
import android.util.Base64;
import android.view.View;



public class Screenshot extends Plugin {

    @Override

    public PluginResult execute(String action, JSONArray args, String callbackId) {
        // starting on ICS, some WebView methods
        // can only be called on UI threads
        final Plugin that = this;
        final String id = callbackId;
        super.cordova.getActivity().runOnUiThread(new Runnable() {
            //@Override
            @TargetApi(8)
            public void run() {
                View view = webView.getRootView();

                view.setDrawingCacheEnabled(true);
                Bitmap bitmap = Bitmap.createBitmap(view.getDrawingCache());
                view.setDrawingCacheEnabled(false);

                File folder = new File(Environment.getExternalStorageDirectory(), "Pictures");
                if (!folder.exists()) {
                    folder.mkdirs();

                }

                File f = new File(folder, "screenshot_" + System.currentTimeMillis() + ".png");
                System.out.println(folder);
                System.out.println("screenshot_" + System.currentTimeMillis() + ".png");



                ByteArrayOutputStream baos = new ByteArrayOutputStream();  
                bitmap.compress(Bitmap.CompressFormat.PNG, 100, baos);
                byte[] b = baos.toByteArray();
                String base64String = Base64.encodeToString(b, Base64.DEFAULT);
                String mytextstring = "data:image/png;base64,"+base64String;
                System.out.println(mytextstring);

                that.success(new PluginResult(PluginResult.Status.OK, mytextstring), id);
            }
        });

        PluginResult imageData = new PluginResult(PluginResult.Status.NO_RESULT);
        imageData.setKeepCallback(true);
        System.out.println("imageData=============>>>>>"+imageData);
        return imageData;
    }

}

然后我将它传递给一些 Javascript,然后将字符串发送到服务器。我检查了 .php 文件接收到的字符串,base64 字符串是相同的。但是,当我解码 base64 字符串时,它似乎已损坏。举个更好的例子,将此文本文件的内容复制到解码器中。

http://dl.dropbox.com/u/91982671/base64.txt

注意:当 .php 文件尝试对其进行解码时 data:image/png;base64, 在前面,我刚刚将其删除,以便您将其粘贴到解码器中。

解码器在这里找到:

http://www.motobit.com/util/base64-decoder-encoder.asp

我能想到的是,由于某种原因,我可能无法从 Java 中正确输出 base64 字符串。有谁知道发生了什么?或者是什么原因造成的?

4

1 回答 1

1

昨晚我玩了几个小时,并考虑了其中一些建议。

首先,我在编码之前检查了图像。很好。

然而,在它进入 Javascript 之前对其进行解码表明它已损坏,这意味着它必须与 Java 编码过程有关。为了解决这个问题,我并没有声称 100% 理解它为什么会发生,但问题似乎在于这段代码:

String mytextstring = "data:image/png;base64,"+base64String;

以及在将其发送到 Javascript 和 PHP 解码器之前添加“data:/image/png;base64”的方式。为了解决这个问题,我从 Java 代码中删除了它,所以它变成了:

String mytextstring = base64String;

在我将它发送到服务器的 JavaScript 函数中,我将它添加到那里的字符串中,这很有效,我收到了一个未损坏的图像。以防万一有人想知道/关心我添加它的Javascript函数如下:

function returnScreenshotImage(imageData) { 
    base64string = "data:image/png;base64,"+imageData;
    console.log("String: "+base64string);

    var url = 'http://www.websitename.co.uk/upload.php';
    var params = {image: imageData};

    document.basicfrm.oldscreenshotimg.value = document.basicfrm.screenshotimg.value;

    // send the data
    $.post(url, params, function(data) {
           document.basicfrm.screenshotimg.value = data;

           });    
}

如您所见:

base64string = "data:image/png;base64,"+imageData;

添加以前由 Java 添加的部分。这现在有效。希望这对未来的人们有所帮助。如果有人愿意评论广告,请解释为什么会这样,如果他们知道,请随意。:)

于 2012-09-19T08:08:08.623 回答