1

このコードは機能せず、エラーも発生しないため、誰かがこのコードの何が問題なのか教えてくれるかどうか疑問に思っていました。

このコードを使用して、誰かがリンクを押すたびに DB テーブルを更新するコンポーネントにアクセスしようとしています。

<cfajaxproxy bind="url:http://www.example.com/admin/CRM/linktracking.cfc" />
<cfscript>
    SSLtype = (CGI.HTTPS EQ 'off')?'http://':'https://';
</cfscript>

<cfset domainname = CGI.SERVER_NAME>
<cfset domainURL = SSLtype&CGI.SERVER_NAME&CGI.SCRIPT_NAME&'?'&CGI.QUERY_STRING>

    <script>    
        function insertTracking(href) {
        var instance = new ajaxjsclass();
        instance.setCallbackHandler();
        <cfoutput>
            instance.insertTrack(href,'#surveymain.contactid#','#domainname#','#domainURL#');
        </cfoutput>
        }       
    </script> 

これは私がアクセスしようとしているコンポーネントです。

<cfcomponent>

<cffunction name="insertTrack" access="remote" returntype="void" >
<cfargument name="clickedURL" required="yes">
<cfargument name="contactid" required="yes">
<cfargument name="domainName" required="yes">
<cfargument name="domainURL" required="yes">

<cfquery name="q_inserttrack" datasource="dpsigweb">
update survey_tracking
set surveystarted = <cfqueryparam value="#now()#" cfsqltype="CF_SQL_TIMESTAMP">
where contactid= '#contactid#'
</cfquery>


<cfif ARGUMENTS.contactid NEQ ''>
    <cfscript>
        additionalInfo = '<b>Clicked URL</b> - <i>#ARGUMENTS.clickedURL#</i><br><br><b>From Site</b> - <i>#ARGUMENTS.domainURL#</i>';
        gaCFC = CreateObject("component","mod_sigweb.components.guestaccount");
        gaCFC.AddCorrespondenceCurDoctorProcedureRemote(
            functionPassword = 'password',
            contactid = '#ARGUMENTS.contactid#',
            theMessage = additionalInfo,
            statustype = 'Survey Started',
            contactresult ='Survey Started'
            );
    </cfscript>
</cfif>

</cffunction>
</cfcomponent>  

これは、私が関数にアクセスしようとしている場所です:

<a href="http://dev.example.com/surveys/survey.cfm?id=#id#&contactid=#contactid#&doctorid=#doctorid#" onClick="insertTracking(this.href)" >

<cfajaxproxy>タグに構文エラーがあるのではないかと疑っていますが、リンクを押してもエラーは発生しません。

私はこれに変更cfajaxproxyします

<cfajaxproxy cfc="linktracking" jsclassname="ajaxjsclass"  />

しかし、まだ機能が機能していないようです。コンポーネントと cfm ファイルを同じフォルダーに移動しましたが、それでも機能しません。

編集: このコードを電子メール テンプレートで送信していることを忘れていました。それが何らかの形で重要かどうかはわかりません。ローカルでテストしているテスト ページを作成しましたが、コードは問題なく動作します。そのために変更する必要がある場合は、お知らせください

4

1 に答える 1

0

解決策が見つかりました。ユーザーがリンクを押してページを開くと、リンクからではなくそこからクエリが実行されるように、更新クエリ コードをページに直接配置しました。

上記のコードは正常に機能していますが、ページを電子メールでユーザーに送信していたため、問題が発生しました。少なくともこれは私が疑っていることです。

于 2012-09-13T20:04:53.830 に答える