接口鑒權是什麼意思?

一、什麼是接口鑒權?

在開放API的情況下,接口鑒權是指API接口認證過程,防止未被授權的第三方應用、未認證用戶和惡意攻擊者訪問API接口。接口鑒權是一種難度比較高的技術,它需要在無障礙、高效、安全和穩定的前提之下,達到對特定接口資源的保護。

通常來講,接口鑒權的前提是要確定接口資源的安全級別和敏感程度,然後再決定採用何種方式進行授權。否則,未經過接口鑒權程序授權的請求就會直接被拒絕,無論請求的來源是API接口的所屬者還是第三方應用或者是某個惡意用戶。

二、接口鑒權的方式有哪些?

接口鑒權的方式有以下幾種:

1. Token鑒權

Token是由服務端生成的一串字符串,用於標識某個用戶的身份。當用戶登錄成功後,服務端返回給客戶端一個Token,客戶端將Token保存在本地,以後每次訪問服務器資源時都必須帶上它。服務端驗證Token,如果驗證通過,就返回請求結果;否則就返回401(未授權)。

2. HMAC鑒權

HMAC是一種散列消息認證碼,利用哈希函數和一個密鑰對消息進行加密和驗證,實現安全的通信。在HMAC鑒權中,客戶端通過把請求信息(如請求頭、請求參數等)和一段隨機字符串一起進行HMAC的哈希計算,得到一個認證碼(hash),將hash值添加到請求中的Authorization頭中。服務端接收到請求後,自行再進行一次哈希計算,比較計算出來的hash值是否匹配,如果匹配,則表明該請求是合法的。

3. Basic認證

Basic認證是HTTP標準的一種認證方式,其中用戶憑證需要在每個請求中明文傳輸。在Basic認證中,客戶端向服務端發送一個擁有用戶憑證的請求,服務端會根據該請求中的憑證信息,在服務端的用戶數據庫中校驗用戶身份。如果校驗成功,服務端就返回請求結果;否則就返回401(未授權)。

三、示例代碼

1. Token鑒權示例代碼:

// 服務端示例代碼(Node.js)
const jwt = require('jsonwebtoken');

// 鑒權函數
function auth(req, res, next) {
  const token = req.headers.authorization.split(' ')[1];
  
  jwt.verify(token, 'secret', (err, decoded) => {
    if (err) {
      res.status(401).json({ msg: 'Token 驗證失敗!' });
    } else {
      // 驗證通過,執行下一步操作
      next();
    }
  });
}

// 生成 Token
function generateToken() {
  const payload = { name: 'John Doe', age: 32 };
  return jwt.sign(payload, 'secret', { expiresIn: '1h' });
}

// 客戶端示例代碼(JavaScript)
fetch('/api/user', {
  method: 'GET',
  headers: {
    'Authorization': 'Bearer ' + token
  }
})

2. HMAC鑒權示例代碼:

// 服務端示例代碼(Java)
// 生成 HMAC 簽名
public static String generateHmac(String data, String secret) throws Exception {
  SecretKeySpec signingKey = new SecretKeySpec(secret.getBytes(), "HmacSHA256");
  Mac mac = Mac.getInstance("HmacSHA256");
  mac.init(signingKey);

  byte[] rawHmac = mac.doFinal(data.getBytes());
  return Base64.getEncoder().encodeToString(rawHmac);
}

// 鑒權函數
public static boolean auth(HttpServletRequest request) {
  String authorizationHeader = request.getHeader("Authorization");
  if (authorizationHeader == null || !authorizationHeader.startsWith("HMAC")) {
    return false;
  } else {
    String data = buildDataString(request);
    String signature = authorizationHeader.substring(5);

    try {
      String hmac = generateHmac(data, "secret");
      return hmac.equals(signature);
    } catch (Exception e) {
      return false;
    }
  }
}

// 客戶端示例代碼(JavaScript)
const headers = {
  'Content-Type': 'application/json',
  'Authorization': 'HMAC ' + generateHmac(JSON.stringify(data), 'secret')
};

