Steam OpenID PHP和HTML

时间:2015-10-06 20:10:39

标签: php openid steam-web-api

所以我也尝试为我的网站制作一个蒸汽登录按钮,但它没有重定向到我想要的。相反,它只是将用户指向具有用户名和注销按钮的普通站点。我没有写这个代码,我只是为了尝试而复制了别人。我正试图将它指向index.php,但它也不想要。 这是代码:

<?php
                        error_reporting(E_ERROR | E_PARSE | E_WARNING);

$user = new user;
$user->apikey = ""; // put your API key here
$user->domain = "localhost/index.php"; // put your domain


class user
{
    public static $apikey;
    public static $domain;

    public function GetPlayerSummaries ($steamid)
    {
        $response = file_get_contents('http://api.steampowered.com/ISteamUser/GetPlayerSummaries/v0002/?key=' . $this->apikey . '&steamids=' . $steamid);
        $json = json_decode($response);
        return $json->response->players[0];
    }

    public function signIn ()
    {
        require_once 'openid.php';
        $openid = new LightOpenID($this->domain);// put your domain
        if(!$openid->mode)
        {
            $openid->identity = 'http://steamcommunity.com/openid';
            header('Location: ' . $openid->authUrl());
        }
        elseif($openid->mode == 'cancel')
        {
            print ('User has canceled authentication!');
        }
        else
        {
            if($openid->validate())
            {
                preg_match("/^http:\/\/steamcommunity\.com\/openid\/id\/(7[0-9]{15,25}+)$/", $openid->identity, $matches); // steamID: $matches[1]
                setcookie('steamID', $matches[1], time()+(60*60*24*7), '/'); // 1 week
                header('Location: /');
                exit;
            }
            else
            {
                print ('fail');
            }
        }
    }
}

if(isset($_GET['login']))
{
    $user->signIn();
}
if (array_key_exists( 'logout', $_POST ))
{
    setcookie('steamID', '', -1, '/');
    header('Location: /');
}


if(!$_COOKIE['steamID'])
{
    print ('<form action="?login" method="post">
        <input type="image" src="http://cdn.steamcommunity.com/public/images/signinthroughsteam/sits_large_border.png"/>
        </form>');
}
else
{
    print('<form method="post"><button title="Logout" name="logout">Logout</button></form>');
    echo $user->GetPlayerSummaries($_COOKIE['steamID'])->personaname;
}




?>

我删除了Apikey,因为我不知道它的保存是否只是为了让它在网上给大家看这样的。 谢谢大家:)有一个很棒的一天。对不起我的语法我的英语不太好。再次感谢:D

1 个答案:

答案 0 :(得分:0)

我在Steam网站上使用相同的代码 See here.

            preg_match("/^http:\/\/steamcommunity\.com\/openid\/id\/(7[0-9]{15,25}+)$/", $openid->identity, $matches); // steamID: $matches[1]
            setcookie('steamID', $matches[1], time()+(60*60*24*7), '/'); // 1 week
            header('Location: /');
            exit;

在该代码区域,应该有一个修复。 我似乎无法找到我的PHP,因为我使用2个php链接并使用框架将它们与其中一个连接起来非常复杂。

如你所说

{
print('<form method="post"><button title="Logout" name="logout">Logout</button></form>');
echo $user->GetPlayerSummaries($_COOKIE['steamID'])->personaname; 
}

我是这样做的,登录/注销按钮加载了这个PHP代码。不确定这是否会对你有所帮助! 如果您使用此代码,请确保您已为登录网站启用allow_url_fopen

$ sign_inout = file_get_contents('http://kuramacraft.net/steam/signinout.php');

echo $ sign_inout;

感谢您花时间阅读本文!