範例如下:
builder.Services.AddSwaggerGen(options =>
{
options.SwaggerDoc("v1", new OpenApiInfo { Title = "My API", Version = "v1" });
//多個 Project, 每一個 xmldocument 都要載入
List<string> xmlFiles = Directory.GetFiles(AppContext.BaseDirectory, "*.xml", SearchOption.TopDirectoryOnly).ToList();
foreach (string fileName in xmlFiles)
{
string xmlFilePath = Path.Combine(AppContext.BaseDirectory, fileName);
if (File.Exists(xmlFilePath))
options.IncludeXmlComments(xmlFilePath, includeControllerXmlComments: true);
}
//防止 SchemaId 的錯誤
options.CustomSchemaIds(type => type.ToString());
});
這些都可以從註解中讀取:
data:image/s3,"s3://crabby-images/026a7/026a7e5a03f2050737f84dd34adf39a121945bca" alt=""
data:image/s3,"s3://crabby-images/876f5/876f502204402219408bde274275cb8260a9fdee" alt=""
data:image/s3,"s3://crabby-images/3329c/3329cf59d66d2ee5e4ce8f2e37126f9a261d039e" alt=""