来自Coldfusion管理员的电子邮件错误报告

时间:2017-05-01 21:04:25

标签: logging coldfusion

我们运行的应用程序没有很好的错误电子邮件通知,但最终会出现在Coldfusion的application.log中。 Coldfusion是否有办法在此文件更改时发送电子邮件,这是一个错误(不仅仅是会话轮换或其他信息级别的日志条目)?

1 个答案:

答案 0 :(得分:1)

这不是解决方案,但它可能会让你朝着正确的方向前进。我没有在CF上查看错误日志文件和发送电子邮件 - 您想要设置一个计划任务来检查它。但我会说500型服务器错误是我身上的一个棘手因为IIS并不想将错误传递给CF来处理。这是我用来打开错误日志的页面,到底部并向后工作以显示500型错误。它不是非常强大,但它确实让我回顾了我以前没有得到通知的错误:

<cffile action="read" variable="exceptionLog" file="C:\ColdFusion10\cfusion\logs\exception.log">
<cfparam name="form.goBack" default="0">
<cfparam name="form.showHowMany" default="10">
<cfif structKeyExists(url,"goback") and  structKeyExists(url,"showHowMany")>
    <cfset form.goBack=url.goback>
    <cfset form.showHowMany=url.showHowMany>
</cfif>
<cfoutput>
<cfset bodyAttr=' style="font-family:arial;font-size:10pt;font-weight:normal;"'>
<cfinclude template="../html_header.cfm">
<form name="f" id="f" action="cfexception.cfm" method="post">
Go back<input name="goBack" id="goBack" class="intgr" size="4" value="#form.goBack#"> &nbsp;
Show how many<input name="showHowMany" id="showHowMany" class="intgr" size="4" value="#form.showHowMany#"> &nbsp;
<input type="button" value="Go" id="btnSbmt">
</form>
<script type="text/javascript">
$(document).ready(function(){
    $("input.intgr").keyup(function (e) { // Filter non-digits from input value.
        if (/\D/g.test($(this).val())) $(this).val($(this).val().replace(/\D/g, ''));
    });
    $("##btnSbmt").click(function(){
        if($("##goBack").val()=="" || $("##goBack").val()=="") alert("Both input fields (Go back and Show how many) are required.");
        else $("##f").submit();
    })
});
</script>
</cfoutput>
<cfset raText=listToArray(exceptionLog,chr(10))>
<cfset raErr=[]>
<cfset goneBack=0>
<cfset showHowMany=1>
<cfoutput>
<cfloop from="#arrayLen(raText)#" to="1" step="-1" index="idxErr">
    <cfif findNoCase("error",raText[idxErr])>
        <cfif goneBack lte form.goBack><cfset goneBack=goneBack+1><!--- display nothing, incr counter --->
        <cfelse><!--- now that we've gone far enough back, start displaying --->
            <strong>#showHowMany#</strong>#raText[idxErr]# <cfif idxErr neq (arrayLen(raText)-1)><br />#raText[idxErr+1]#</cfif><br /><br />
            <cfif int(showHowMany) lte int(form.showHowMany)-1><cfset showHowMany=showHowMany+1>
            <cfelse><cfbreak><!--- incr counter up to number user entered (or default) and then bail out --->
            </cfif>
        </cfif>
    </cfif>
</cfloop>
</body>
</html>
</cfoutput>