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

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

接口功能自測(cè)頁(yè)面

集成方式:
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
啟動(dòng)項(xiàng)目,訪問(wèn)地址:?http://localhost:8080/interface-ui由于微信平臺(tái)算法改版,公號(hào)內(nèi)容將不再以時(shí)間排序展示,如果大家想第一時(shí)間看到我們的推送,強(qiáng)烈建議星標(biāo)我們和給我們多點(diǎn)點(diǎn)【在看】。星標(biāo)具體步驟為:
(1)點(diǎn)擊頁(yè)面最上方“小詹學(xué)Python”,進(jìn)入公眾號(hào)主頁(yè)。
(2)點(diǎn)擊右上角的小點(diǎn)點(diǎn),在彈出頁(yè)面點(diǎn)擊“設(shè)為星標(biāo)”,就可以啦。
感謝支持,比心。
評(píng)論
圖片
表情
