- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们将 CXF 用于 SOAP 客户端,并使用 cxf-codegen-plugin (wsdl2java) maven 插件(我认为这只是 wsd2java 的包装器)生成客户端。我们通常习惯在每次生成后给每个服务添加@Logging(pretty=true)注解。
有没有办法以某种方式自动生成此注释?
最佳答案
不知道是否有任何插件可以更改 Log 语句,但我想最简单的方法是创建将在 cxf-code gen 插件之后运行的插件。
如果您使用 Eclipse,请遵循以下步骤。
选择新项目->maven项目->并在新maven项目中选择原型(prototype)
groupId:org.apache.maven.achetypes
artifactId:maven-achetype-plugin
添加 commons-io dependentecny 并将版本更改为 1.0.0.0
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
编辑 MyMojo.java
package com.kp.plugin.logcodegen;
import java.io.File;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.io.FileUtils;
import org.apache.commons.io.filefilter.FileFileFilter;
import org.apache.commons.io.filefilter.TrueFileFilter;
import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
@Mojo(name = "code-gen", defaultPhase = LifecyclePhase.GENERATE_SOURCES)
public class MyMojo extends AbstractMojo {
@Parameter(defaultValue = "${project.build.directory}")
private File outputDirectory;
@Parameter(defaultValue = "${basedir}")
private File baseDir;
@Parameter(defaultValue = "src/main/java", property = "sourceDirecory")
private String sourceDirectory;
@Parameter(defaultValue = "", property = "packageNames")
private String packageNames;
@Parameter(defaultValue = "", property = "addImport")
private String addImport;
@Parameter(defaultValue = "", property = "removeImport")
private String removeImport;
@Parameter(defaultValue = "", property = "defineLogInstance")
private String defineLogInstance;
@Parameter(defaultValue = "", property = "removeLogInstance")
private String removeLogInstance;
public void execute() throws MojoExecutionException {
System.out.println("-------------------");
System.out.println("Adding logs to java classes");
System.out.println("--------------------");
System.out.println("Input package is:" + packageNames);
System.out.println("BaseDir is " + baseDir.getAbsolutePath());
StringBuilder sourceDir = new StringBuilder(baseDir.getAbsolutePath());
sourceDir.append("/");
sourceDir.append(sourceDirectory);
if (!packageNames.isEmpty()) {
sourceDir.append("/");
for (final String packageName : packageNames.split(",")) {
String path = sourceDir.toString() + packageName.replaceAll("\\.", "/");
File dest = new File(path);
if (dest.isDirectory()) {
Iterator<File> it = FileUtils.iterateFiles(dest, FileFileFilter.FILE, TrueFileFilter.INSTANCE);
while (it.hasNext()) {
try {
processFile(it.next());
} catch (IOException e) {
e.printStackTrace();
}
}
} else {
System.out.append("Path is not directory " + path);
}
}
} else {
System.out.println("No packages to parse");
}
}
private void processFile(final File file) throws IOException {
List<String> contents = FileUtils.readLines(file);
ListIterator<String> it = contents.listIterator();
String className = "";
while (it.hasNext()) {
String str = it.next();
// Remove import
if (str != null && !str.isEmpty() && str.contains(removeImport)) {
it.remove();
it.add(addImport);
}
if (str != null && !str.isEmpty()) {
Pattern pat = Pattern.compile("\\s*(public|private)\\s+class\\s+(\\w+)");
Matcher matcher = pat.matcher(str);
if (matcher.find()) {
className = matcher.group(2);
}
}
// change the instance
if (str != null && !str.isEmpty() && str.contains(removeLogInstance)) {
it.remove();
it.add(defineLogInstance + className + ".class);");
}
}
FileUtils.writeLines(file, contents, false);
}
}
运行maven安装
现在将插件添加到您的项目中
<pluginManagement>
<plugins>
<plugin>
<groupId>org.eclipse.m2e</groupId>
<artifactId>lifecycle-mapping</artifactId>
<version>1.0.0</version>
<configuration>
<lifecycleMappingMetadata>
<pluginExecutions>
<pluginExecution>
<pluginExecutionFilter>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-codegen-plugin</artifactId>
<versionRange>[2.7,)</versionRange>
<goals>
<goal>wsdl2java</goal>
</goals>
</pluginExecutionFilter>
<action>
<execute />
</action>
</pluginExecution>
<pluginExecution>
<pluginExecutionFilter>
<groupId>com.kp.plugin</groupId>
<artifactId>logcode-gen</artifactId>
<versionRange>[1.0.0.0,)</versionRange>
<goals>
<goal>code-gen</goal>
</goals>
</pluginExecutionFilter>
<action>
<execute />
</action>
</pluginExecution>
</pluginExecutions>
</lifecycleMappingMetadata>
</configuration>
</plugin>
</plugins>
</pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>${maven-compiler.version}</version>
<configuration>
<source>${jdk.version}</source>
<target>${jdk.version}</target>
<encoding></encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-codegen-plugin</artifactId>
<version>${cxf.version}</version>
<executions>
<execution>
<id>generate-sources</id>
<phase>generate-sources</phase>
<configuration>
<sourceRoot>${basedir}/src/main/java</sourceRoot>
<wsdlOptions>
<wsdlOption>
<wsdl>${basedir}/src/main/resources/wsdl/kpws.wsdl</wsdl>
<extraargs>
<extraarg>-impl</extraarg>
</extraargs>
</wsdlOption>
</wsdlOptions>
</configuration>
<goals>
<goal>wsdl2java</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>com.kp.plugin</groupId>
<artifactId>logcode-gen</artifactId>
<version>1.0.0.0</version>
<executions>
<execution>
<id>codegen-resouces</id>
<phase>generate-sources</phase>
<goals>
<goal>code-gen</goal>
</goals>
</execution>
</executions>
<configuration>
<packageNames>com.kp.webservices.services</packageNames>
<addImport>import org.slf4j.Logger;</addImport>
<removeImport>java.util.logging.Logger</removeImport>
<removeLogInstance>private static final Logger LOG</removeLogInstance>
<defineLogInstance>private static final Logger LOG = org.slf4j.LoggerFactory.getLogger(</defineLogInstance>
</configuration>
</plugin>
</plugins>
注意
关于java - CXF:如何使用wsdl2java生成@Logging注释?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25129731/
所以`MKAnnotation's。有趣的东西。 我的问题: 注释的标题和副标题有什么区别?这对注释的视觉组件有何影响? MKPinAnnotationView 和 MKAnnotationView
我正在使用 JBoss 工具将 DB 模式反向工程到 POJO 中。具体来说,我在 hibernatetool ANT 任务中使用了 hbm2java 选项。在 hbm2java 选项下,您可以指定
假设我有这段文字: cat file /* comment */ not a comment /* another comment */ /* delete this * /* multiline
我明白,如果你///在类、字段、方法或属性上方 Visual Studio 将开始为您建立 XML 样式的注释。 但是,我在哪里可以为我的命名空间和/或库添加 XML 注释... 例如: .NET F
int API_VERSION = 21; @TargetApi(API_VERSION)在Android中用于指定该方法/类支持API_VERSION及以下。 我们是否可以镜像类似的东西,指定仅支持
Closed. This question needs to be more focused。它当前不接受答案。
假设我有一个界面如下。 public interface MyInterface{ /** * This method prints hello */ void sayHello();
我已将 Jboss 应用程序迁移到 WebSphere Liberty。我必须删除所有 Jboss 引用库。在这样做的同时,我在某些注释中面临问题。 Jboss 应用程序使用 @SecurityDom
在本教程中,您将了解 JavaScript 注释,为什么要使用它们以及在示例的帮助下如何使用它们。 JavaScript 注释是程序员可以添加的提示,以使代码更易于阅读和理解。JavaScri
我正在建立一个博客,为了发表评论,我有这个 CSS。 #comments { position:absolute; border: 1px solid #900; border-width: 1
我正在尝试在单元格中插入评论。我正在尝试按照代码进行评论,但它没有在创建的 excel 中显示评论。我正在创建 .xls 扩展名。 $objPHPExcel->getActiveSheet()->ge
我正在使用 TS 在 MarionetteJS 上编写项目,我想使用注释来注册路由。例如: @Controller class SomeController { @RouteMapping("so
我有一个应用程序可以在页面上生成大量注释。用户可以单击页面上的任意位置以创建快速注释(例如 Acrobat Pro)可以在一般 中使用一些 javascript 行添加和删除这些注释
是否有 JavaScript 注释? 当然 JavaScript 没有它们,但是是否有额外的库或建议的语言扩展,例如 @type {folder.otherjsmodule.foo} function
Java 中注解的目的是什么?我有一个模糊的想法,认为它们介于注释和实际代码之间。它们在运行时会影响程序吗? 它们的典型用法是什么? 它们是 Java 独有的吗?有 C++ 等价物吗? 最佳答案 注解
其实我们在 Ruby 基础语法 已经比较详细的介绍了 Ruby 语言中的注释 Ruby 解释器会忽略注释语句 注释会对 Ruby 解释器隐藏一行,或者一行的一部分,或者若干行。 Ruby 中的注
我正在 try catch VBA 注释。到目前为止,我有以下内容 '[^";]+\Z 它捕获以单引号开头但在字符串结尾之前不包含任何双引号的任何内容。即它不会匹配双引号字符串中的单引号。 dim s
有没有办法在'svn commit'上将提交注释添加到更改的文件中。有人告诉我有一种方法可以用 cvs 做到这一点,但我们使用 svn。目前,我们使用“$Revision”关键字将修订号添加到更改的文
我正在尝试通过 ManyToMany 注释自动对报告的结果进行排序 @OrderBy : /** * @ORM\ManyToMany(targetEntity="Artist", inversedB
我正在使用 JBoss 5 GA,我创建了一个测试 session bean 和本地接口(interface)。我创建了一个 servlet 客户端。我尝试使用 @EJB 将接口(interface)
我是一名优秀的程序员,十分优秀!