我有一组类,它们都从我的 ReportConfig 抽象类扩展而来。一旦创建,它们目前是不可变的并且不受 Spring 管理。
但是,我发现有时我需要执行需要使用特定服务的操作,但我正在努力寻找将这些服务注入(inject)我的非托管 ReportConfig 实例的最佳方法。见下文:
@Service
public class ReportService() {
@Autowired
private SchemaService schemaService;
@Autowired
private ExecutionService executionService;
@Autowired
private ReportConfigFactory reportConfigFactory;
public Result executeReport(ReportRequest request) {
ReportConfig reportConfig = reportConfigFactory.getReportConfig(request);
reportConfig.validateAgainstSchema(schemaService.getSchemaForDataset(reportConfig.getDataset()));
executionService.execute(reportConfig.getQuery());
}
现在我对 dataService.execute()
行没有问题,但是我对 reportConfig.validateAgainstSchema()
行有问题,我觉得有一个替代方案会是这样的:
reportConfig.validateAgainstSchema(schemaService);
但我觉得这可能代表紧耦合。
我想还有一种方法可以将 SchemaService 直接注入(inject)到 ReportConfigs 中,但不确定这是否会破坏对象...
很想听听您的想法。
谢谢
最佳答案
根据我对您所给出的应用程序当前设计的理解,我正在猜测功能并考虑替代设计,
reportConfig.validateAgainstSchema(schemaService.getSchemaForDataset(reportConfig.getDataset()));
你可以想到的是,如果 reportconfig 是执行 validateAgainstSchema
的正确位置,如果不考虑更改它。
schemaService
是执行 validateAgainstSchema
的正确位置吗(我认为不是)如果那也不是执行此操作的正确位置,则创建一个 SchemaValidator
或类似的东西。
根据您提供的信息,我可以想到这一点。
如果 validateAgainstSchema
没有被 ReportConfig
的任何子类覆盖并且这种可能性非常小,那么您绝对应该考虑将其移至其他类。我这样说的原因是,如果架构发生变化,那么您不必更改 reportConfig
类
如果它被覆盖并且有多个实现,那么一种方法是使用 validator 工厂来获取 validator 并进行验证。我什至不知道这是否适合您的用例,但这就是我能提供的问题信息。 希望它能在某种程度上帮助你。
关于java - 将 Spring Boot 服务注入(inject)非托管类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61013015/