我在 Go 中實(shí)現(xiàn) REST API 時(shí)遇到了一些問題。我使用 go-swagger 來記錄我的 API。它基于結(jié)構(gòu)生成模型。我的第一個(gè)問題是我不知道在我的招搖 yaml 文件中如何定義一個(gè)簡(jiǎn)單的 hasMany 關(guān)系。如果我需要一輛有很多輪子的車。在我的數(shù)據(jù)庫(kù)中,我將有一個(gè)vehicle表和一個(gè)wheel包含id車輛的表。由于 Vehicle 沒有wheel_id,所以我大搖大擺地得到一個(gè)簡(jiǎn)單的type: object. 對(duì)于輪子,我有一個(gè)屬性: vehicle: $ref: '#/definitions/Vehicle'這會(huì)生成一個(gè)模型:type Wheel struct { ... Vehicle *Vehicle}當(dāng)我要求輪子列表時(shí),這不是我希望我的 API 返回的內(nèi)容。所以我需要一個(gè) DTO 或某種映射器在客戶端和數(shù)據(jù)庫(kù)之間工作。閱讀https://www.reddit.com/r/golang/comments/6xgzmp/model_to_dto_mapper_my_first_experience_with_go/ 看起來這不是在 Go 中做事的方式。我是否需要?jiǎng)h除我的 swagger 文件中的所有參考,以便它更好地匹配模型?(將 $ref 替換為屬性 id:類型:字符串)在這種情況下,最佳做法是什么?
1 回答

呼喚遠(yuǎn)方
TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超11個(gè)贊
我找到的解決方案是大搖大擺地制作一個(gè)自定義響應(yīng)模型:
/vehicle/{id}:
get:
...
responses:
'200':
schema:
$ref: '#definitions/VehicleCustomeResponse'
我想我可以使用招搖anyOf來減少重復(fù)的數(shù)量。
- 1 回答
- 0 關(guān)注
- 135 瀏覽
添加回答
舉報(bào)
0/150
提交
取消