【发布时间】:2015-09-20 00:53:12
【问题描述】:
我正在尽我最大的努力在这里几乎不使用 XML。我做了一个非常简单的程序,但它不工作。希望有人能帮帮我。
public class App {
public static void main(String[] args) {
AnnotationConfigApplicationContext ctx = new
AnnotationConfigApplicationContext(Logger.class);
Logger logger = ctx.getBean(Logger.class);
logger.writeConsole("Hello there");
logger.writeFile("Hi again");
ctx.close();
}
}
界面
public interface LogWriter {
public void write(String text);
}
文件编写器
public class FileWriter implements LogWriter {
public void write(String text) {
System.out.println("FileWriter: " + text);
}
}
控制台编写器
public class ConsoleWriter implements LogWriter{
public void write(String text) {
System.out.println("Console Writer: "+text);
}
}
记录器
public class Logger {
@Autowired
private ConsoleWriter consoleWriter;
@Autowired
private FileWriter fileWriter;
public void setConsoleWriter(ConsoleWriter consoleWriter) {
this.consoleWriter = consoleWriter;
}
public void setFileWriter(FileWriter fileWriter) {
this.fileWriter = fileWriter;
}
public void writeFile(String text) {
fileWriter.write(text);
}
public void writeConsole(String text) {
consoleWriter.write(text);
}
@Bean
public Logger getLogger(){
return new Logger();
}
}
错误
Jul 02, 2015 2:52:49 PM org.springframework.context.annotation.AnnotationConfigApplicationContext prepareRefresh
INFO: Refreshing org.springframework.context.annotation.AnnotationConfigApplicationContext@246b179d: startup date [Thu Jul 02 14:52:49 CEST 2015]; root of context hierarchy
Exception in thread "main" java.lang.NoSuchMethodError: org.springframework.core.GenericTypeResolver.resolveReturnTypeForGenericMethod(Ljava/lang/reflect/Method;[Ljava/lang/Object;)Ljava/lang/Class;
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getTypeForFactoryMethod(AbstractAutowireCapableBeanFactory.java:650)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.predictBeanType(AbstractAutowireCapableBeanFactory.java:575)
at org.springframework.beans.factory.support.AbstractBeanFactory.isFactoryBean(AbstractBeanFactory.java:1344)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.doGetBeanNamesForType(DefaultListableBeanFactory.java:356)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeanNamesForType(DefaultListableBeanFactory.java:327)
at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:644)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:461)
at org.springframework.context.annotation.AnnotationConfigApplicationContext.<init>(AnnotationConfigApplicationContext.java:73)
at com.main.application.App.main(App.java:10)
这是我的 XML 文件,但我试图摆脱使用 XML 而只使用注释,所以我将这个简单的程序作为实践来理解。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd">
<context:annotation-config></context:annotation-config>
</beans>
【问题讨论】:
-
@TilmanHausherr 我的目标是不使用 XML。我知道有办法做到这一点。我只是认为我的问题会帮助其他人尝试做同样的事情。我错了假设我必须使用 XML。我以前使用过 JHipster,它只有一个基本的 XML 文件。都是 POJO 和 Annotations。
-
你的
Logger应该有@Configuration否则它不会被用作配置类。接下来,您应该将配置与应用程序代码分开(单一职责。从堆栈跟踪来看,您有一些混合的 jar 文件(来自不同版本的框架的 jar)。
标签: java spring-mvc