快手的API接口都使用簽名作了保護,API接口請求使用的是POST方法,簽名是POST表單中的sig參數,咱們看一下API請求的內容:android
POST http://api.gifshow.com/rest/n... HTTP/1.1
User-Agent: kwai-android
Connection: keep-alive
Accept-Language: zh-cn
X-REQUESTID: 634454806
Content-Type: application/x-www-form-urlencoded
Content-Length: 83
Host: api.gifshow.com
Accept-Encoding: gzip算法
userId=51363790&sig=4fa5b967070fe445ccec17fa6a53c820&client_key=3c2cd3f3&os=androidapi
sig的計算方法以下:app
把url中的參數放入map1中;
把表單中的參數放入map2中;
把map1和map2中的元素以key=value的形式放入arraylist中;ui
對arraylist進行排序;
把arraylist中的元素按順序拼接成一個字符串str;
把str轉成bytearray;
調用CPU.getClock(),傳入str計算簽名;
CPU.getClock()是一個native方法,在libcore.so中實現,快手接口簽名算法大概就這些,對細節感興趣的朋友能夠聯繫我。url