Data binding Coldfusion:需要禁用或阻止“调用CFC时出错-服务器出错”错误弹出消息

Data binding Coldfusion:需要禁用或阻止“调用CFC时出错-服务器出错”错误弹出消息,data-binding,coldfusion,cfc,server-error,cfgrid,Data Binding,Coldfusion,Cfc,Server Error,Cfgrid,我使用.cfm和.cfc在.cfm上编辑cfgrid中的数据,它可以工作,但有10%的时间我会收到以下错误消息: 调用CFC/test/editCFgrid.CFC时出错:内部服务器错误 我尝试使用调试建议,但是没有成功 以下是CFM代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> &

我使用.cfm和.cfc在.cfm上编辑cfgrid中的数据,它可以工作,但有10%的时间我会收到以下错误消息:

调用CFC/test/editCFgrid.CFC时出错:内部服务器错误

我尝试使用调试建议,但是没有成功

以下是CFM代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
</head>

<body>
<cfform name="artistform">
            <cfgrid format="html" name="artistgrid" pagesize=11
            striperows="yes" 
            bind="cfc:editCFgrid.getArtists({cfgridpage},{cfgridpagesize},{cfgridsortcolumn},{cfgridsortdirection})"
            delete="yes" insert="yes" selectmode="edit"
            onchange="cfc:editCFgrid.saveArtist({cfgridaction},{cfgridrow},{cfgridchanged})">
                <cfgridcolumn name="firstname" header="First Name" />
                <cfgridcolumn name="lastname" header="Last Name" />
                <cfgridcolumn name="address" header="Address" />
                <cfgridcolumn name="city" header="City" />
                <cfgridcolumn name="state" header="State" />
                <cfgridcolumn name="postalcode" header="Postal Code" />
                <cfgridcolumn name="email" header="Email" />
                <cfgridcolumn name="phone" header="Phone" />
                <cfgridcolumn name="fax" header="Fax" />
                <cfgridcolumn name="thepassword" header="Password" />
</cfgrid>
</cfform>
</body>
</html>
以下是CFC代码:

