Czy ktoś zdołał ukryć parametr z wygenerowanej dokumentacji? Znalazłem problem here, ale używanie @ApiParam(access="internal", required=false)
przed @HeaderParam
nie działa.Jak ukryć parametr w swaggerze?
5
A
Odpowiedz
7
Ok, patrząc na testy jednostkowe pomógł. Najpierw trzeba zdefiniować filtr:
import com.wordnik.swagger.core.filter.SwaggerSpecFilter
import com.wordnik.swagger.model.{Parameter, ApiDescription, Operation}
import java.util
class MySwaggerSpecFilter extends SwaggerSpecFilter{
override def isOperationAllowed(operation: Operation, api: ApiDescription, params: util.Map[String, util.List[String]], cookies: util.Map[String, String], headers: util.Map[String, util.List[String]]): Boolean = true
override def isParamAllowed(parameter: Parameter, operation: Operation, api: ApiDescription, params: util.Map[String, util.List[String]], cookies: util.Map[String, String], headers: util.Map[String, util.List[String]]): Boolean = {
if(parameter.paramAccess == Some("internal")) false
else true
}
}
a następnie włączyć go w web.xml
<servlet>
<servlet-name>DefaultJaxrsConfig</servlet-name>
<servlet-class>com.wordnik.swagger.jaxrs.config.DefaultJaxrsConfig</servlet-class>
...
<init-param>
<param-name>swagger.filter</param-name>
<param-value>com.example.MySwaggerSpecFilter</param-value>
</init-param>
</servlet>
2
Z Swagger-springmvc (https://github.com/springfox/springfox) w tej chwili nie ma sposobu, aby korzystać SwaggerSpecFilter. Ale respektuje adnotację @ApiIgnore - można ją zastosować do parametru metody, który nie powinien pojawiać się w generowanych metadanych.
1
W implementacji sprigfox-swagger2
znajduje się adnotacja @ApiModelProperty
, która to robi.
przykład:
@ApiModelProperty(required = false, hidden = true)
private String internallyUsedProperty;
0
This odpowiedź opisano aktualny rozwiązanie springfox pomocą .ignoredParameterTypes
lub @ApiIgnore
2
nadzieję, że to pomaga.
dla pól
@ApiModelProperty(required = false, hidden = true)
private String hiddenProperty
Dla Apis
@ApiIgnore
public class MyApi {}
dla parametrów
public void getApi(@ApiIgnore String param){}
@ApiModelProperty(hidden="true")
public String paramInsideClass
Powiązane problemy
- 1. Jak ukryć przepełnienie w select2?
- 2. Jak ukryć __methods__ w python?
- 3. Jak ukryć karetkę w RichTextBox?
- 4. Jak ukryć szablon w Wordpressie?
- 5. Jak ukryć UITableViewSections w Swift?
- 6. Jak ukryć podmenu w QMenu
- 7. Jak pokazać/ukryć animowany komponent w Aurelia
- 8. Jak ukryć obrazy apk?
- 9. Jak ukryć nagłówek PivotItem?
- 10. Jak "ukryć" UIRefreshControl?
- 11. Jak ukryć zmienną Z3
- 12. Jak ukryć granicę UITextField?
- 13. jak ukryć wyjście systemowe()
- 14. Jak ukryć podramkę UIView?
- 15. Jak ukryć metodę utylizacji?
- 16. Jak ukryć część obrazu?
- 17. Jak ukryć schemat mikrodanych?
- 18. Jak ukryć ikonę Docku
- 19. ukryć kolumnę w JTable
- 20. Parametr w jak klauzula JPQL
- 21. Jak ustawić parametr w HttpServletRequest?
- 22. Jak przekazać parametr w RedirectToAction?
- 23. Jak ukryć pasek przewijania w QScrollArea?
- 24. Jak ukryć elementy tablicy rekordów w Numpy?
- 25. Jak ukryć aplikację konsoli w języku C#
- 26. jak ukryć przycisk w pasku czynności
- 27. jak ukryć wszystkie panele w formie okna?
- 28. Jak ukryć oczekiwane wycieki pamięci w FastMM?
- 29. Jak ukryć rysowane wartości w MPAndroidChart?
- 30. Jak ukryć klawiaturę w oknie dialogowym?