Ниже представлен снимок экрана моей структуры проекта. Модуль пружинной загрузки - это api, и я хочу использовать его в модульном сервере, который является весенним загрузочным приложением.Я определяю свой Springboot api от Swagger и как его использовать в других модулях для реализации контроллера?
АНИ порождается Swagger, и один из API выглядит следующим образом:
ProductsApi.class:
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiResponse;
import io.swagger.annotations.ApiResponses;
import io.wondergate.polaris.model.Product;
import java.util.List;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
@Api(
value = "products",
description = "the products API"
)
public interface ProductsApi {
@ApiOperation(
value = "",
notes = "Get the list of products",
response = Product.class,
responseContainer = "List",
tags = {}
)
@ApiResponses({ @ApiResponse(
code = 200,
message = "OK",
response = Product.class
)})
@RequestMapping(
value = {"/products"},
produces = {"application/json"},
consumes = {"application/json"},
method = {RequestMethod.GET}
)
ResponseEntity<List<Product>> getProducts();
}
Я реализации сервер api в модуле следующим образом:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import java.util.ArrayList;
import java.util.List;
import io.wondergate.polaris.api.ProductsApi;
import io.wondergate.polaris.model.Product;
import io.wondergate.polaris.server.dao.ProductDao;
import io.wondergate.polaris.server.dao.ResourceInfoDao;
import io.wondergate.polaris.server.model.ResourceInfo;
import io.wondergate.polaris.server.model.ServerProduct;
import io.wondergate.polaris.server.utils.Convertor;
@Controller
public class ProductController implements ProductsApi {
@Autowired
private ProductDao productDao;
@Autowired
private ResourceInfoDao resourceInfoDao;
@RequestMapping("/")
@ResponseBody
public String index() {
return "Greetings from Spring Boot!";
}
// @RequestMapping("/products")
public ResponseEntity<List<Product>> getProducts() {
List<Product> productList = new ArrayList<Product>();
Iterable<ServerProduct> allProducts = productDao.findAll();
for (ServerProduct serverProduct : allProducts) {
Iterable<ResourceInfo> resourceInfo = resourceInfoDao.findByProductId(serverProduct.getId());
Product product = Convertor.serverProductToProduct(serverProduct, resourceInfo);
productList.add(product);
}
ResponseEntity<List<Product>> res = new ResponseEntity<List<Product>>(productList, HttpStatus.OK);
return res;
}
}
Однако, хотя проект может быть собран и успешно запущен, он может не отображать URL-адрес маршруты, как я хочу, например,
Так как я могу это сделать? Я хочу сделать модуль api define и реализовать модуль отдельно, поэтому, когда я изменяю определение api, мне не нужно изменять его реализацию (например, URL-адрес).
'@ RequestMapping' читается весной во время создания контекста на конкретном классе, поэтому, строго говоря, он не знает о его интерфейсе. Грязное обходное решение будет добавлять его в impl (как вы прокомментировали) и ссылаться на значение (значения) на статическое поле на интерфейсе. –