当我使用 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| 归档时间: |
|
| 查看次数: |
2179 次 |
| 最近记录: |