做用:BeanPostProcessor在bean初始化先後作自定義處理spring
場景:須要自定義swagger,使全部請求顯示固定的請求頭參數(自定義Docket類),可是swagger被架構組封裝到sdk中,因此在BeanPostProcessor中對Docket的bean作處理bash
/**
* 自定義swagger
*
* @author xiantao.wu
* @create 2019/3/269:51
**/
@Component
public class GiveAppBeanPostProcessor implements BeanPostProcessor {
//bean初始化以前的操做
@Override
public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
return bean;
}
//bean初始化以後的操做
@Override
public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
//swagger統一增長請求頭
if ("docket".equals(beanName)) {
return builderHeader((Docket) bean);
}
return bean;
}
private Docket builderHeader(Docket docket) {
List<Parameter> pars = new TreeList();
pars.add(new ParameterBuilder().name("x-os-name").description("系統類型").defaultValue("iOS")
.modelRef(new ModelRef("string")).parameterType("header").required(true).build());
pars.add(new ParameterBuilder().name("x-os-version").description("系統版本").defaultValue("10.3.3")
.modelRef(new ModelRef("string")).parameterType("header").required(true).build());
return docket.globalOperationParameters(pars);
}
}
複製代碼