如何設(shè)計(jì)B端SDK和API的激活與安全機(jī)制?

1 評(píng)論 10611 瀏覽 110 收藏 14 分鐘

在C端流量紅利逐漸消失的今天,很多企業(yè)開始轉(zhuǎn)向 to B的生意。

而B端的生意就離不開SDK和API。這是公司對(duì)外輸出技術(shù)方案必不可少的兩種不同的形式。

因此,本文將結(jié)合SDK和API進(jìn)行介紹,分析它們的區(qū)別以及如何設(shè)置激活與安全機(jī)制。

1. SDK和API的區(qū)別

首先我們簡(jiǎn)單來(lái)講一下SDK和API的區(qū)別。

1.1 什么是API?

API,全稱Application Programming Interface,即應(yīng)用程序編程接口。

API其實(shí)就是把做好的功能,封裝成各種預(yù)先定義好的函數(shù),其他人想使用這些已有的功能,只需要調(diào)用這些函數(shù),并傳遞必要的參數(shù)即可。

API的主要作用是,程序員不需要深究API背后功能實(shí)現(xiàn)的具體邏輯,程序員只需要直接調(diào)用API就可以使用其背后的功能邏輯,這節(jié)省了程序員一大部分的工作,大大提升了效率。

舉個(gè)例子:

銀行的窗口就類似一個(gè)個(gè)的API,他們分別有不同的功能,比如取款、存款、對(duì)公等業(yè)務(wù)。

而我們預(yù)先填好的表格信息,交給窗口的工作人員,就是傳遞必要的“參數(shù)”信息給這個(gè)窗口API,然后使用它的存款功能。

我們不需要理解工作人員具體需要哪些操作,其中涉及多少?gòu)?fù)雜邏輯。

只需要來(lái)到窗口(調(diào)用API),上交表格(傳遞必要信息)就能使用該功能服務(wù)。

1.2 什么是SDK?

SDK 就是 Software Development Kit 的縮寫,翻譯過(guò)來(lái)——軟件開發(fā)工具包。

這是一個(gè)覆蓋面相當(dāng)廣泛的名詞,可以這么說(shuō):輔助開發(fā)某一類軟件的相關(guān)文檔、范例和工具的集合都可以叫做SDK。

SDK可以簡(jiǎn)單的認(rèn)為是一系列API的程序包集合。在這個(gè)程序包中是一個(gè)完整的軟件功能,這份程序包幾乎是全封閉的,只有一個(gè)小小接口(API)可以聯(lián)通外界。

還是剛剛銀行的例子:

可以把銀行看做是一整個(gè)SDK,銀行SDK程序包能幫你完成存款、取款等業(yè)務(wù)。

銀行SDK唯一聯(lián)通外界的就是它的大門,或者說(shuō)是取號(hào)機(jī)(API),只有進(jìn)入銀行然后取號(hào),才能在不同的窗口辦理服務(wù)。

而這些不同的窗口,就可以看成一個(gè)個(gè)不同功能的API接口。

2. API的接入安全機(jī)制

安全機(jī)制,其實(shí)是為了保護(hù)我方后臺(tái),主要有兩點(diǎn):

  1. 不被不明身份者訪問(wèn)
  2. 不被惡意大量的請(qǐng)求攻擊

先來(lái)簡(jiǎn)單說(shuō)一下API的接入安全機(jī)制。

API的安全機(jī)制設(shè)計(jì)主要考慮兩個(gè)方面:

  1. API接入方案如何避免接口盜用(防止不明身份者訪問(wèn))
  2. Http接口請(qǐng)求如何避免攻擊(防止被惡意大量請(qǐng)求攻擊)

第一個(gè)方面,需要客戶對(duì)自家的后臺(tái)做一層封裝,然后我們后臺(tái)僅接受客戶后臺(tái)接口傳遞的請(qǐng)求。

第二個(gè)方面,需要在我方后臺(tái)建立IP白名單,提供給客戶后臺(tái),方便雙方進(jìn)行加密驗(yàn)證。識(shí)別哪些是客戶的請(qǐng)求,哪些是惡意請(qǐng)求。

3. SDK的接入安全機(jī)制

