我正在使用 $.ajax() 将字符串发送到存储在表中的冷融合服务器。当我稍后查询并尝试使用该数据时,我得到一个错误;“空封闭异常:3 字节 UTF-8 序列的字节 2 无效”。
首先,我从 DOM 中获取 SVG 并将其发送到操作页面。它应该只是一个字符串,对吧?
var lclSVG = $('#myDiv')[0].innerHTML; // SVG Code (XML?)
$.ajax({
url: "myAction.cfm",
type: "POST",
data: ({myInfo: lclSVG}),
});
在 myAction.cfm 页面上,我将数据更新到一个表中。
<CFQUERY NAME="postSVG">
UPDATE myTable
SET svg = '#form.myInfo#'
WHERE ID = 1
</CFQUERY>
SVG2PNG.cfm:当我尝试查询和使用 svg 数据时,我收到错误“3 字节 UTF-8 序列的字节 2 无效”。错误发生在 .transcode 行。
<CFQUERY NAME="getSVG">
SELECT svg
FROM myTable
WHERE ordID = 1
</CFQUERY>
<cfset svg = getSVG.svg>
<cfscript>
transcoder = createObject("java", "org.apache.batik.transcoder.image.PNGTranscoder").init();
inputStream = createObject("java", "java.io.StringBufferInputStream").init(svg);
input = createObject("java", "org.apache.batik.transcoder.TranscoderInput").init(inputStream);
OutFile = expandPath("myTest2.png");
outputStream=CreateObject("java", "java.io.FileOutputStream").init(OutFile);
output=CreateObject("java", "org.apache.batik.transcoder.TranscoderOutput").init(outputStream);
transcoder.transcode(input, output);
outputStream.close();
</cfscript>
我已经多次使用 jQuery 的 ajax 方法,没有太大的困难。我在这里做错了什么,我似乎无法处理它......