JSON / CFML - 循环结构数组

时间:2015-08-12 23:24:01

标签: android arrays json coldfusion cfml

我为我的公司测试了一款名为Barcode Scanner Terminal的应用程序;我希望用它作为时钟的替代品。

员工可以在他们的身份证上扫描条形码或二维码,这个应用程序会将其与时间戳甚至GPS坐标一起发送到我的服务器,以验证他们是否在正确的时间出现在正确的位置。当手机有互联网连接时,这些信息通过我网站上的特殊URL传递,我可以使它完美无瑕地工作。

问题?

当没有互联网时,手机会在本地存储扫描件,您可以稍后将其发送到服务器。这些扫描存储为结构的JSON数组。

According to the documentation

...以这种方式存储的数据可以作为POST请求发送到服务器。我不确定如何测试所有这些因此我只是设置了一些变量,进行了扫描,并向我发送了一封电子邮件,其中包含了他们所代表的值。

<cfset requestBody = toString( getHttpRequestData().content )/>

回归这个怪物和许多其他喜欢它;您在下面看到的是一次扫描。

  

批次=%5B%7B%22barcode%22%3A%22CSS1959%22%2C%22scannerID%22%3A%223e81b04aa521a05e%22%2C%22time%22%3A%222015-08-11 + 08%3A28% 3A20.419%22%2C%22lat%22%3A32.3999433%2C%22long%22%3A-110.040379%7D%5D

所以我通过URLDecode()函数运行该值以获得看起来更熟悉的东西。

<cfset decodedBody = #URLDecode(requestBody)#>
<!--- This would output the following. Line breaks are for ease of reading. --->
batch=[{"barcode":"CSS1959","scannerID":"3e81b04aa521a05e",
"time":"2015-08-11 08:28:20.419","lat":32.3999433,"long":-110.040379}] 

所以最终我有一堆扫描在JSON中形成了这个Structs数组,我不知道如何处理它。

batch=[
{"barcode":"CSS1035","scannerID":"3e81b04aa521a05e","time":"2015-08-11 08:30:27.232","lat":32.4001579,"long":-110.0403455},
{"barcode":"CSS1959","scannerID":"3e81b04aa521a05e","time":"2015-08-11 08:30:29.366","lat":32.4001579,"long":-110.0403455},
{"barcode":"CSS1649","scannerID":"3e81b04aa521a05e","time":"2015-08-11 08:30:31.642","lat":32.4001579,"long":-110.0403455}
] 

我正在尝试循环并将它们全部插入到数据库中。

到目前为止,我有这个,我收到了JSON解析错误。

<cfset requestBody = toString( getHttpRequestData().content ) />
<cfset decodedBody = #URLDecode(requestBody)#>
<!---This is where I falter because I have no idea how to handle it.--->
<cfset arrayOfStructs = deserializeJson(decodedBody)>
<cfloop array="#arrayOfStructs#" index="barcode">
blah blah query logic
</cfloop>

这是我得到的错误。enter image description here

谢谢!

编辑:解决了部分谢谢我在这里收到的帮助。解决方案如下:

<cfset requestBody = #replaceNoCase( toString(getHttpRequestData().content), "batch=", "" )#  />
<cfset decodedBody = #URLDecode(requestBody)#>
<cfset ArrayOfStructs = deserializeJson(decodedBody)>
<cfloop array="#ArrayOfStructs#" index="i">
<cfquery name="doodoodoo" datasource="CRM">
    INSERT INTO TimeAppTest
    (
        EmployeeID,
        lat,
        long,
        TimoStampo
        )
    VALUES
    (
        '#i.barcode#',
        '#i.lat#',
        '#i.long#',
        '#i.time#'

        )
</cfquery>
</cfloop>

2 个答案:

答案 0 :(得分:3)

在我看来,你很可能能够获得&#34;批次&#34;的价值。直接作为表单范围的一部分。当然假设你真的收到了一个帖子请求。

所以你可以做到:

<cfif isDefined("form.batch")>
    <cfset aData = deSerializeJSON(trim(form.batch))>
    <cfdump var="#aData#">
</cfif>

因此无需查看请求正文,也无需解码响应。

答案 1 :(得分:2)

您需要剥离&#34; batch =&#34;或将整个事物传递给&#34; evaluate()&#34;这会将数组文字设置为一个名为batch的变量。我会推荐前一个选项,因为第二个可能被字符串中的恶意CFML内容利用。

<cfset arrayOfStructs = deserializeJson( replaceNoCase( decodedBody, "batch=", "" ) )>