為了防止客戶拿到我們的SDK以后白嫖,或者為所欲為,我們需要在客戶接入SDK,請(qǐng)求我方服務(wù)的時(shí)候進(jìn)行激活校驗(yàn)。

就像是我們買票進(jìn)站乘車一樣,需要出示身份證和車票進(jìn)行校驗(yàn)方可通過(guò)。

SDK最終都是會(huì)被集成到硬件設(shè)備中提供服務(wù),尤其是AI公司的技術(shù)方案,不管是視覺(jué)還是語(yǔ)音,最后交付的都是硬件產(chǎn)品。

通常激活的時(shí)機(jī),都是在硬件設(shè)備進(jìn)行第一次啟動(dòng)的時(shí)候進(jìn)行。

SDK的激活涉及到我方對(duì)客戶的計(jì)費(fèi),所以激活邏輯的設(shè)計(jì)要非常的仔細(xì)和嚴(yán)謹(jǐn)(畢竟都是錢哪。。)

一般來(lái)說(shuō),SDK的激活方案可以分為三種(以下說(shuō)法參考思必馳的產(chǎn)品授權(quán)方案):

  1. 預(yù)燒錄
  2. 預(yù)登記
  3. 動(dòng)態(tài)注冊(cè)

預(yù)燒錄,指的是,我們后臺(tái)預(yù)先生成授權(quán)的license文件,然后預(yù)先寫入硬件設(shè)備的存儲(chǔ)文件中。在設(shè)備首次啟動(dòng)的時(shí)候,就直接調(diào)取license文件進(jìn)行激活。這種方式適用于需要不聯(lián)網(wǎng)提供服務(wù)的場(chǎng)景。

預(yù)登記,指的是,預(yù)先登記設(shè)備白名單,以用戶設(shè)備注冊(cè)激活的一種授權(quán)方式。這種方式適用于客戶提前知道所需授權(quán)設(shè)備的設(shè)備標(biāo)識(shí)的場(chǎng)景

動(dòng)態(tài)注冊(cè),指的是,每次設(shè)備激活,后臺(tái)動(dòng)態(tài)給這些設(shè)備進(jìn)行激活并注冊(cè)的一種形式。這種方式適用于客戶可以提供設(shè)備的唯一標(biāo)識(shí),但是提前不知道哪些設(shè)備需要授權(quán),不知道有多少設(shè)備需要授權(quán)的場(chǎng)景。

下面想主要講一下,我在設(shè)計(jì)預(yù)登記和動(dòng)態(tài)注冊(cè)時(shí)遇到的一些坑。

3.1 預(yù)登記對(duì)我方友好,但是對(duì)客戶不太靈活

預(yù)登記方式其實(shí)對(duì)我方來(lái)說(shuō)是比較友好的,因?yàn)榭蛻籼崆疤峁?zhǔn)確的設(shè)備唯一標(biāo)識(shí)的時(shí)候,我們可以很方面的進(jìn)行激活和統(tǒng)計(jì),說(shuō)直白點(diǎn),就是方便收錢。

所以,客戶為了省錢,有可能采取作弊策略:將一個(gè)設(shè)備的唯一標(biāo)識(shí)給多臺(tái)設(shè)備進(jìn)行使用。

因?yàn)樵O(shè)備標(biāo)識(shí),一般是設(shè)備序列號(hào)(SN),對(duì)于硬件廠商來(lái)說(shuō)是可以自己按照一定的規(guī)則隨便刷的。

那為了防止被客戶白嫖,我們自然要設(shè)計(jì)一套防作弊策略:不僅僅采集客戶提供的設(shè)備序列號(hào),還要采集一些設(shè)備的其他信息進(jìn)行輔助判斷,該序列號(hào)只綁定了一臺(tái)設(shè)備。

當(dāng)客戶想白嫖我們,將設(shè)備A的序列號(hào)給設(shè)備B使用,那么在激活校驗(yàn)的時(shí)候,就會(huì)發(fā)現(xiàn)設(shè)備B的序列號(hào)關(guān)聯(lián)的信息和我們記錄的信息(設(shè)備A)不同,如此就可以認(rèn)定客戶是想白嫖,激活失敗。

