当我使用 NSwag 为 API 生成 C# 客户端时,其中 API 包括可用于多种 Http 请求类型(例如 POST、GET)的端点,客户端为每个具有相同基本名称的请求生成一个方法,并加上一个数字。
例如使用这个 API:https : //api.premiumfunding.net.au/assets/scripts/swagger/v1/swagger.json
该架构包含一个端点/contract
支持GET
和POST
要求,以及端点/contract/{ID}
支持GET
,POST
并DELETE
请求。
生成的客户端有方法:
ContractAsync
对于没有 ID 的 GET 请求Contract2Async
对于没有 ID 的 POST 请求Contract3Async
对于带有 ID 的 GET 请求Contract4Async
用于带有 ID 的 POST 请求Contract5Async
用于带有 ID 的 DELETE 请求我希望它生成名为的方法:
GetContractAsync
对于没有 ID 的 GET 请求PostContractAsync
对于没有 ID 的 POST 请求GetContractAsync
对于带有 ID 的 GET 请求(方法重载)PostContractAsync
对于带有 ID 的 POST 请求(方法过载)DeleteContractAsync
用于带有 ID 的 DELETE 请求目前我只是手动重命名方法。
是否可以配置 NSwag 来生成这些方法名称?
(或者有没有其他工具可以给我这个结果?)
您可以实现并提供自己的 IOperationNameGenerator:
\n\n\n\n另一个选择是预处理规范并将 \xe2\x80\x9coperationId\xe2\x80\x9ds 更改为 \xe2\x80\x9ccontroller_operation\xe2\x80\x9d 形式(基于 NSwag.Core 包的简单控制台应用程序)
\n