1

私はこれに完全に行き詰まっています。私は常温核融合を十分に理解しておらず、何がうまくいかないのかを知るための答えを見つけることができません.

これが問題の私のcoldfusionスクリプトの一部です。ここでは一般的な名前を使用しています

<cfscript>
    function run() {

        var obj = createObject("java", "com.company.Run");

        var variable1= "string1";
        var variable2= "string2";
        var variable3= "string3";

        obj.init();

        var success = obj.runThis(variable1, variable2, variable3); <-- failing here
        return success;
    }
</cfscript>
<cfset success = run()>
<cfoutput>SUCCESS? #success#</cfoutput>

これがアクセスした Java コードは jar 内にあり、コンパイルされ、そのクラス内の単純なメソッドに対して機能します。たとえば、coldfusion スクリプトの下にある Java コードを使用して、これを行うことができます。問題は 1 つもありません。

<cfscript>
    function run() {

        var obj = createObject("java", "com.company.Run");

        var variable= "string";

        obj.init();

        var success = obj.print(variable); <-- failing here
        return success;
    }
</cfscript>
<cfset success = run()>
<cfoutput>SUCCESS? #success#</cfoutput>


public static String print(String input) {
    return input;
}

私が実行しようとしているのは、この種のアイデアを備えた上記の最初の常温核融合スクリプトです。このクラス内では、別のクラスからオブジェクトを構築し、そのオブジェクトから文字列を返すメソッドを実行する「runThis」を実行しています。これらは両方とも同じ jar 内にあるため、まったく同じコードに対して junit テストのみを実行すると、すべてアクセス可能で正常に実行されるはずです。ここでの問題は、coldfusion にプルしてそこで実行することです。

public class Run {
public Run() {

    }
public String runThis(String variable1, String variable1, String variable3) throws Exception {

        try {
            MyObject object= new MyObject (variable1, variable2, variable3);
            return object.execute();
        } catch (Exception e) {
            return "error";
        }
    }
}

私が受け取っているエラー:

"Error","http-bio-8500-exec-7","10/08/14","10:47:13",,"javax/ws/rs/WebApplicationException The specific sequence of files included or processed is: C:\ColdFusion11\cfusion\wwwroot\company\response.cfm, line: 77 "
java.lang.NoClassDefFoundError: javax/ws/rs/WebApplicationException
    at com.company.Run.runThis(Run.java:21)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at coldfusion.runtime.java.JavaProxy.invoke(JavaProxy.java:97)
    at coldfusion.runtime.CfJspPage._invoke(CfJspPage.java:2483)
    at cfresponse2ecfm1522673216$funcRUN.runFunction(C:\ColdFusion11\cfusion\wwwroot\company\response.cfm:77)
    at coldfusion.runtime.UDFMethod.invoke(UDFMethod.java:487)
    at coldfusion.runtime.UDFMethod$ArgumentCollectionFilter.invoke(UDFMethod.java:383)
    at coldfusion.filter.FunctionAccessFilter.invoke(FunctionAccessFilter.java:95)
    at coldfusion.runtime.UDFMethod.runFilterChain(UDFMethod.java:334)
    at coldfusion.runtime.UDFMethod.invoke(UDFMethod.java:231)
    at coldfusion.runtime.CfJspPage._invokeUDF(CfJspPage.java:2840)
    at cfresponse2ecfm1522673216.runPage(C:\ColdFusion11\cfusion\wwwroot\company\response.cfm:82)
    at coldfusion.runtime.CfJspPage.invoke(CfJspPage.java:246)
    at coldfusion.tagext.lang.IncludeTag.handlePageInvoke(IncludeTag.java:734)
    at coldfusion.tagext.lang.IncludeTag.doStartTag(IncludeTag.java:570)
    at coldfusion.filter.CfincludeFilter.invoke(CfincludeFilter.java:65)
    at coldfusion.filter.IpFilter.invoke(IpFilter.java:45)
    at coldfusion.filter.ApplicationFilter.invoke(ApplicationFilter.java:487)
    at coldfusion.filter.RequestMonitorFilter.invoke(RequestMonitorFilter.java:42)
    at coldfusion.filter.MonitoringFilter.invoke(MonitoringFilter.java:40)
    at coldfusion.filter.PathFilter.invoke(PathFilter.java:141)
    at coldfusion.filter.ExceptionFilter.invoke(ExceptionFilter.java:94)
    at coldfusion.filter.ClientScopePersistenceFilter.invoke(ClientScopePersistenceFilter.java:28)
    at coldfusion.filter.BrowserFilter.invoke(BrowserFilter.java:38)
    at coldfusion.filter.NoCacheFilter.invoke(NoCacheFilter.java:58)
    at coldfusion.filter.GlobalsFilter.invoke(GlobalsFilter.java:38)
    at coldfusion.filter.DatasourceFilter.invoke(DatasourceFilter.java:22)
    at coldfusion.filter.CachingFilter.invoke(CachingFilter.java:62)
    at coldfusion.CfmServlet.service(CfmServlet.java:219)
    at coldfusion.bootstrap.BootstrapServlet.service(BootstrapServlet.java:89)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
    at coldfusion.monitor.event.MonitoringServletFilter.doFilter(MonitoringServletFilter.java:42)
    at coldfusion.bootstrap.BootstrapFilter.doFilter(BootstrapFilter.java:46)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
    at coldfusion.inspect.weinre.MobileDeviceDomInspectionFilter.doFilter(MobileDeviceDomInspectionFilter.java:121)
    at coldfusion.bootstrap.BootstrapFilter.doFilter(BootstrapFilter.java:46)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:501)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:422)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1040)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:607)
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:313)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)
Caused by: java.lang.ClassNotFoundException: javax.ws.rs.WebApplicationException
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1718)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1569)
    ... 56 more

