ARGUMENTS.item
我发现如果在将变量传递给函数之前对变量执行以下操作,我可以使用上面的确切代码:
<cfquery name="qData" datasource="#VARIABLES.dsn#">
select * from myData
</cfquery>
<!--- Setup and init Java objects --->
<cfset byteArrayOutputStream = createObject("java","java.io.ByteArrayOutputStream") />
<cfset objectOutputStream = createObject("java","java.io.ObjectOutputStream") />
<cfset byteArrayOutputStream.init() />
<cfset objectOutputStream.init(byteArrayOutputStream) />
<!--- Serialize the cfquery object --->
<cfset objectOutputStream.writeObject(qData) />
<cfset serializedQuery = toBase64(byteArrayOutputStream.toByteArray()) />
<cfset objectOutputStream.close() />
<!--- Stick in the cache --->
<cfset myCache.put(myCacheName, key, serializedQuery) />
答对了!之后serializedQuery
就可以使用它了,它可以通过 HTTP 跨网络传输。当您从 EHCache 取回它时,您需要执行以下操作:
<!--- Get result value from cache --->
<cfset cacheData = myCache.get(myCacheName, key) />
<!--- Java objects setup --->
<cfset byteArrayInputStream = createObject("java","java.io.ByteArrayInputStream") />
<cfset objectInputStream = createObject("java","java.io.ObjectInputStream") />
<!--- deserialize --->
<cfset ba = toBinary(cacheData) />
<cfset byteArrayInputStream.init(ba) />
<cfset objectInputStream.init(byteArrayInputStream) />
<cfset deserializedQuery = objectInputStream.readObject() />
<cfset objectInputStream.close() />
<!--- Dump query --->
<cfdump var="#deserializedQuery#" />
这种类型的序列化也非常非常快。我可以理解使用 JSON 表示的其他人,但我不确定它们是否一样快。
无论如何,这似乎对我很有用。谢谢大家的意见。我希望其他人觉得这很有用。