Ответ 1
Я проверил ваш код: это невероятно, но я не могу воспроизвести вашу проблему. Я загрузил последнюю версию spring (3.0.5), это мой контроллер:
package test;
import org.apache.commons.lang.StringUtils;
import org.apache.log4j.Logger;
import org.springframework.stereotype.Controller;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
@Controller
@RequestMapping("/test/**")
public class MyController {
private static final Logger logger = Logger.getLogger(MyController.class);
@RequestMapping(value = "/test/params", method = RequestMethod.GET)
public void test(SearchRequestParams requestParams, BindingResult result) {
logger.debug("fq = " + StringUtils.join(requestParams.getFq(), "|"));
}
}
это мой класс SearchRequestParams:
package test;
public class SearchRequestParams {
private String[] fq;
public String[] getFq() {
return fq;
}
public void setFq(String[] fq) {
this.fq = fq;
}
}
и это моя простая конфигурация spring:
<bean id="urlMapping" class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />
<bean class="test.MyController" />
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix">
<value>/WEB-INF/jsp/</value>
</property>
<property name="suffix">
<value>.jsp</value>
</property>
</bean>
Я тестировал свой код в tomcat 7.0.8; когда я набираю http://localhost:8080/testweb/test/params.htm?fq=foo,bar
, я могу прочитать в своем файле журнала эту строку: DEBUG fq = foo,bar
.
Каковы отличия от моего кода? Я делаю что-то неправильно?
Я хотел бы помочь вам, поэтому, если у вас есть какие-либо сомнения или я могу сделать некоторые другие тесты для вас, это будет приятно.
ОБНОВЛЕНИЕ/РЕШЕНИЕ
С вашим кодом я воспроизвел проблему; у вас есть тег <mvc:annotation-driven />
в конфигурации сервлета диспетчера, поэтому вы тихо используете службу преобразования по умолчанию, экземпляр FormattingConversionService
, который содержит конвертер по умолчанию от String
до String[]
, который использует запятую как разделитель.
Вы должны использовать другую службу преобразования bean, содержащую ваш собственный конвертер от String
до String[]
. Вы должны использовать другой разделитель, я выбрал использовать ";" потому что это разделитель, обычно используемый в строке запроса ( "? first = 1; second = 2; third = 3" ):
import org.springframework.core.convert.converter.Converter;
import org.springframework.util.StringUtils;
public class CustomStringToArrayConverter implements Converter<String, String[]>{
@Override
public String[] convert(String source) {
return StringUtils.delimitedListToStringArray(source, ";");
}
}
Затем вы должны указать эту службу преобразования bean в своей конфигурации:
<mvc:annotation-driven conversion-service="conversionService" />
<bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean">
<property name="converters">
<list>
<bean class="au.org.ala.testspringbinding.CustomStringToArrayConverter" />
</list>
</property>
</bean>
Проблема исправлена, теперь вы должны проверить наличие каких-либо побочных эффектов. Надеюсь, вам не понадобится в вашем приложении исходное преобразование от String
до String[]
(с запятой в качестве разделителя).;-)