MyObject オブジェクトを正しくインスタンス化していないか、コードが失敗していると感じています。それを削除すると、コードが機能するように見えますが、明らかに、私が目指しているものは得られません。

4

2 に答える 2

1

jar に 1 つ以上の依存関係が欠落していると強く疑われます。

現時点では CF11 にアクセスできませんが、プロジェクトを jar にエクスポートすることで同様のトレースを再現できますが、必要なクラスの一部を省略しています。たとえば、2 つのクラスのダミー バージョンを作成しました (以下を参照)。3 番目のクラス -MyObjectを参照していることに注意してください。次に、すべてを jar にエクスポートしましたが、意図的に除外しました。YetAnotherClassYetAnotherClass

テスト コードを使用して、 を正常に呼び出すことができますprint()。ただし、コードが呼び出すrunThis()と、同様のエラーが発生します。A NoClassDefFoundError、原因ClassNotFoundException- 瓶に入れるのを怠ったため。

注、私はCF10でテストしています。

CFコード

<cfscript>
    obj = createObject("java", "com.company.Run");
    result = obj.print("testing...");
    writeDump(result);

    obj.init();
    result = obj.runThis("john", "doe", "atlanta");
    writeDump(result);
</cfscript>

エラー スタック トレース:

java.lang.NoClassDefFoundError: com/othercompany/YetAnotherClass
    at com.company.MyObject.<init>(MyObject.java:10)
    at com.company.Run.runThis(Run.java:9)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    ......
    at java.lang.Thread.run(Thread.java:662)
Caused by: java.lang.ClassNotFoundException: com.othercompany.YetAnotherClass
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1688)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1533)

走る

package com.company;

public class Run {

    public Run() {
    }

    public String runThis(String var1, String var2, String var3) throws Exception {
        MyObject object= new MyObject(var1, var2, var3);
        return object.execute();
    }

    public static String print(String input) {
        return input;
    }
}

MyObject

package com.company;

import java.util.Date;
import com.othercompany.YetAnotherClass;

public class MyObject {

    private YetAnotherClass other;
    public MyObject(String first, String last, String city) {
        this.other = new YetAnotherClass();
    }

    public String execute() {
        return "Method execute invoked at "+ new Date();
    }
}

YetAnotherClass (別パッケージ)

package com.othercompany;

public class YetAnotherClass {

    public YetAnotherClass() {
        // do nothing to keep it simple
    }

}
于 2014-10-08T20:47:41.830 に答える