Вопрос

У меня есть следующий Applicaton.cfc

<cffunction name="onApplicationStart" access="public" returntype="Object">
 <cfset application.dsn = "myDB" />
 <cfset application.userGateway = createObject("component","cfc.UserGateway").init(dsn = application.dsn) />
 <cfreturn this />
</cffunction>

Это мой компонент UserGateway.cfc.

<cfcomponent name="UserGateway" hint="Data Access Object" output="false">
 <cffunction name="init" access="public" hint="constructor" output="false" returntype="UserGateway">
  <cfargument name="dsn" type="string" required="true" hint="datasource" />
   <cfset variables.dsn = arguments.dsn />
 <cfreturn this />
 </cffunction>

 <cffunction name="getUsers" access="public" output="false" returntype="query">
  <cfargument name="id" type="String" default="" />
  <cfargument name="name" type="String" default="" />
  <cfargument name="district" type="String" default="" />
  <cfset var qQuery = "" />
  <cfquery name="qQuery" datasource="#variables.dsn#">
    SELECT *
    FROM A INNER JOIN B
    ON A.X = B.Y
    WHERE 0=0
    <cfif "#arguments.id#" neq "">
     AND B.X LIKE '%#arguments.id#%'
    </cfif>
    <cfif "#arguments.name#" neq "">
     AND (A.I LIKE '#arguments.name#%'
      OR A.J LIKE '#arguments.name#%')
    </cfif>
    <cfif "#arguments.district#" neq "">
     AND A.O LIKE '%#arguments.district#%'
    </cfif>
  </cfquery>
  <cfreturn qQuery />
 </cffunction>
</cfcomponent>

И это мой самый.cfm

<cfform action="same.cfm" method="post" preservedata="true">
 <p>ID: <cfinput type="text" name="id" size="20" maxlength="4" /></p>
 <p>Name: <cfinput type="text" name="name" size="20" maxlength="64" /></p>
 <p>District: <cfinput type="text" name="district" size="20" maxlength="3" /></p>
 <p><cfinput class="button" type="submit" name="submit" value="OK" /></p>
</cfform>

<cfif IsDefined("form.submit")>
 <table>
  <cfset qQuery = application.userGateway.getUsers(id = form.id, name = form.name, district = form.district) />
  <cfoutput query="qQuery">
   <tr>
    <td>#qQuery.currentRow#.</a></td>
    <td>#qQuery.I#</a></td>
    <td>#qQuery.M#, #qQuery.N#</a></td>
    <td>#qQuery.D#</a></td>
   </tr>
  </cfoutput>
 </table>
</cfif>

Я получаю следующую ошибку:

Element USERGATEWAY is undefined in a Java object of type class [Ljava.lang.String;.
The error occurred in same.cfm: line 10

Что мне не хватает?

-------------------------------------------
-------------------------------------------

Когда я делаю это таким образом, это работает.это должно быть что-то тривиальное, чего я, как новичок, не понимаю.

Приложение.cfc

<cffunction name="onRequestStart" access="public" returntype="String">
 <cfset request.dsn="myDB" />
</cffunction>

тот же.cfm

    <cfset userGateway = createObject("component","cfc.UserGateway").init(dsn = request.dsn) />
    <cfset qGetUser = userGateway.getUsers(id = form.personid, name = form.name, district = form.district) />
  <cfoutput query="qQuery">
   <tr>
    <td>#qQuery.currentRow#.</a></td>
    <td>#qQuery.I#</a></td>
    <td>#qQuery.M#, #qQuery.N#</a></td>
    <td>#qQuery.D#</a></td>
   </tr>
  </cfoutput>
Это было полезно?

Решение

Я вижу здесь две вещи неправильно:

Во-первых, насколько я понимаю, использование области «this» в application.cfc не работает так, как вы пытаетесь это сделать.Присвоив объекту userGateway значение области приложения, он становится глобально доступным и действительно делает ненужным возврат его в onApplicationStart.В файле application.cfc измените тип возврата на логический и просто верните true;это должно решить вашу проблему.

Во-вторых, если в вашем запросе ваши аргументы и условия не являются прокси того, что у вас есть на самом деле, вы ссылаетесь на аргумент «personid», которого не существует в вашей функции.При вызове этого запроса через вызов объекта в области приложения я видел, что ошибка строки Java возвращалась как ошибка раньше, в отличие от ошибки CF Friendly «переменная не существует».

Другие советы

В том же.cfm запустите это:

<cfset OnApplicationStart()>

Затем обновите страницу еще раз.Теперь это работает?

<cffunction name="init" access="public" hint="constructor" output="false" returntype="UserGateway">

должно быть:

<cffunction name="init" access="public" hint="constructor" output="false" returntype="Any">

Следующая строка неверна:

<cfset application.userGateway = createObject("component","cfc.UserGateway").init(dsn = application.dsn) />

Он должен читать без "CFC". В начале имени компонента, которое вы хотите:

<cfset application.userGateway = createObject("component","UserGateway").init(dsn = application.dsn) />

Кроме того, дважды проверьте остальную часть файла application.cfc на правильность, так как что-то работает неправильно, поскольку вы должны были увидеть эту ошибку о том, что не удалось найти компонент cfc.UserGateway.

РЕДАКТИРОВАТЬ:Еще я забыл упомянуть, что onApplicationStart не нужно ничего возвращать.Тип возвращаемого значения должен быть пустым и не <return this/> необходимо присутствовать.

Может быть это:

http://kathylynnward.wordpress.com/2008/04/14/lyra-captcha-error-element-captcha-is-undefined-in-a-java-object-of-type-class-ljavalangstring/

(Я уточню пост, если в этом проблема)

перезапустите службу CF, это может помочь.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top