3

我想将自动注入的对象替换log为 typeorg.apache.commons.logging.Log的对象org.slf4j.Logger,以便我可以在 Logback 中正确使用它。

因此,我需要创建一个...Transformer类(用 Java 编写)——这就是我在“grails-user”邮件列表中从 Graeme Rocher 那里得到的。我也知道我必须将这个...Transformer类打包到一个插件中,并使其成为一个 *.jar 存档,我可以将其加载lib/到插件的文件夹中。但是我想我在这里做错了,因为我有这个类,以及一个META-INF包含该MANIFEST.MF文件的文件夹以及另一个文件夹,该文件夹services包含以下文件,该文件org.codehaus.groovy.transform.ASTTransformation仅包含一个字符串:类的规范名称...Transformer

现在,如果我尝试做grails clean一切都很好,但是如果我尝试运行grails package-plugin控制台会出现java.lang.ClassNotFoundException.

从 Stacktrace 剪辑:

| Packaging Grails application...

| Error Fatal error during compilation org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:

Could not instantiate global transform class my.package.ast.LoggingTransformation specified at jar:file:/C:/Source/MyGrailsAST/lib/replace-logging-logback-ast.jar!/META-INF/services/org.codehaus.groovy.transform.ASTTransformation  because of exception java.lang.ClassNotFoundException: my.package.ast.LoggingTransformation

1 error

org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:

Could not instantiate global transform class my.package.ast.LoggingTransformation specified at jar:file:/C:/Source/MyGrailsAST/lib/replace-logging-logback-ast.jar!/META-INF/services/org.codehaus.groovy.transform.ASTTransformation  because of exception java.lang.ClassNotFoundException: my.package.ast.LoggingTransformation

有没有人对处理 Grails 插件有一些经验,AstTransformer可以给我一些建议吗?有没有我至今没见过的好教程?

请告诉我 ;)

4

1 回答 1

1

因此,经过一些研究、浏览并最终在 Grails 邮件列表中询问(请参阅邮件列表存档:http ://grails.1312388.n4.nabble.com/Grails-user-f1312389.html ,我找到了解决方案。

我的目标是创建一个Globals ASTTransformation,将一个org.slf4j.Logger对象而不是通常的org.apache.commons.logging.Log对象注入到每个 Artefact 类中而无需注释。

所以,这里是步骤:

我创建了类似于https://github.com/grails/grails-core/blob/master/grails-logging/src/main/groovy/org/codehaus/groovy/grails/compiler/logging/LoggingTransformer.java的 Java 类但是用我自己的org.slf4j.Logger对象实现。将 Java.class 放在以下包下至关重要:org.codehaus.groovy.grails.compileras

Grails 会扫描此包中带有 @AstTransformer 注释的类。(格雷姆·罗彻

MANIFEST.MF并将其与文件夹中的文件一起打包到 JAR中META-INF/正如Graeme RocherMETA-INF/services所说,不需要包含所有内容的目录:

你不需要 META-INF/services 的东西,我会删除它,因为它可能会使事情复杂化。

所以,我猜这个陈述与我的具体问题更相关,因为我@AstTransformer的插件中只有一个类,但这只是一个猜测。而且我还没有搜索有关此主题的更多信息。也许这里需要这个的其他一些开发人员可以做一些研究并在这个线程中分享他的解决方案......

JAR 应该被导入插件并放在lib/目录下。在这之后你应该可以做grails clean,grails compilegrails package-plugin

如果您想像log我一样替换实现,您应该从指定项目的类路径中排除grails-logginggrails-plugin-log4jJAR。这是在BuildConfig.groovy文件中完成的:

inherits("global") {
  excludes "grails-plugin-log4j", "grails-logging"
}

现在安装你的插件grails install-plugin \path\to\plugin.zip,一切都应该按预期工作。

希望这可以帮助...

于 2012-12-12T15:44:35.850 回答