<cfcomponent output="FALSE">
    <cffunction name="getArtists" hint="I extract artists from the database" access="remote" output="FALSE" returntype="struct">
        <cfargument name="page" required="TRUE" hint="the page the grid is on" />
        <cfargument name="pagesize" required="TRUE" hint="records displayed per page" />
        <cfargument name="gridsortcolumn" required="TRUE" hint="selected column to sort" />
        <cfargument name="gridsortdirection" required="TRUE" hint="the sort direction" />
        <cfset var qArtists = "" />

        <cfif arguments.gridsortcolumn eq "">
            <cfset arguments.gridsortcolumn = "lastname" />
            <cfset arguments.gridsortdirection = "asc" />
        </cfif>

            <cfquery name="qArtists" datasource="test_database">
                SELECT *
                FROM Artists
                ORDER BY #arguments.gridsortcolumn# #arguments.gridsortdirection#
            </cfquery>

        <cfreturn QueryConvertForGrid( qArtists, arguments.page, arguments.pagesize ) />
    </cffunction>

    <cffunction name="saveArtist" type="any" hint="I insert, update or delete an artist" access="remote" output="FALSE" returntype="void">
        <cfargument name="gridaction" type="any" required="TRUE" hint="I for insert, U for update and D for delete" />
        <cfargument name="gridrow" type="any" required="TRUE" hint="the rows being inserted or updated" />
        <cfargument name="gridchanged" type="any" hint="the changes" />
        <cfset var qInsertArtist = "" />
        <cfset var qUpdateArtist = "" />
        <cfset var qDeleteArtist = "" />

        <cfif IsStruct( arguments.gridrow ) and IsStruct( arguments.gridchanged )>
            <cfif arguments.gridaction eq "I">
                <cfquery name="qInsertArtist" datasource="test_database">
                    INSERT INTO Artists
                        (firstname, lastname, address, city, state, postalcode, email, phone, fax, thepassword)
                    VALUES
                        (<cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.firstname#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.lastname#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.address#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.city#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.state#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.postalcode#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.email#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.phone#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.fax#" />, 
                        <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.gridrow.thepassword#" />)
                </cfquery>

            <cfelseif arguments.gridaction eq "U">
                <cfset var colname = StructKeyList( arguments.gridchanged ) />
                <cfset var value = StructFind( arguments.gridchanged, colname ) />
                    <cfquery name="qUpdateArtist" datasource="test_database">
                        UPDATE Artists
                        SET #colname# = <cfqueryparam value="#value#" />
                        WHERE artistid = <cfqueryparam cfsqltype="cf_sql_integer" value="#arguments.gridrow.artistid#" />
                    </cfquery>

            <cfelseif arguments.gridaction eq "D">
                <cfquery name="qDeleteArtist" datasource="test_database">
                DELETE FROM Artists 
                WHERE artistid = <cfqueryparam cfsqltype="cf_sql_integer" value="#arguments.gridrow.artistid#" />
                </cfquery>
            </cfif>
        </cfif>
    </cffunction>
</cfcomponent>
每个函数编辑、插入、删除等都可以工作,但它会随机生成错误。最终,我正在寻找一个可以忽略/阻止/确定错误消息的代码,这样用户就不会看到它


任何帮助都将不胜感激!我花了整整9个小时在谷歌上搜索答案,但我没有找到任何答案。我没有访问CF管理日志的权限,我只是一个普通的开发人员。谢谢

Google chrome、firefox中的firebug、IE开发者工具都可以帮你解决这个问题

在google chrome my preference中,右键单击页面>检查元素。然后转到“网络”选项卡。你必须刷新你的网页。然后,您将在文件列表中看到您的cfc,可能是红色的。右键单击>在新选项卡中打开,您将直接打开cfc,并调用所有参数。然后,您应该能够看到您的错误


没有忽略/阻止/确定。您需要修复错误。

可能是超时或SQL错误。要获取完整错误,请使用:cferror,此标记显示的完整调试信息优于我通过邮件发送给我的调试服务器信息:

将此文件放在您的应用程序文件中:

<cferror type="exception" template="error.cfm" />
<cferror type="request" template="error.cfm" />
使用以下内容创建error.cfm文件:

"Error message"
<cfsavecontent variable="errorContent">
<cfoutput>
An error occurred: http://#cgi.server_name##cgi.script_name#?#cgi.query_string#<br />
Time: #dateFormat(now(), "short")# #timeFormat(now(), "short")#<br />

<h2>Error:</h2>
<cfdump var="#error#" label="Error">
<h2>Form:</h2>
<cfdump var="#form#" label="Form">
<h2>URL:</h2>
<cfdump var="#url#" label="URL">
<h2>SESSION:</h2>
<cfdump var="#SESSION#" label="SESSION">

</cfoutput>
</cfsavecontent>

<cfmail to="mail@mymail.com" from="mail@mymail.com" subject="Error on #cgi.server_name#: #error.message#" type="html">
#errorContent#
</cfmail>

有一种方法可以使用以下脚本忽略/阻止/确定错误消息:

<script>ColdFusion.setGlobalErrorHandler(function (error) 
{mygrid = ColdFusion.Grid.refresh ('artistgrid', false);
}
);
</script>
在CFM文件中插入此脚本,就可以开始了!由于我遇到的错误没有影响编辑cfgrid单元格的功能,因此弹出消息比任何其他消息都更令人讨厌。希望这个解决方案能帮助其他人

您不需要在脚本中使用“Grid.refresh”命令,您可以使用任何需要的命令


感谢所有试图回答我问题的人

试着设置你自己的全局错误处理程序——如果投票反对的人解释了他们决定这么做的原因,那就太好了。简单地投反对票是没有多大帮助的。投票支持它,因为这个问题没有任何问题,稍加修饰也无济于事。您应该能够通过浏览错误请求的URL来查看实际错误。完整的URL应该显示在Firebug网络面板中。如果做不到这一点,它将出现在异常日志、应用程序日志或退出日志中,这取决于我从未完全确定的各种情况。发布实际的错误消息,我们就可以知道发生了什么。。本质上,启用健壮的调试、检查日志、使用cfinvoke重复调用方法并记录这些结果。希望这能帮助您了解情况。感谢@AdamCameron投票支持本期。这是我从Firebug得到的错误:NetworkError:500服务器错误-你好,Steve。。。首先,感谢您抽出时间回答我的问题。尽管这有点帮助,但它并不能解决问题。第二,我想纠正你。。。有一种方法可以忽略/阻止/确定以下脚本“查看下面的我的解决方案”的问题您正在掩盖错误。我决不会把这个错误推荐给其他程序员。我很高兴这对您有效,但这是我见过的最糟糕的解决方案。Steve,您无法解决我的编码问题,并且理解问题是由于我无法编辑的系统JS之间的冲突造成的。冲突不允许我的代码完成它的工作,它只是在编辑单元格后随机弹出一条错误消息,这是不必要的。另外,如果您无法读取我的请求,我正在寻找一个可以忽略/阻止/确定错误消息的代码,这样用户就看不到它,而我的代码正适合这种需要。你的回答使我误以为没有这样的密码。如果你没有解决办法,或者没有帮助的方法,请找其他人。泰