我想用类型为log
的对象替换自动注入的org.apache.commons.logging.Log
对象,类型为org.slf4j.Logger
,以便我可以正确使用它与Logback。
因此,我需要创建一个...Transformer
类(用Java编写) - 这是我从Graeme Rocher那里得到的#34; grails-user"邮件列表。我也知道我必须在插件中打包这个...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
有没有人对使用AstTransformer
处理的Grails插件有一些经验,可以给我一些建议吗?那里有一个很好的教程,到目前为止我还没有看到过吗?
请让我知道;)
答案 0 :(得分: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.compiler
为
Grails扫描在此包中使用@AstTransformer注释的类。 ( Graeme Rocher )
并将其与MANIFEST.MF
文件夹中的META-INF/
文件一起打包到JAR中。不需要META-INF/services
目录及其所有内容,因为 Graeme Rocher 声明:
你不需要META-INF /服务的东西,我会删除它,因为它可能使问题复杂化。
所以,我猜这个陈述与我的具体问题更相关,因为我的插件中只有一个@AstTransformer
类,但这只是猜测。我没有搜索关于这个主题的进一步信息。 也许其他一些需要这个的开发人员可以做一些研究并在这个帖子中分享他的解决方案......
应将JAR导入插件并放在lib/
目录下。在此之后,您应该能够grails clean
,grails compile
和grails package-plugin
。
如果要像我一样替换log
实现,则应从指定项目的类路径中排除grails-logging
和grails-plugin-log4j
JAR。这是在BuildConfig.groovy
文件中完成的:
inherits("global") {
excludes "grails-plugin-log4j", "grails-logging"
}
现在安装你的插件grails install-plugin \path\to\plugin.zip
,并且everthing应该按预期工作。
希望这会有所帮助......