ABP框架使用 Swagger
在最近的一個項目中用到了 ABP框架 http://aspnetboilerplate.com/ ,第一次接觸到 Swagger https://swagger.io/ 以及前后端的完全分離
在ABP官網下載下來的ABP框架結構【基于ASP.NET MVC5.x的】如圖:
ABP的EntityFramework 是Code First Mode的,所以在配置好相應的實體后,修改數據庫連接字符串,選擇執行Migration 后數據庫創建的位置
<connectionStrings><add name="Default" connectionString="Server=.;Database=ABP_show_api_in_the_swagger; Trusted_Connection=True;" providerName="System.Data.SqlClient" /></connectionStrings>舊的Migration已經沒有用了,全部刪除掉,
在程序包管理控制臺中,做如下操作:
默認項目一定要選擇帶有后綴EntityFramework的
Add-migration 要輸入兩遍
update-database在執行成功后相應的數據庫就會創建在相應的地方
在WebApi類庫中,找到后綴為WebApiMoudle的類,添加ConfigureSwaggerUi方法
private void ConfigureSwaggerUi() {Configuration.Modules.AbpWebApi().HttpConfiguration.EnableSwagger(c =>{c.SingleApiVersion("v1", "show all Api");c.ResolveConflictingActions(apiDescriptions => apiDescriptions.First());}).EnableSwaggerUi(); }之后在Initialize方法里追加代碼
var cors = new EnableCorsAttribute("*", "*", "*");GlobalConfiguration.Configuration.EnableCors(cors);Configuration.Modules.AbpWeb().AntiForgery.IsEnabled = false;ConfigureSwaggerUi();會發現缺少命名空間
其中EnableCorsAttribute 位于System.Web.Http.Cors命名空間下,EnableSwagger 位于Swashbuckle.Core包中,用Nuget中引入相應的包
都安裝到 WebApi類庫中
重新引入命名空間,可以看到問題沒有了,重新編譯運行項目,在網站URI根路徑后鍵入 swagger/ui/index ,訪問之,大功告成!
可以看到所有的API【注意只有繼承了IApplictionService接口的Interface中定義的方法才會被掃描并顯示在這里】的名稱、參數、都在這里面了,還可以直接驗證好不好用哦~
轉載于:https://www.cnblogs.com/Mxy-cnblog/p/8819326.html
總結
以上是生活随笔為你收集整理的ABP框架使用 Swagger的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java求职简历建议
- 下一篇: 博弈(SG函数)