chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

風控系統(tǒng)就該這么設計穩(wěn)的一批!

jf_ro2CN3Fa ? 來源:芋道源碼 ? 2023-01-30 09:32 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

12ab472e-a03d-11ed-bfe3-dac502259ad0.jpg

一、背景

1.為什么要做風控?

這不得拜產品大佬所賜

目前我們業(yè)務有使用到非常多的AI能力,如ocr識別、語音測評等,這些能力往往都比較費錢或者費資源,所以在產品層面也希望我們對用戶的能力使用次數(shù)做一定的限制,因此風控是必須的!

2.為什么要自己寫風控?

那么多開源的風控組件,為什么還要寫呢?是不是想重復發(fā)明輪子呀.12d2b32c-a03d-11ed-bfe3-dac502259ad0.jpg

要想回答這個問題,需要先解釋下我們業(yè)務需要用到的風控(簡稱業(yè)務風控),與開源常見的風控(簡稱普通風控)有何區(qū)別:

12dbbc42-a03d-11ed-bfe3-dac502259ad0.png

因此,直接使用開源的普通風控,一般情況下是無法滿足需求的

3.其它要求

支持實時調整限制

很多限制值在首次設置的時候,基本上都是拍定的一個值,后續(xù)需要調整的可能性是比較大的,因此可調整并實時生效是必須的

基于 Spring Boot + MyBatis Plus + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權限、多租戶、數(shù)據(jù)權限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://github.com/YunaiV/ruoyi-vue-pro
  • 視頻教程:https://doc.iocoder.cn/video/

二、思路

要實現(xiàn)一個簡單的業(yè)務風控組件,要做什么工作呢?

1.風控規(guī)則的實現(xiàn)

a.需要實現(xiàn)的規(guī)則:

  • 自然日計數(shù)
  • 自然小時計數(shù)
  • 自然日+自然小時計數(shù)

自然日+自然小時計數(shù) 這里并不能單純地串聯(lián)兩個判斷,因為如果自然日的判定通過,而自然小時的判定不通過的時候,需要回退,自然日跟自然小時都不能計入本次調用!

b.計數(shù)方式的選擇:

目前能想到的會有:

  • mysql+db事務 持久化、記錄可溯源、實現(xiàn)起來比較麻煩,稍微“重”了一點
  • redis+lua 實現(xiàn)簡單,redis的可執(zhí)行l(wèi)ua腳本的特性也能滿足對“事務”的要求
  • mysql/redis+分布式事務 需要上鎖,實現(xiàn)復雜,能做到比較精確的計數(shù),也就是真正等到代碼塊執(zhí)行成功之后,再去操作計數(shù)

目前沒有很精確技術的要求,代價太大,也沒有持久化的需求,因此選用 redis+lua 即可

2.調用方式的實現(xiàn)

a.常見的做法 先定義一個通用的入口

//簡化版代碼

@Component
classDetectManager{
funmatchExceptionally(eventId:String,content:String){
//調用規(guī)則匹配
valrt=ruleService.match(eventId,content)
if(!rt){
throwBaseException(ErrorCode.OPERATION_TOO_FREQUENT)
}
}
}

在service中調用該方法

//簡化版代碼

@Service
classOcrServiceImpl:OcrService{

@Autowired
privatelateinitvardetectManager:DetectManager

/**
*提交ocr任務
*需要根據(jù)用戶id來做次數(shù)限制
*/
overridefunsubmitOcrTask(userId:String,imageUrl:String):String{
detectManager.matchExceptionally("ocr",userId)
//doocr
}

}

有沒有更優(yōu)雅一點的方法呢? 用注解可能會更好一點(也比較有爭議其實,這邊先支持實現(xiàn))

由于傳入的 content 是跟業(yè)務關聯(lián)的,所以需要通過Spel來將參數(shù)構成對應的content

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權限、多租戶、數(shù)據(jù)權限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://github.com/YunaiV/yudao-cloud
  • 視頻教程:https://doc.iocoder.cn/video/

三、具體實現(xiàn)

1.風控計數(shù)規(guī)則實現(xiàn)

a.自然日/自然小時

自然日/自然小時可以共用一套lua腳本,因為它們只有key不同,腳本如下:

