前端
一、项目环境:vue2+antd 1.7.8
问题:
1.点开弹框页面控制台爆出红色警告You cannot set a …:
Warning: You cannot set a form field before rendering a field associated with the value. You can use getFieldDecorator(id, options)
instead v-decorator="[id, options]"
to register it before render.
如下图。
2.点开弹框页面控制台爆出红色警告Duplicate keys detected:
vue.runtime.esm.js:4646 [Vue warn]: Duplicate keys detected: ‘aao1_2_aerobic_terminal_do’. This may cause an update error.
如下图。
3.antd1.7.8下拉框数据分页实现
解决方法:
1.去除form表单多余属性
进入弹框页面时方法内,对页面form表单进行赋值时,不要将多余信息赋值给表单,否则会出现警告提示,如下图中id属性,注释后问题解决。
2.v-for循环中key值重复导致,去除重复的值保持key唯一,问题解决。
3.直接贴链接好了,鼓捣了很久看到这篇文章帮我解决了这个分页的问题,感谢大佬,https://juejin.cn/post/7267114615661920295
后端
一、项目环境:java springboot 2.7.5
问题:
1.springboot整合swagger报错(swagger版本2.9.2):
org.springframework.context.ApplicationContextException: Failed to start bean ‘documentationPluginsBootstrapper’; nested exception is java.lang.NullPointerException
如下图。
解决方法:
2.修改springboot匹配策略
报错原因:Springfox 假设 Spring MVC 的路径匹配策略是 ant-path-matcher,而 Spring Boot 2.6以上版本的默认匹配策略是 path-pattern-matcher,这就造成了上面的报错。
方案a(治标)
…在 application.yml配置文件中修改mvc的匹配策略:
spring :
mvc:
pathmatch:
matching-strategy: ant-path-matcher
我是用后可正常启动,但我查阅的文章表明在后续某些服务启动时会失效,治标不治本。
原句:
只有在不使用 Spring Boot 的执行器时,此功能才起作用。 无论配置的匹配策略如何,执行器将始终使用基于路径模式的解析 (
也就是默认策略 ) 。 如果您想在 Spring Boot 2.6及更高版本中将其与执行器一起使用,则需要对 Springfox 进行更改。
方案b(治标)
…重写一个 WebMvcConfigurer实现类,然后开启@EnableWebMvc注解:
注意:这种方法会破坏sprijngboot自带的mvc自动装配配置项,导致默认的一些静态目录功能无法使用,只能重写addResourceHandlers方法,需要手动指定静态目录
方案c(治本)
…在项目里添加这个 bean :(加在配置类里就可)
@Bean
public static BeanPostProcessor springfoxHandlerProviderBeanPostProcessor() {
return new BeanPostProcessor() {
@Override
public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
if (bean instanceof WebMvcRequestHandlerProvider || bean instanceof WebFluxRequestHandlerProvider) {
customizeSpringfoxHandlerMappings(getHandlerMappings(bean));
}
return bean;
}
private <T extends RequestMappingInfoHandlerMapping> void customizeSpringfoxHandlerMappings(List<T> mappings) {
List<T> copy = mappings.stream()
.filter(mapping -> mapping.getPatternParser() == null)
.collect(Collectors.toList());
mappings.clear();
mappings.addAll(copy);
}
@SuppressWarnings("unchecked")
private List<RequestMappingInfoHandlerMapping> getHandlerMappings(Object bean) {
try {
Field field = ReflectionUtils.findField(bean.getClass(), "handlerMappings");
field.setAccessible(true);
return (List<RequestMappingInfoHandlerMapping>) field.get(bean);
} catch (IllegalArgumentException | IllegalAccessException e) {
throw new IllegalStateException(e);
}
}
};
}