2010-10-16 78 views
1

我开始创建谷歌应用程序市场应用程序时遇到了很多麻烦。混合演示不返回oauth请求令牌

我已经尝试过大量的演示,包括可以从谷歌下载的php hello world示例。在任何情况下,openid部分都可以正常工作,但oauth失败。

我已经跟踪到混合openid/oauth请求不返回oauth请求令牌。你可以在这里看到我的混合标准演示的版本http://lookmumimontheinternet.com/staging/hybrid/index.php

你可以看到我停止了重定向并在链接中输出url进行调试。我还输出了$ _REQUEST对象中返回的所有内容。

此链接到一个市场的应用与如下因素清单:

<?xml version="1.0" encoding="UTF-8" ?> 
<ApplicationManifest xmlns="http://schemas.google.com/ApplicationManifest/2009"> 
    <!-- Metadata --> 
    <Name>Hello World</Name> 
    <Description>A simple application for demonstrating the marketplace</Description> 
    <Support> 
    <Link rel="support" href="http://www.lookmumimontheinternet.com/staging/hybrid/support.php" /> 
    </Support> 

    <!-- Navigation link --> 
    <Extension id="navlink" type="link"> 
    <Name>Hello World</Name> 
    <Url>http://www.lookmumimontheinternet.com/staging/hybrid/index.php?from=google&amp;domain=${DOMAIN_NAME}</Url> 
    <Scope ref="calendarFeed"/> 
    </Extension> 

    <!-- Single Sign On with OpenID --> 
    <Extension id="realm" type="openIdRealm"> 
    <Url>http://lookmumimontheinternet.com/staging/hybrid</Url> 
    </Extension> 

    <!-- Authorized Data access --> 
    <Scope id="calendarFeed"> 
    <Url>https://www.google.com/calendar/feeds/</Url> 
    <Reason>This app displays your next upcoming calendar appointment..</Reason> 
    </Scope> 
</ApplicationManifest> 

这里是我的安装演示(我知道我不应该张贴的秘密的PHP配置,但它只是一个测试应用程序):

$CONSUMER_KEY = '995079586589.apps.googleusercontent.com'; 
$CONSUMER_SECRET = '6yTp+2Xz7nSqB4Yx6OdSds7n'; 

$openid_params = array(
    'openid.ns'    => 'http://specs.openid.net/auth/2.0', 
    'openid.claimed_id'  => 'http://specs.openid.net/auth/2.0/identifier_select', 
    'openid.identity'   => 'http://specs.openid.net/auth/2.0/identifier_select', 
    'openid.return_to'   => "http://lookmumimontheinternet.com/staging/hybrid/index.php", 
    'openid.realm'    => "http://lookmumimontheinternet.com/staging/hybrid", 
    'openid.mode'    => @$_REQUEST['openid_mode'], 
    'openid.ns.ui'    => 'http://specs.openid.net/extensions/ui/1.0', 
    'openid.ns.ext1'   => 'http://openid.net/srv/ax/1.0', 
    'openid.ext1.mode'   => 'fetch_request', 
    'openid.ext1.type.email' => 'http://axschema.org/contact/email', 
    'openid.ext1.type.first' => 'http://axschema.org/namePerson/first', 
    'openid.ext1.type.last' => 'http://axschema.org/namePerson/last', 
    'openid.ext1.type.country' => 'http://axschema.org/contact/country/home', 
    'openid.ext1.type.lang' => 'http://axschema.org/pref/language', 
    'openid.ext1.required'  => 'email,first,last,country,lang', 
    'openid.ns.oauth'   => 'http://specs.openid.net/extensions/oauth/1.0', 
    'openid.oauth.consumer' => $CONSUMER_KEY, 
    'openid.oauth.scope'  => implode(' ', $scopes) 
); 

$openid_ext = array(
    'openid.ns.ext1'   => 'http://openid.net/srv/ax/1.0', 
    'openid.ext1.mode'   => 'fetch_request', 
    'openid.ext1.type.email' => 'http://axschema.org/contact/email', 
    'openid.ext1.type.first' => 'http://axschema.org/namePerson/first', 
    'openid.ext1.type.last' => 'http://axschema.org/namePerson/last', 
    'openid.ext1.type.country' => 'http://axschema.org/contact/country/home', 
    'openid.ext1.type.lang' => 'http://axschema.org/pref/language', 
    'openid.ext1.required'  => 'email,first,last,country,lang', 
    'openid.ns.oauth'   => 'http://specs.openid.net/extensions/oauth/1.0', 
    'openid.oauth.consumer' => $CONSUMER_KEY, 
    'openid.oauth.scope'  => implode(' ', $scopes), 
    'openid.ui.icon'   => 'true' 
); 

在运行,我可以看到,即使被要求它是一个正在返回任何OAuth令牌(正确就演示可以看到)。任何人都可以看到我在这里做错了吗?

回答

1

好的解决了它。由于应用程序在安装时预先获得批准,因此您无需获得oauth访问权限。你已经用你的应用程序密钥。