Użyłem narzędzia swagger w moim projekcie cache apache, użyłem adnotacji @Api i @ApiOperations oraz @ApiParam i wygenerowałem dokument api dla pozostałych usług.Wyklucz modele lub właściwości z odpowiedzi typu "swagger".
Ale chcę wykluczyć niektóre z pól, takich jak EntityTag, StatusType i MediaType itp. Z atrybutu Models lub pełnego modułu lub atrybutu właściwości.
Jak to zrobić?
Pobierałem dane z db i ustawiając je w obiekcie użytkownika i przekazując ten obiekt użytkownika do konstruktora odpowiedzi JAX-RS.
Poniżej jest jednym z moich DTO obiektu:
@ApiModel
public class User{
private String name;
private String email;
@ApiModelProperty(position = 1, required = true, notes = "used to display user name")
public int getName() {
return name;
}
public void setName(String name) {
this.name= name;
}
@ApiModelProperty(position = 2, required = true, notes = "used to display user email")
public int getEmail() {
return email;
}
public void setEmail(String email) {
this.email= email;
}
Teraz nie widzę pola lub właściwości obiektu użytkownika wewnątrz Swagger zwrócone w formacie JSON.
mój serwis metoda klasy odpowiedź brzmi:
@GET
@ApiOperation(value = "xxx", httpMethod = "GET", notes = "user details", response = Response.class)
public Response getUserInfo(){
User userdto = userdaoimpl.getUserDetails();
ResponseBuilder builder = Response.ok(user, Status.OK), MediaType.APPLICATION_JSON);
builder.build();
}
<bean id="swaggerConfig" class="com.wordnik.swagger.jaxrs.config.BeanConfig">
<property name="resourcePackage" value="com.services.impl" />
<property name="version" value="1.0.0" />
<property name="basePath" value="http://localhost:8080/api" />
<property name="license" value="Apache 2.0 License" />
<property name="licenseUrl"
value="http://www.apache.org/licenses/LICENSE-2.0.html" />
<property name="scan" value="true" />
</bean>
Którą wersję Swagger-core używasz? – Ron