上述方式看起來(lái)比較完美的解決了客戶作弊的問(wèn)題。但是對(duì)于部分客戶來(lái)說(shuō)就會(huì)造成不便。

有些客戶在對(duì)接SDK后,會(huì)進(jìn)行測(cè)試。在測(cè)試的過(guò)程中,客戶會(huì)不斷的對(duì)硬件設(shè)備進(jìn)行刷機(jī)、恢復(fù)出廠設(shè)置等騷操作。

而刷機(jī)、恢復(fù)出廠設(shè)置會(huì)改變?cè)O(shè)備的信息(例如AndroidID),那么就會(huì)造成同樣的序列號(hào)在同一臺(tái)設(shè)備上不能激活了。

因?yàn)樗C(jī)改變了它的設(shè)備信息,我們會(huì)認(rèn)為這不是同一臺(tái)設(shè)備。

你可能會(huì)說(shuō),那客戶再寫一個(gè)序列號(hào)不就行了,反正客戶可以自己刷序列號(hào)。

客戶是上帝,你不能指望客戶去干這樣的累活。當(dāng)然是我們來(lái)優(yōu)化了。

為了解決這個(gè)問(wèn)題,我們想到一個(gè)方案:超級(jí)序列號(hào)。這個(gè)序列號(hào)必須是我們來(lái)生成(可控),擁有無(wú)限次激活,可以在多臺(tái)設(shè)備上使用的超能力。

但是為了防止客戶拿這個(gè)超級(jí)序列號(hào)白嫖我們,我們需要給這個(gè)超級(jí)序列號(hào)設(shè)置時(shí)間限制。在有效時(shí)間內(nèi)可以隨意使用,一旦過(guò)了有效期就會(huì)失效。

3.2 動(dòng)態(tài)注冊(cè)雖然靈活,但是對(duì)于統(tǒng)計(jì)來(lái)說(shuō)麻煩

動(dòng)態(tài)注冊(cè)就是在設(shè)備第一次啟動(dòng)激活的時(shí)候,上傳設(shè)備的信息,包括:序列號(hào)、MAC(藍(lán)牙+WiFi)、IMEI和AndroidID。

但是這些信息不一定能獲取到。

IMEI,國(guó)際移動(dòng)設(shè)備識(shí)別碼(International Mobile Equipment Identity,IMEI)

IMEI本該最理想的設(shè)備ID,具備唯一性,恢復(fù)出廠設(shè)置不會(huì)變化(真正的設(shè)備相關(guān))。

但是Android6.0以后,就需要用戶授權(quán)才能使用,而且在Android10.0以后,就會(huì)徹底拒絕獲取IMEI。

并且,IMEI其實(shí)只有通訊的設(shè)備才會(huì)有,如果沒(méi)有通訊(簡(jiǎn)單理解,就是電話卡)模塊的話,也不一定有IMEI號(hào)。

序列號(hào)(SN)

設(shè)備序列號(hào)由廠商提供,如果廠商比較規(guī)范的話,序列號(hào)應(yīng)該是唯一的,也不會(huì)隨刷機(jī)或恢復(fù)出廠設(shè)置等改變。

但是你不能把利益建立在人性的基礎(chǔ)上,那太不靠譜。所以序列號(hào),其實(shí)更多只能作為輔助信息來(lái)進(jìn)行判斷。

MAC地址

MAC地址一般指藍(lán)牙MAC、WiFi Mac或者是兩者的拼接。但是獲取同樣需要權(quán)限,而且如果設(shè)備沒(méi)有藍(lán)牙模塊,沒(méi)有WiFi模塊的話,也不一定有MAC地址。

Android ID

Android ID 是獲取門檻最低的,不需要任何權(quán)限,64bit 的取值范圍,唯一性算是很好的了。但是不足之處也很明顯:刷機(jī)、root、恢復(fù)出廠設(shè)置等會(huì)使得 Android ID 改變

所以,我們?cè)谠O(shè)計(jì)動(dòng)態(tài)注冊(cè)激活邏輯的時(shí)候,就需要考慮到這些情況。