//lua腳本
localcurrentValue=redis.call('get',KEYS[1]);
ifcurrentValue~=falsethen
iftonumber(currentValue)tonumber(ARGV[1])then
returnredis.call('INCR',KEYS[1]);
else
returntonumber(currentValue)+1;
end;
else
redis.call('set',KEYS[1],1,'px',ARGV[2]);
return1;
end;

其中 KEYS[1] 是日/小時關聯(lián)的key,ARGV[1]是上限值,ARGV[2]是過期時間,返回值則是當前計數(shù)值+1后的結果,(如果已經(jīng)達到上限,則實際上不會計數(shù))

b.自然日+自然小時 如前文提到的,兩個的結合實際上并不是單純的拼湊,需要處理回退邏輯

//lua腳本
localdayValue=0;
localhourValue=0;
localdayPass=true;
localhourPass=true;
localdayCurrentValue=redis.call('get',KEYS[1]);
ifdayCurrentValue~=falsethen
iftonumber(dayCurrentValue)tonumber(ARGV[1])then
dayValue=redis.call('INCR',KEYS[1]);
else
dayPass=false;
dayValue=tonumber(dayCurrentValue)+1;
end;
else
redis.call('set',KEYS[1],1,'px',ARGV[3]);
dayValue=1;
end;

localhourCurrentValue=redis.call('get',KEYS[2]);
ifhourCurrentValue~=falsethen
iftonumber(hourCurrentValue)tonumber(ARGV[2])then
hourValue=redis.call('INCR',KEYS[2]);
else
hourPass=false;
hourValue=tonumber(hourCurrentValue)+1;
end;
else
redis.call('set',KEYS[2],1,'px',ARGV[4]);
hourValue=1;
end;

if(notdayPass)andhourPassthen
hourValue=redis.call('DECR',KEYS[2]);
end;

ifdayPassand(nothourPass)then
dayValue=redis.call('DECR',KEYS[1]);
end;

localpair={};
pair[1]=dayValue;
pair[2]=hourValue;
returnpair;

其中 KEYS[1] 是天關聯(lián)生成的key, KEYS[2] 是小時關聯(lián)生成的key,ARGV[1]是天的上限值,ARGV[2]是小時的上限值,ARGV[3]是天的過期時間,ARGV[4]是小時的過期時間,返回值同上

這里給的是比較粗糙的寫法,主要需要表達的就是,進行兩個條件判斷時,有其中一個不滿足,另一個都需要進行回退.

2.注解的實現(xiàn)

a.定義一個@Detect注解

@Retention(AnnotationRetention.RUNTIME)
@Target(AnnotationTarget.FUNCTION,AnnotationTarget.CLASS)
annotationclassDetect(

/**
*事件id
*/
valeventId:String="",

/**
*content的表達式
*/
valcontentSpel:String=""

)

其中content是需要經(jīng)過表達式解析出來的,所以接受的是個String

b.定義@Detect注解的處理類

@Aspect
@Component
classDetectHandler{

privatevallogger=LoggerFactory.getLogger(javaClass)

@Autowired
privatelateinitvardetectManager:DetectManager

@Resource(name="detectSpelExpressionParser")
privatelateinitvarspelExpressionParser:SpelExpressionParser

@Bean(name=["detectSpelExpressionParser"])
fundetectSpelExpressionParser():SpelExpressionParser{
returnSpelExpressionParser()
}

@Around(value="@annotation(detect)")
funoperatorAnnotation(joinPoint:ProceedingJoinPoint,detect:Detect):Any?{
if(detect.eventId.isBlank()||detect.contentSpel.isBlank()){
throwillegalArgumentExp("@Detectconfigisnotavailable!")
}
//轉換表達式
valexpression=spelExpressionParser.parseExpression(detect.contentSpel)
valargMap=joinPoint.args.mapIndexed{index,any->
"arg${index+1}"toany
}.toMap()
//構建上下文
valcontext=StandardEvaluationContext().apply{
if(argMap.isNotEmpty())this.setVariables(argMap)
}
//拿到結果
valcontent=expression.getValue(context)

detectManager.matchExceptionally(detect.eventId,content)
returnjoinPoint.proceed()
}
}

需要將參數(shù)放入到上下文中,并起名為arg1、arg2....

四、測試一下

