介紹一款 API 敏捷開發(fā)工具

作者:棒錘
來源:xie.infoq.cn/article/b5c3a339267e1351c6151b42a
初衷
特性
- 用于快速開發(fā)API接口。不再定義
Controller,Service,Dao,Mybatis,xml,Entity,VO等對象和方法. - 可視化界面,將入?yún)⒆詣臃庋b到可執(zhí)行的腳本上,支持所有關(guān)系性數(shù)據(jù)庫SQL執(zhí)行語句,非關(guān)系型
MONGODB查詢語句.歡迎擴展 - 完全基于springboot2.x 作為springboot項目的stater方式集成,無侵入性,新老項目都能快速集成
- 只需編寫一行代碼即可完成大部分的業(yè)務(wù)需求開發(fā),使用難度級別(測試 or 運維)也可參與開發(fā)
- 在線動態(tài)編譯,無需重啟,即時生效,多數(shù)據(jù)源操作
- 版本控制,歷史記錄比對,回滾等功能
- 遠(yuǎn)程一鍵發(fā)布到線上環(huán)境
- 線上POSTMAN調(diào)試,保存POSTMAN信息或三方文檔的自動生成,歷史調(diào)用記錄存儲,回塑
- 代碼提示,SQL提示,語法提示
- 用戶管理控制,安全性控制,以及歷史行為記錄
- 經(jīng)過多次項目驗證,傳統(tǒng)業(yè)務(wù)型開發(fā),服務(wù)端效率能夠提升3-5倍,前后端聯(lián)調(diào)提升效率1倍,測試效率2倍提升
傳統(tǒng)開發(fā)步驟:
- 增加一張表
- 創(chuàng)建實體對象,映射這張表
- 創(chuàng)建API入?yún)O
- 創(chuàng)建API出參VO
- 創(chuàng)建Controller
- 創(chuàng)建Service
- 創(chuàng)建Dao
- 創(chuàng)建Mapper, xml或者JPA
- 在mysql客戶端,或者mongo客戶端中寫執(zhí)行腳本語句,復(fù)制到代碼中
- 反復(fù)重啟,進行接口自測
- 編寫API文檔
- 完成一個功能點開發(fā)
- 基于springboot開發(fā)。包括接口的注冊,參數(shù)的獲取,輸入輸出的消息轉(zhuǎn)換,都是基于springboot的生態(tài)環(huán)境,能無侵入性集成于springboot項目中,如果你有基于springboot實現(xiàn)了全局異常處理,返回值統(tǒng)一封裝,權(quán)限控制等,不用擔(dān)心,都在你的管控范圍內(nèi)
- 參考于mybatis的參數(shù)定義方式,不同點在于使用默認(rèn)大于配置的邏輯,實現(xiàn)參數(shù)的注入直接來源于請求參數(shù),省略了傳統(tǒng)MVC 實體類,方法,VO等定義
- 默認(rèn)擔(dān)供了內(nèi)部函數(shù),可以很簡單的實現(xiàn) 多表/多庫的增/刪/改/查,導(dǎo)出,導(dǎo)入,上傳,下載,分頁查詢等功能
- 提供了基于Groovy的語法解析,可以實現(xiàn)Groovy的一些邏輯處理
- 提供了調(diào)用springboot bean對象的方法及其他任意java定義的靜態(tài)類,方法和對象,這意味著我能夠調(diào)用公共定義的類,或者之前在項目中定義的service,dao,和utils
- 因為基于的groovy動態(tài)語法解析,所以代碼修改,或者線上問題的處理能夠不用重啟服務(wù),也不用升級代碼就能夠完成功能開發(fā)和問題處理,這對開發(fā)效率而言會有很大的提升
- 傳統(tǒng)業(yè)務(wù)開發(fā),不僅有服務(wù)端的開發(fā),還有相對應(yīng)的文檔生成,前后端對接,以及測試配合。“Rocket API” 提供了POSTMAN的操作頁面,能夠?qū)?shù)的請求值,請求類型,響應(yīng)等保存起來,給予前端做真實數(shù)據(jù)的對接,而不是類yapi,或者swagger之類生成的不能使用的假數(shù)據(jù)。基于這些真實的請求參數(shù)和返回值,提供了外部接口能力,測試團隊可以以此來做接口的一鍵冒煙測試,和文檔的一鍵生成
演示說明
https://blog.csdn.net/maple_son/article/details/108196584
接口功能邏輯頁面

接口功能自測頁面

集成方式:
1. 添加依賴<dependency>
??<groupId>com.github.alenfivegroupId>
??<artifactId>rocket-api-boot-starterartifactId>
??<version>0.0.1-SNAPSHOTversion>
dependency>2. 數(shù)據(jù)源配置@Component
public?class?DefaultDataSourceManager?extends?DataSourceManager?{
@Autowired
private?JdbcTemplate jdbcTemplate;
@PostConstruct
public?void?init()?{
????????Map dialects = new?HashMap<>();
????????dialects.put("mysql",new?SqlDataSource(jdbcTemplate,true));
super.setDialectMap(dialects);
????}
} 3. 最新建表腳本查看:?
https://gitee.com/alenfive/rocket-api-doc/wikis/pages?sort_id=2670007&doc_id=859283
啟動項目,訪問地址:?http://localhost:8080/interface-ui由于微信平臺算法改版,公號內(nèi)容將不再以時間排序展示,如果大家想第一時間看到我們的推送,強烈建議星標(biāo)我們和給我們多點點【在看】。星標(biāo)具體步驟為:
(1)點擊頁面最上方“小詹學(xué)Python”,進入公眾號主頁。
(2)點擊右上角的小點點,在彈出頁面點擊“設(shè)為星標(biāo)”,就可以啦。
感謝支持,比心。
評論
圖片
表情
