将二进制值转换为字符串然后转换回二进制吗?

时间:2018-08-27 15:10:27

标签: coldfusion binary decode encode rowversion

我有rowversion值,该值来自二进制格式的数据库。我需要将该值转换为字符串,以便传递我的前端代码。然后,当用户将数据提交回服务器时,我需要将该字符串转换回二进制。这是我的数据示例:

Binary 00000010586 

以上是查询结果返回值时看到的输出。然后我尝试了这个:

编码值如下:iV

然后我尝试将值解码回去,这就是我所使用的:

#charsetDecode( local.encodedVal, "utf-8" )#

然后我收到此错误消息:ByteArray objects cannot be converted to strings.

在我的数据库行版本中,列的类型为timestamp。当查询返回该值时,它将在ColdFusion中表示为二进制。我将此列用作表中每行设置的唯一ID。有没有办法在CldFusion中处理此转换,什么是最佳方法?

1 个答案:

答案 0 :(得分:3)

您使用的是二进制数据,而不是字符串编码。您将需要使用binaryEncodedbinaryDecode将数据作为字符串发送并将其转换回二进制。

以下示例将一些二进制数据转换为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>

TryCF.com

上运行示例