設計模式:策略模式(根據參數,調用不同的service接口)


1.定義類容器providers,當spring加載時@PostConstruct(類似構造方法),會先執行init() ; 在init()中,反射"cn.jdk18"的所有帶自定義注解@ProviderName的java文件,並且遍歷的類要滿足被DataProvider繼承關系,將滿足條件的類放到providers容器中

2.前端url 訪問 {basePath}/jdbc 或 {basePath}/kylin  即可調用不用的service

ClassByTypeServiceImpl

@Service
public class ClassByTypeServiceImpl implements ClassByTypeService {

private Map<String, Class<? extends DataProvider>> providers = Maps.newConcurrentMap();

@SuppressWarnings("unchecked")
@PostConstruct
public void init() {
Set<Class<?>> setClass = new Reflections("cn.jdk18").getTypesAnnotatedWith(ProviderName.class);
for (Class<?> class1 : setClass) {
if (!class1.isAssignableFrom(DataProvider.class)) {
System.out.println(class1.getName());
ProviderName providerName = class1.getAnnotation(ProviderName.class);
providers.put(providerName.name(), (Class) class1);
} else {
System.out.println("未被繼承:" + class1.getName());
}
}
}

public Class<?> getClassByType(String type) {
return providers.get(type);
}

}

  

ClassByTypeService

public interface ClassByTypeService {
Class<?> getClassByType(String type);
}

ProviderName

@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface ProviderName {
String name();
}

  

JDBCDataProvider

@ProviderName(name = "jdbc")
public class JDBCDataProvider extends DataProvider{
public void helloWorld(){}
}

  

KylinDataProvider

@ProviderName(name = "kylin")
public class KylinDataProvider extends DataProvider{
public void helloWorld(){}
}

  

UserController

@RequestMapping("/getClassByType/{type}") 
public String getClassByType(@PathVariable String type){
return "saySomething:"+classByTypeService.getClassByType(type).getName();
}

  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM