開發API。若可以同時產生文件,則可減少工作內容,所以本次嘗試使用Swagger,看看該工具可以有什麼樣的幫助
環境
- VS2022
- ASP.NET Core 6
建立專案
data:image/s3,"s3://crabby-images/fac01/fac01cfba3e76b0c763b29370b4cf72cc7c3cc81" alt=""
點選專案屬性並勾選文件檔案
data:image/s3,"s3://crabby-images/024c6/024c65a9702841b86b71e4bbedb4f8725f661593" alt=""
隱藏警告中填入
$(NoWarn);1591
如無填入,則會出現警告要求寫入Summary
data:image/s3,"s3://crabby-images/80cc9/80cc93e0670601fc6fbbd80fc0b14e991eb1386a" alt=""
打開專案的Csproj檔,可看到剛勾選的屬性已寫入Csproj
data:image/s3,"s3://crabby-images/c61e5/c61e5d74278411f5a90fa56ef7d19bb70e39a641" alt=""
打開Program檔找到
builder.Services.AddSwaggerGen()
修改為
builder.Services.AddSwaggerGen(options =>
{
var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile);
options.IncludeXmlComments(xmlPath, true);
});
data:image/s3,"s3://crabby-images/ea0fb/ea0fbc72ef9f0bccd1a13d9071369b73a0b8ee3e" alt=""
Controllers加上Summary,以及Produces限制回應Json格式
data:image/s3,"s3://crabby-images/940b9/940b963693fe283b450e8beaee307928a73b1a3e" alt=""
執行並驗證
data:image/s3,"s3://crabby-images/02b06/02b060f954b2da46ce2311753d54b34fcf7b0996" alt=""
點開Get
data:image/s3,"s3://crabby-images/149c4/149c4233178af3ba1b6be1830c16702307a4316e" alt=""
點擊Try it out
data:image/s3,"s3://crabby-images/9a7bb/9a7bb233a91439df78cc8752ab8b943224f4ecde" alt=""
執行後建置的路徑多一個Xml
data:image/s3,"s3://crabby-images/a86fd/a86fd8ad6d738dfc61c9071f994f7e44a742cbce" alt=""
良好的編寫Summary此時就成了API文件的產生幫手,而文件則成了公開的URL,或是可以轉Swagger JSON提供給對方使用
以上為初次簡易嘗試,後續會再提供進階需要使用到的功能