1.寫法

使用注解之后的寫法:

//簡化版代碼

@Service
classOcrServiceImpl:OcrService{

@Autowired
privatelateinitvardetectManager:DetectManager

/**
*提交ocr任務
*需要根據(jù)用戶id來做次數(shù)限制
*/
@Detect(eventId="ocr",contentSpel="#arg1")
overridefunsubmitOcrTask(userId:String,imageUrl:String):String{
//doocr
}

}

2.Debug看看

12e43304-a03d-11ed-bfe3-dac502259ad0.jpg
  • 注解值獲取成功
  • 表達式解析成功


審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • AI
    AI
    +關注

    關注

    88

    文章

    37012

    瀏覽量

    289969
  • 開源
    +關注

    關注

    3

    文章

    3875

    瀏覽量

    45203
  • 代碼
    +關注

    關注

    30

    文章

    4922

    瀏覽量

    72219

原文標題:風控系統(tǒng)就該這么設計(萬能通用),穩(wěn)的一批!

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    2025年新一批“燈塔工廠”名單公布

    繼今年年初,十三燈塔名單公布后,9月16日,世界經(jīng)濟論壇(WEF)又發(fā)布了最新一批全球“燈塔工廠”名單,分布在7個國家,其中中國有6家,而墨西哥、新加坡、泰國、土耳其、卡塔爾和法國分別有1家。
    的頭像 發(fā)表于 10-16 14:21 ?186次閱讀
    2025年新<b class='flag-5'>一批</b>“燈塔工廠”名單公布

    一批智能體開發(fā)者的生存境況

    中國第一批智能體開發(fā)者的生存模式,比起硅谷同行,要更復雜
    的頭像 發(fā)表于 09-05 11:29 ?2522次閱讀
    第<b class='flag-5'>一批</b>智能體開發(fā)者的生存境況

    舜宇新獲一批車載光學鏡頭專利授權

    近日,舜宇集團自主研發(fā)的一批車載光學鏡頭類專利獲得授權。本專利對應的光學鏡頭通過優(yōu)化設置各透鏡的形狀、光焦度等方面,圍繞高溫穩(wěn)定性、小型化等核心特性,使車載攝像頭在 800 萬像素及以上分辨率下仍能保持優(yōu)異的成像質量。
    的頭像 發(fā)表于 08-06 16:06 ?555次閱讀

    友道智途獲頒上海市新一批智能網(wǎng)聯(lián)汽車示范運營牌照

    2025年7月26日,中國商用車自動駕駛發(fā)展迎來個具有分水嶺意義的時刻。在2025世界人工智能大會上,洋山港智能重卡獲頒了新一批智能網(wǎng)聯(lián)汽車示范運營牌照(商用領域全國首例),這意味著全國第一批基于法規(guī)的主駕無人的智能重卡即將商
    的頭像 發(fā)表于 07-31 15:39 ?792次閱讀

    智己汽車獲得上海市新一批智能網(wǎng)聯(lián)汽車示范運營牌照

    近日,在2025世界人工智能大會(WAIC 2025)上,智己汽車與享道出行、強生出租組成聯(lián)合體,率先獲得上海市新一批智能網(wǎng)聯(lián)汽車示范運營牌照。這不僅是對智己汽車L4級自動駕駛技術實力和安全可靠
    的頭像 發(fā)表于 07-31 15:38 ?837次閱讀

    開放原子開源基金會與新一批開源項目完成捐贈簽約

    近日,在2025開放原子開源生態(tài)大會開幕式上,開放原子開源基金會與新一批開源項目完成捐贈簽約,涵蓋人工智能、具身智能、基礎軟件、區(qū)塊鏈等多個技術領域,為基金會拓展在關鍵技術領域上的布局。這些項目豐富和完善了開源生態(tài)核心技術,構建“工具-技術-場景”閉環(huán)。
    的頭像 發(fā)表于 07-28 17:04 ?633次閱讀

    同星智能入選 “新質企業(yè)”第一批種子企業(yè)名單

    近日,中國生產力促進中心協(xié)會正式公布“新質企業(yè)”第一批種子企業(yè)入庫名單。此次評選基于企業(yè)創(chuàng)新能力、產業(yè)價值、數(shù)字化能力、成長性、可持續(xù)性五大核心指標,旨在培育現(xiàn)代化產業(yè)體系中的標桿企業(yè),推動新質
    的頭像 發(fā)表于 04-03 20:03 ?506次閱讀
    同星智能入選 “新質企業(yè)”第<b class='flag-5'>一批</b>種子企業(yè)名單

    江西薩瑞微電子榮獲2025年第一批次“數(shù)智工廠”企業(yè)稱號

    熱烈祝賀江西省工業(yè)和信息化廳正式公布2025年第一批次“數(shù)智工廠”企業(yè)名單,江西薩瑞微電子技術有限公司憑借在半導體集成電路領域的數(shù)字化創(chuàng)新與智能制造實力,成功入選。上下滑動,查看更多“數(shù)智工廠
    的頭像 發(fā)表于 03-20 11:46 ?725次閱讀
    江西薩瑞微電子榮獲2025年第<b class='flag-5'>一批</b>次“數(shù)智工廠”企業(yè)稱號

    鴻道Intewell操作系統(tǒng)入選工信部第一批先進適用技術名單

    程序,形成了第一批先進適用技術名單。科東軟件自主研發(fā)的“基于鴻道(Intewell)操作系統(tǒng)混合關鍵技術的智能工控系統(tǒng)”入選“第一批先進適用技術名單”。
    的頭像 發(fā)表于 03-04 11:29 ?609次閱讀
    鴻道Intewell操作<b class='flag-5'>系統(tǒng)</b>入選工信部第<b class='flag-5'>一批</b>先進適用技術名單

    達實智能入選深圳市第一批全屋智能建筑應用試點項目

    近期,深圳市住房和建設局公布了《深圳市第一批全屋智能建筑應用試點項目清單》,達實智能大廈憑借在空間場景及物聯(lián)網(wǎng)平臺的應用入選清單,成為首批9個項目之
    的頭像 發(fā)表于 02-07 09:29 ?1068次閱讀

    手機和鋰電池納入第一批工業(yè)產品碳足跡核算規(guī)則團體標準推薦清單

    了《工業(yè)產品碳足跡核算規(guī)則團體標準推薦清單(第一批)》(以下簡稱《清單》)。手機和鋰電池作為重要的電子產品及其關鍵組件,其碳排放量對全球氣候變化具有重要影響,因此
    的頭像 發(fā)表于 01-21 17:47 ?1370次閱讀
    手機和鋰電池納入第<b class='flag-5'>一批</b>工業(yè)產品碳足跡核算規(guī)則團體標準推薦清單

    十堰新一批智慧路燈投用,集多種功能于身 智慧路燈案例分享

    十堰新一批智慧路燈投用,集多種功能于身 智慧路燈案例分享
    的頭像 發(fā)表于 01-03 10:39 ?509次閱讀
    十堰新<b class='flag-5'>一批</b>智慧路燈投用,集多種功能于<b class='flag-5'>一</b>身 智慧路燈案例分享

    芯來科技入選上海市新輪第一批重點“小巨人”企業(yè)

    )等文件規(guī)定,上海市新輪第一批重點“小巨人”企業(yè)實施期初獎補資金分配方案正式公布。芯來科技憑借在RISC-V領域的專業(yè)化實力與示范作用成功入選上海市新輪第一批重點“小巨人”企業(yè)。
    的頭像 發(fā)表于 12-19 15:38 ?993次閱讀

    本人研,做DFB激光穩(wěn)頻,目前只差FPGA ADC DAC做個反饋系統(tǒng)

    我目前要做的是DFB激光器的穩(wěn)頻。目前差個數(shù)字電路的穩(wěn)系統(tǒng),我打算用FPGA來實現(xiàn)。要求:個ADC(內置或者外接的模塊)八通道以上,來
    發(fā)表于 12-01 21:48

    總投資超60億元,一批半導體相關項目簽約江蘇宜興

    近日,宜興經(jīng)開區(qū)開放創(chuàng)新合作大會在宜興陶都半島酒店舉行。一批重要載體現(xiàn)場揭牌,一大批重磅項目集中簽約,為建設國際化現(xiàn)代化流園區(qū)注入新的動能。
    的頭像 發(fā)表于 10-24 17:49 ?1045次閱讀