動(dòng)態(tài)注冊(cè)的激活邏輯,就是每次激活的時(shí)候,后臺(tái)記錄設(shè)備上傳的四個(gè)設(shè)備信息(有的不一定有)。

然后每次其他設(shè)備激活的時(shí)候,就把該要激活的設(shè)備信息在已激活的設(shè)備信息記錄中進(jìn)行比對(duì),比對(duì)的規(guī)則有兩方面:

  1. 所上報(bào)的設(shè)備信息種類是否一致,種類指的是四種設(shè)備信息
  2. 所上報(bào)的設(shè)備信息是否一致

這樣的激活邏輯,雖然能保證最大程度的識(shí)別出不同的設(shè)備,但是會(huì)給統(tǒng)計(jì)激活設(shè)備上(統(tǒng)計(jì)是為了收錢)造成麻煩。

例如,AndroidID,會(huì)隨著刷機(jī)、恢復(fù)出廠設(shè)置而改變。這就會(huì)成為客戶扯皮的點(diǎn)。

客戶會(huì)說(shuō):“我并沒(méi)有更換設(shè)備,只是因?yàn)樵O(shè)備故障需要刷機(jī)或者恢復(fù)出廠設(shè)置,你就多收我一臺(tái)設(shè)備的錢,當(dāng)我是冤大頭嗎?”

雖然這可以通過(guò)商務(wù)的手段去解決,但是還是那句話,客戶是霸霸嘛。

其實(shí),從上面我們描述四大設(shè)備信息的特征來(lái)看,AndroidID具有如下優(yōu)秀屬性:

  1. 一定能獲取到;
  2. 只有刷機(jī)操作才會(huì)改變,無(wú)法人為指定。

所以,完全可以以AndroidID作為主要依據(jù),只要AndroidID一致,不管其他參數(shù)種類和參數(shù)值是否相同,都可以認(rèn)為是一臺(tái)設(shè)備。

我們只需要找出那些,因?yàn)樗C(jī)或恢復(fù)出廠設(shè)置導(dǎo)致AndroidID改變的設(shè)備,而這些是客戶扯皮的主要部分。

因此,在我們給設(shè)備動(dòng)態(tài)注冊(cè)的時(shí)候,要采用嚴(yán)格的規(guī)則,只要有一點(diǎn)不一樣,就重新注冊(cè)設(shè)備信息。

但是在統(tǒng)計(jì)激活的設(shè)備信息上,可以根據(jù)一定的規(guī)則,將具有爭(zhēng)議的注冊(cè)設(shè)備信息給統(tǒng)計(jì)出來(lái),做到扯皮也是要有準(zhǔn)備和技術(shù)含量的。

SDK 和 API 是公司輸出技術(shù)的主要手段,而如何設(shè)計(jì)激活邏輯和安全機(jī)制,是保證公司不被白嫖的手段,需要認(rèn)真和謹(jǐn)慎的考慮。

以上內(nèi)容是在工作中的一些總結(jié),僅供大家參考。

 

本文由 @Jarvan 原創(chuàng)發(fā)布于人人都是產(chǎn)品經(jīng)理。未經(jīng)許可,禁止轉(zhuǎn)載

題圖來(lái)自Unsplash,基于CC0協(xié)議

更多精彩內(nèi)容,請(qǐng)關(guān)注人人都是產(chǎn)品經(jīng)理微信公眾號(hào)或下載App
評(píng)論
評(píng)論請(qǐng)登錄
  1. 看到這篇文章真的是深有同感,其實(shí)就是考慮在線激活和離線激活且兩種形式并存,并且需要考慮客戶頻繁刷機(jī)導(dǎo)致的激活碼失效問(wèn)題,補(bǔ)充一下,超級(jí)序列號(hào)的話可以寫個(gè)程序,監(jiān)控同一個(gè)設(shè)備序列號(hào)激活的次數(shù),如果發(fā)現(xiàn)這臺(tái)設(shè)備序列號(hào)在一天內(nèi)或者幾天內(nèi)激活了很多次,超過(guò)了設(shè)置的閾值,就可以視為異常,讓商務(wù)上門吧

    來(lái)自廣東 回復(fù)