Я хочу сохранить свой холст в базе данных MySQL (ячейка BLOB). У меня есть функция в javaScript
function saveCanvas(){
var canvas = document.getElementById("canvas");
var dataURL = canvas.toDataURL("image/png");
dataURL = dataURL.replace(/^data:image\/(png|jpeg);base64,/, "");
var req = $.ajax({
url: "Canvases",
type: "Post",
data: "operation=0&sessionId=" + readCookie('sessionId') + "&title=" + document.getElementById('imageNameTextbox').value + "&pic=" + dataURL,
success: function(){
}
});
}
Затем я использую Java для хранения своего изображения
BASE64Decoder decoder = new BASE64Decoder();
byte[] pic = decoder.decodeBuffer(request.getParameter("pic"));
CanvasController.AddCanvas(sessionId, new CanvasModel(0, 0, request.getParameter("title"), pic));
И вставка в базу данных:
String insertStatement = "INSERT INTO Canvas(userId, title, pic) VALUES (?, ?, ?);";
prepStmt = connection.prepareStatement(insertStatement);
prepStmt.setInt(1, id);
prepStmt.setString(2, canvas.getTitle());
prepStmt.setBytes(3, canvas.getPic());
prepStmt.executeUpdate();
После запуска я всегда получаю пустое изображение в БД. Когда я меняю image / png на image / jpeg и рисую, например:
http://imageshack.us/photo/my-images/714/pobranec.jpg
Я получаю:
http://imageshack.us/photo/my-images/15/pobrane2q.jpg
Можете ли вы сказать, что я делаю неправильно?