весенний freemarker ConversionNotSupportedException - PullRequest
0 голосов
/ 23 июня 2011

Я пытаюсь использовать Freemarker для шаблонных писем в своем веб-приложении на сервере веб-приложений JBoss 5.1.

почта-контекст-XML:

<bean id="freemarkerConfiguration"
    class="org.springframework.ui.freemarker.FreeMarkerConfigurationFactoryBean">
    <property name="templateLoaderPath" value="/WEB-INF/templates" />
</bean>


<bean id="registrationMailService" class="com.epam.darts.webapp.utils.RegistrationMailService">
    <property name="configuration" ref="freemarkerConfiguration" />
    <property name="mailSender" ref="mailSender" />
</bean>

RegistrationMailService.java:

public class RegistrationMailService {

    private JavaMailSender mailSender;
    private Configuration configuration;

    public void sendConfirmationEmail(final User user) {
        MimeMessage message = this.mailSender.createMimeMessage();
        MimeMessageHelper helper = new MimeMessageHelper(message);
        try {
            helper.setFrom(user.getLogin());

            helper.setTo(user.getLogin());
            helper.setSubject(user.getLogin());

            Map<String, Object> model = new HashMap<String, Object>();
            model.put("user", user);

            String sendText = FreeMarkerTemplateUtils.processTemplateIntoString(
                        this.configuration.getTemplate("regisstration_mail.html"), model);
            helper.setText(sendText, true);
            this.mailSender.send(helper.getMimeMessage());
        }
        catch(MessagingException e) {
            e.printStackTrace();
           }
    }

    public void setMailSender(final JavaMailSender mailSender) {
        this.mailSender = mailSender;
    }
    public void setConfiguration(final Configuration configuration) {
        this.configuration = configuration;
    }
}

maven depandency для freemarker:

    <dependency>
        <groupId>freemarker</groupId>
        <artifactId>freemarker</artifactId>
        <version>2.3.9</version>
    </dependency>

В первый раз все работает хорошо. Но если я пытаюсь повторно развернуть свое приложение (mvn clean package jboss: hard-deploy), я получаю ошибку

 18:17:46,839 ERROR [ContextLoader] Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'registrationMailService' defined in
ServletContext resource [/WEB-INF/spring/spring-mail.xml]: Initialization of bean failed; nested exception is org.springfram
ework.beans.ConversionNotSupportedException: Failed to convert property value of type 'freemarker.template.Configuration' to
 required type 'freemarker.template.Configuration' for property 'configuration'; nested exception is java.lang.IllegalStateE
xception: Cannot convert value of type [freemarker.template.Configuration] to required type [freemarker.template.Configurati
on] for property 'configuration': no matching editors or conversion strategy found

Возможно, проблема в загрузчике классов, но я не знаю, как это исправить.

1 Ответ

1 голос
/ 24 июня 2011

Похоже, у вас есть две копии JAR-файла freemarker в вашем classpath.Вам нужно найти их и сузить до одного.

...