我正在尝试配置HybridAuth,目前处于初期阶段.现在,我要做的就是连接并确保HA将重定向到facebook并提示安装应用程序,然后在用户返回时对其进行身份验证.
我正在通过以下方式手动致电:
http://mydomain.com/auth.php?provider=Facebook
auth.php看起来像这样:
session_start();
require_once($_SERVER['DOCUMENT_ROOT'] . "/func/db_connect.php");
require_once($_SERVER['DOCUMENT_ROOT'] . "/api/auth/Hybrid/Auth.php"); // HybridAuth Module
$hybridauth_config = include($_SERVER['DOCUMENT_ROOT'] . '/api/auth/config.php');
if ($_GET['provider'] == '' || !in_array($_GET['provider'], array_keys($hybridauth_config['providers']))) {
echo 'Invalid Provider';
} else {
try {
$hybridauth = new Hybrid_Auth($hybridauth_config);
// try to authenticate with this provider
$adapter = $hybridauth->authenticate($_GET['provider']);
// grab user profile
if ($hybridauth->isConnectedWith($f_provider)) {
// yep, we're connected. Add this provider's info to the user_auth table
echo 'connection successful';
}
} catch (Exception $e) {
echo $e->getMessage();
}
}
它的工作方式是转发到Facebook,并提示您使用适当的权限安装正确的应用程序.这告诉我我的HA配置工作正常.我成功安装了该应用程序,然后将其重定向回页面,在该页面上我收到以下消息:
Authentification failed! Facebook returned an invalide user id.
是什么赋予了?我的应用程序在FB控制面板中也显示0个添加和0个API调用(尽管此数据看起来可能会延迟几天).我是否在等待FB以某种方式启用该应用程序?难道我做错了什么?
UPDATE
HybridAuth使用Facebook SDK,因此我试图从整个方程式中消除HA.运行以下基本示例:
session_start();
require($_SERVER['DOCUMENT_ROOT'] . "/path/to/fbsdk/facebook.php");
$facebook = new Facebook(array(
'appId' => 'myappid',
'secret' => 'myappsecret',
'fileUpload' => true
));
$user = $facebook->getUser();
var_dump($user);
我登录到Facebook并添加了应用程序,但是无论我做什么,用户ID都会返回0.我也尝试过使用测试用户-无济于事.我在这里可能会缺少一些服务器配置问题吗?
解决方法:
我将代码移至其他应用程序/服务器,然后移至其他服务器上的同一应用程序,一切正常.因此,我开始将其视为服务器配置问题.事实证明,Facebook不喜欢我的开发服务器上的自签名证书.
我能够通过更改PHP SDK中的base_facebook.php类并添加curlopt来忽略SSL验证步骤来解决此问题.见下文:
public static $CURL_OPTS = array(
CURLOPT_CONNECTTIMEOUT => 10,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_TIMEOUT => 60,
CURLOPT_USERAGENT => 'facebook-php-3.1',
CURLOPT_SSL_VERIFYPEER => false
);