从ASP到PHP的Facebook身份验证脚本

从ASP到PHP的Facebook身份验证脚本,php,authentication,facebook,signature,Php,Authentication,Facebook,Signature,我正在尝试将下面的代码转换成php版本,如果有人能帮忙的话,谢谢 private bool IsValidFacebookSignature() { //keys must remain in alphabetical order string[] keyArray = { "expires", "session_key", "ss", "user" }; string signature = ""; foreach (s

我正在尝试将下面的代码转换成php版本,如果有人能帮忙的话,谢谢

private bool IsValidFacebookSignature()
    {
        //keys must remain in alphabetical order
        string[] keyArray = { "expires", "session_key", "ss", "user" };
        string signature = "";

        foreach (string key in keyArray)
            signature += string.Format("{0}={1}", key, GetFacebookCookie(key));

        signature += SecretKey; //your secret key issued by FB

        MD5 md5 = MD5.Create();
        byte[] hash = md5.ComputeHash(Encoding.UTF8.GetBytes(signature.Trim()));

        StringBuilder sb = new StringBuilder();
        foreach (byte hashByte in hash)
            sb.Append(hashByte.ToString("x2", CultureInfo.InvariantCulture));

        return (GetFacebookCookie("") == sb.ToString());
    }

    private string GetFacebookCookie(string cookieName)
    {
        //APIKey issued by FB
        string fullCookie = string.IsNullOrEmpty(cookieName) ? ApiKey : ApiKey + "_" + cookieName;

        return Request.Cookies[fullCookie].Value;
    }

它未经测试,但请尝试以下方法:

function IsValidFacebookSignature() {
    $keyArray = array( 'expires', 'session_key', 'ss', 'user' );
    $signature = '';

    foreach( $key in $keyArray ) {
        $signature .= "$key=".GetFacebookCookie($key);
    }

    $signature .= $SecretKey;
    $hash = md5(trim($signature));

    return GetFacebookCookie('') == $hash;
}

function GetFacebookCookie($cookieName) {
    $fullCookie = empty($cookie) ? $APIKey : $APIKey . '_' . $cookieName;
    return $_COOKIES[$fullCookie];
}

我不确定您希望在哪里声明
$SecretKey
$APIKey
,但这是基本想法。

很酷,谢谢。不幸的是,它不起作用——我放弃了这种方法,选择了完全不同的方法,但感谢你的努力。