【问题标题】:Authorization request header OAuth 2.0授权请求标头 OAuth 2.0
【发布时间】:2012-04-12 21:42:44
【问题描述】:

我正在尝试在我正在进行的项目中实施 OAuth 2.0。我能够使用身份验证服务器进行身份验证,但是我遇到了资源服务器的问题。我们正在使用 MAC 令牌(spec)。您可以在规范的 3.1 中看到我需要发送一个 Authorization 请求标头,其中包括以下内容。我对此毫无意义。有人可以告诉我我应该在这里做什么吗?

credentials = "MAC" [ RWS 1#param ]
param = id /
nonce /
body-hash /
ext /
mac
id = "id" "=" <"> plain-string <">
nonce = "nonce" "=" <"> 1*DIGIT ":" plain-string <">
body-hash = "bodyhash" "=" <"> plain-string <">
ext = "ext" "=" <"> plain-string <">
mac = "mac" "=" <"> plain-string <">
plain-string = 1*( %x20-21 / %x23-5B / %x5D-7E )

更新

我觉得我正在取得进展,但我觉得我离解决这个问题还很远。

所以我正在构建类似以下的东西

StringBuilder header = new StringBuilder("MAC ").append("id=\"").append(sharedPrefs.getString(Constants.ACCESS_TOKEN, "error")).append("\",nonce=\"").append(createNonce()).
                append("\",bodyhash=\"").append(bodyHash).append("\",mac=\"").append(mac).append("\"");

我这样计算body hash

public static String SHA256(String text) throws  UnsupportedEncodingException  { 
        MessageDigest md = null;
        try {
            md = MessageDigest.getInstance("SHA-256");
        } catch (NoSuchAlgorithmException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        byte[] shahash = new byte[40];
        md.update(text.getBytes("iso-8859-1"), 0, text.length());
        shahash = md.digest();
        return Base64.encodeToString(shahash, Base64.DEFAULT);
}

还有这样的mac

private String hmacSHA256(String data) throws Exception {
    String key = sharedPrefs.getString(Constants.SECRET, "error");
    SecretKeySpec secretKey = new SecretKeySpec(key.getBytes("UTF-8"), "HmacSHA256");
    Mac mac = Mac.getInstance("HmacSHA256");
    mac.init(secretKey);
    byte[] hmacData = mac.doFinal(data.getBytes("UTF-8"));
    //Log.i(TAG, "BYTE ARRAY TO STRING: " + Base64.encodeToString(hmacData, Base64.DEFAULT));
    String value = Base64.encodeToString(hmacData, Base64.DEFAULT);
    return value;
}

我遇到了问题,因为服务器没有响应。这真的让我发疯了,我无法想象这个文档对任何人来说都是清楚的。

【问题讨论】:

    标签: android oauth oauth-2.0


    【解决方案1】:

    您需要注意 MAC access authentication scheme 是 oauth2 协议的扩展,类似于 HTTP 基本访问,但是可选,因此无需在每个资源服务器中都实现。

    因此,如果您发出 未经身份验证的请求,而 资源服务器 会做出如下响应:

    HTTP/1.1 401 Unauthorized 
    WWW-Authenticate: MAC
    

    MAC,表示您被允许使用此方案的身份验证。

    目前为基于 oauth2 的资源服务器实施的最常见的身份验证方案是:bearer


    如果您仍然对如何实施此规范有疑虑,Github 上有一个 excelent source for Android 来完成它。你需要的java类可能是this

    玩得开心!

    【讨论】:

    • 服务器团队已经实现了 mac 令牌而不是不记名令牌。虽然
    • 只是为了让将来使用该库的任何人都清楚,mac 令牌部分没有完全工作
    猜你喜欢
    • 2012-06-19
    • 1970-01-01
    • 2017-02-01
    • 2016-07-31
    • 1970-01-01
    • 1970-01-01
    • 2017-06-20
    • 2017-12-25
    • 1970-01-01
    相关资源
    最近更新 更多