我有一个以下结构的应用程序
我正在使用 rest client library https://github.com/philsturgeon/codeigniter-restclient 连接到 MyAPI, 并且使用 php api client http://code.google.com/p/google-api-php-client/ 连接到 Google API
我的控制器代码如下
function index()
{
if($this->form_validation->run())
{
$logged = $this->rest->get('auth/user',array(
'email'=>$this->input->post('email')
));
var_dump($logged);
}
$this->load->view('layout/login',$this->data);
}
这是我的API代码,用于处理该请求。它确保用户在我的数据库中存在,并且已通过Google进行了身份验证。
function user_get()
{
$response=NULL;
$data=array(
'email'=>$this->get('email')
);
$google_account=$this->google->authenticate();
if( isset($google_account) && $this->user_model->login($data))
{
$response->status='success';
$response->message=$google_account;
}
else
{
$response->status='error';
$response->message='Failed to authenticate user';
}
$this->response($response,200);
}
而 Google
库函数 `Authenticate' 的代码如下:
function authenticate()
{
$oauth2 = new Google_Oauth2Service($this->client);
if (isset($_GET['code']))
{
$this->client->authenticate($_GET['code']);
$_SESSION['token'] = $this->client->getAccessToken();
$redirect = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];
header('Location: ' . filter_var($redirect, FILTER_SANITIZE_URL));
return;
}
if (isset($_SESSION['token']))
{
$this->client->setAccessToken($_SESSION['token']);
}
if (isset($_REQUEST['logout']))
{
unset($_SESSION['token']);
$this->client->revokeToken();
}
if ($this->client->getAccessToken())
{
$user = $oauth2->userinfo->get();
// The access token may have been updated lazily.
$_SESSION['token'] = $this->client->getAccessToken();
return $user;
}
else
{
$authUrl = $this->client->createAuthUrl();
redirect($authUrl);
}
}
问题是 当我通过直接网址连接时:http://localhost/hac_dc/api/auth/user/ahmed.samy.cs@gmail.com,我可以完美地获取JSON响应。
但是当我使用rest客户端进行连接时:
我得到的响应为false
。我已经尝试了改变我的rest客户端的使用方式。我尝试将第三个参数作为JSON
和MIME application/json
添加,但仍然没有解决这个问题。
我不知道通过我的REST API连接另一个REST API是问题还是不好的做法,我已经为此烦恼了数小时,请帮帮我。