我有rowversion
值,该值来自二进制格式的数据库。我需要将该值转换为字符串,以便传递我的前端代码。然后,当用户将数据提交回服务器时,我需要将该字符串转换回二进制。这是我的数据示例:
Binary 00000010586
以上是查询结果返回值时看到的输出。然后我尝试了这个:
编码值如下:iV
然后我尝试将值解码回去,这就是我所使用的:
#charsetDecode( local.encodedVal, "utf-8" )#
然后我收到此错误消息:ByteArray objects cannot be converted to strings.
在我的数据库行版本中,列的类型为timestamp
。当查询返回该值时,它将在ColdFusion中表示为二进制。我将此列用作表中每行设置的唯一ID。有没有办法在CldFusion中处理此转换,什么是最佳方法?
答案 0 :(得分:3)
您使用的是二进制数据,而不是字符串编码。您将需要使用binaryEncoded
和binaryDecode
将数据作为字符串发送并将其转换回二进制。
以下示例将一些二进制数据转换为2个字符串表示形式,并在转储中使用binaryDecode
将它们转换回相同的字节数组。
<cfscript>
binaryData = toBinary("SomeBinaryData++");
hexEncoded = binaryEncode(binaryData, "hex");
base64Encoded = binaryEncode(binaryData, "base64");
writeDump([
binaryData,
hexEncoded,
base64Encoded,
binaryDecode(hexEncoded, "hex"),
binaryDecode(base64Encoded, "base64")
]);
</cfscript>
上运行示例