fetch('/api/user', {
  method: 'POST',
  headers: headers,
  body: JSON.stringify(data)
})

3. Basic認證示例代碼:

// 服務端示例代碼(Python)
from flask import Flask, request, Response

app = Flask(__name__)

@app.route('/api/user')
def user():
    auth = request.authorization
    if not auth or not auth.username == 'username' or not auth.password == 'password':
        # 認證失敗,返回 401 錯誤
        return Response('用戶名或密碼錯誤!', 401, {'WWW-Authenticate': 'Basic realm="Login Required"'})
    else:
        # 認證成功,返回請求結果
        return 'Hello World!'

if __name__ == '__main__':
    app.run()

// 客戶端示例代碼(JavaScript)
const headers = new Headers();
headers.append('Authorization', 'Basic ' + btoa('username:password'));

fetch('/api/user', {
  method: 'GET',
  headers: headers
})

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/234113.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-11 17:13
下一篇 2024-12-11 17:13

相關推薦

  • Java 監控接口返回信息報錯信息怎麼處理

    本文將從多個方面對 Java 監控接口返回信息報錯信息的處理方法進行詳細的闡述,其中包括如何捕獲異常、如何使用日誌輸出錯誤信息、以及如何通過異常處理機制解決報錯問題等等。以下是詳細…

    編程 2025-04-29
  • Python接口自動化測試

    本文將從如下多個方面對Python編寫接口自動化進行詳細闡述,包括基本介紹、常用工具、測試框架、常見問題及解決方法 一、基本介紹 接口自動化測試是軟件測試中的一種自動化測試方式。通…

    編程 2025-04-27
  • Jadoor門鎖開發接口接入指南

    本文將從多個方面詳細介紹如何將門鎖接入Jadoor平台的開發接口,方便開發者們快速實現門鎖遠程控制、開鎖記錄查看等功能。 一、Jadoor門鎖開發接口簡介 Jadoor是一款用於密…

    編程 2025-04-27
  • 後端接口設計開發經驗分享

    在受到前端某些限制或特殊需求時,後端接口的設計和開發顯得尤為重要。下面從以下幾個方面進行講述。 一、命名規範 合理的命名規範可以大大提高接口的可讀性和可維護性。以下是一些命名規範的…

    編程 2025-04-27
  • 期貨數據接口 Python:打通數字資產交易數據的關鍵

    本文將從以下幾個方面討論期貨數據接口 Python: 一、數據接口簡介 期貨數據接口是指為期貨從業人員提供用於獲取歷史、實時及未來交易數據的工具。Python是一種常用的編程語言,…

    編程 2025-04-27
  • 如何快速發布http接口

    想要快速發布http接口,可以從以下幾個方面入手。 一、選擇合適的框架 選擇合適的框架對於快速發布http接口非常重要。目前比較受歡迎的框架有Flask、Django、Tornad…

    編程 2025-04-27
  • Javaweb 接口返回數據的定義與實現

    本文將介紹 javaweb 如何定義接口返回數據,並提供相應的代碼示例。 一、接口返回數據的定義 在 javaweb 開發中,我們經常需要通過接口返回數據。接口返回的數據格式通常是…

    編程 2025-04-27
  • Postman接口自動化

    一、安裝和使用Postman Postman是一個強大的API測試工具,可以使用它來測試各種類型的API請求和響應。在進行接口自動化測試之前,首先需要安裝和使用Postman。以下…

    編程 2025-04-25
  • POST接口測試完整指南

    一、POST接口測試介紹 POST接口測試是一種測試的方式,主要用於測試Web應用程序。它是通過POST HTTP方法發送HTTP請求到Web服務器並且對服務器的響應進行驗證的一種…

    編程 2025-04-25
  • 電費充值API接口詳解

    一、API介紹 電費充值API接口是一種允許用戶通過其他平台或應用程序進行電費充值的接口,方便用戶快速充值電費。 通過電費充值API接口,用戶可以通過其他應用程序或平台,直接將資金…

    編程 2025-04-25

發表回復

登錄後才能評論