ColdFusion 问题:将 XML Child 的值读取为空字符串

ColdFusion Issue: Reading Value of XML Child as Empty String

我目前使用的是 ColdFusion 10/11,对它还是比较陌生。 我通常在 PHP/C# 中编写代码,因此使用脚本语言(如果您这么称呼它)来管理 XML 中的数据的概念对我来说有点奇怪。如果我可以在 PHP 中重新设计 Web 应用程序,我会的,但不幸的是,现在这不是一个选项。

就平台而言,我不使用 Adob​​e ColdFusion Builder 或 CF Administrator。我正在使用 Dreamweaver 和 CFEclipse。

所以,现在我正在读取一个 XML 文件并检查 XML child 是否包含 "yes"、"no" 等,并且显示相应的标签。它以前工作正常,但我必须向名为 "GNTrained".

的 XML 文件添加一个新的 child

添加新元素后,依然提示该值为空字符串。我使用 "structKeyExists" 来验证 child 是否存在,但该值仍然为空。

我还验证了它正在读取正确的 XML 文件。伟大的 ColdFusion 参考文献不再在线存在(尽管,我不确定它们是否曾经存在过)所以任何帮助将不胜感激!

知道为什么会这样吗?
XML 位置将被委托到其他任何地方?

我已经多次尝试修改这个,但仍然想知道为什么这个值仍然是一个空字符串。我已经尝试了各种不同的值,交换了周围的元素,任何东西都可以让它工作。

为了我的工作,这是示例代码,而不是我正在使用的确切代码集。所以如果我遗漏了什么,请告诉我。然而,这是最简单的代码版本,我认为这真的是解决这个问题所需要的。

有 3 个不同的文件:front-end 显示文件、查询文件和 XML 文件。

显示页面的代码如下:

<cfinclude template="#APPLICATION.root#employee/details/employee-query.cfm" />
<cfoutput>
<cfquery name="get_employee" dbtype="query">
    SELECT id,name,GNTrained from session.employeeDetails order by name
</cfquery>
<cfloop query="get_employee">
<cfif tr eq "RowEven">
    <cfset tr="RowOdd">
    <cfelse>
    <cfset tr="RowEven">
</cfif>
<li class="EmployeeRow #tr#" id="company_#get_employee.currentrow#">#htmleditformat(get_employee.name)#
    <div id="bfeat_#get_employee.currentrow#" class="Hidden">
        <div class="employeeGroup" style="width:371px;">
            <ul class="EmpTrainingList">
            <li>BBTrained:
                <cfif get_employee.BBTrained contains "YES">
                    <span class="yes">#get_employee.BBTrained#</span>
                <cfelse>
                    <span class="no">#get_employee.BBTrained#</span>
                </cfif>
            </li>
            <li>GNTrained: 
            <cfif structKeyExists( get_employee, "GNTrained" )>
                <span style="color: red;"><strong>EXISTS! </strong></span>
                <cfelse> DOES NOT EXIST!
            </cfif>
            <cfif get_employee.GNTrained contains "YES">
                    <span class="yes">#get_employee.GNTrained#</span>
                <cfelseif get_employee.GNTrained contains "In Progress">
                    <span class="in-progress">#get_employee.GNTrained#</span>
                <cfelseif get_employee.GNTrained eq "">
                    <span class="no">EMPTY</span>    
                <cfelse>
                    <span class="no">#get_employee.GNTrained#</span>
            </cfif>             
            </li>
            </ul>
        </div>
    </div>
</li>
</cfloop>
</cfoutput>

查询代码如下:

<cffile action="read" file="#ExpandPath('#application.root#cf_test/employeeDetails.xml')#" variable="myxml">

<cfset mydoc = XmlParse(myxml)>
<cfset apps = mydoc.data.XmlChildren>
<cfset size = ArrayLen(apps)>

<cfset session.employeeDetails = QueryNew("employee_id,employee_name,GNTrained") >
<cfset temp = QueryAddRow(session.employeeDetails, #size#)>

<cfloop index="i" from = "1" to = #size#>
    <cfloop index="x" from="1" to="8">
        <cfset attr_name = REReplace(#mydoc.data.employees[i].XMLChildren[x].xmlName#, "[^a-zA-Z0-9__]", "", "ALL") />
        <cfset temp = QuerySetCell(session.employeeDetails, "#attr_name#", 
            #mydoc.data.employees[i].XMLChildren[x].xmlText#, #i#)>
    </cfloop>     
</cfloop>

<cfcatch>Error loading</cfcatch>
</cftry>

</cfoutput>

这是 XML 文件:

<!---- File Name: employeeDetails.xml ---->
<?xml version="1.0" encoding="utf-8" ?>
<data>
<employees>
        <name>John Smith</name>
        <id>1234</id>
        <BBTrained>NO</BBTrained>
        <DEPT>21</DEPT>
        <EXP>12</EXP>
        <current>YES</current>
        <Status>ACTIVE</Status>
        <StateCode>CO122</StateCode>
        <GNTrained>NO</GNTrained>
</employees>
<employees>
        <name>Mary Chapman</name>
        <id>3344</id>
        <BBTrained>YES</BBTrained>
        <DEPT>21</DEPT>
        <EXP>18</EXP>
        <Status>LOA</Status>
        <StateCode>DE255</StateCode>
        <GNTrained>YES</GNTrained>
</employees>
<employees>
        <name>Alex Fisher</name>
        <id>6655</id>
        <BBTrained>NO</BBTrained>
        <DEPT>22</DEPT>
        <EXP>6</EXP>
        <Status>ACTIVE</Status>
        <StateCode>ME255</StateCode>
        <GNTrained>YES</GNTrained>
</employees>
</data>

更新代码 - 现在包括 cfloop。 (4/20/16)

**解决方案:**在 SpliFF 的帮助下,我找到了问题所在。说真的,这是我遇到过的最简单的修复方法之一。在查询页面的以下代码中:

我需要将“8”更改为“9”以说明新元素。是的……真的是那么小的变化。 感叹

您在构建查询时仅将 temp 设置为第 1 行,因为您的 QueryAddRow 在循环之外。您需要它指向每个 XML child:

上的当前行
<cfloop index="i" from = "1" to = #size#>
    <cfset temp = QueryAddRow(session.employeeDetails)>
    <cfloop index="x" from="1" to="#ArrayLen(mydoc.data.employees[i].XMLChildren)#">
        <cfset attr_name = REReplace(#mydoc.data.employees[i].XMLChildren[x].xmlName#, "[^a-zA-Z0-9__]", "", "ALL") />
        <cfset QuerySetCell(session.employeeDetails, "#attr_name#", 
            #mydoc.data.employees[i].XMLChildren[x].xmlText#, #i#)>
    </cfloop>
</cfloop>