我试图将“世界笔记”SDK整合到我的 CodeIgniter 网络应用程序中,
我有一个简单的代码:
$access_token = my validated access token ;
// Get User Store
$userStoreTrans;
try{
$userStoreTrans = new THttpClient(USER_STORE_HOST, USER_STORE_PORT, USER_STORE_URL, USER_STORE_PROTO);
}
catch(TTransportException $e)
{
print $e->errorCode. Message: .$e->parameter;
}
$userStoreProt = new TBinaryProtocol($userStoreTrans);
$userStoreClient = new UserStoreClient($userStoreProt, $userStoreProt);
虽然正确创建了 $userStore Transtrans
和 $userStoreProt
,但是在.../home.php 用户StereClient > 和 类Evernote SDK的
Thattpical 协议
, $userStoreClient
和
我不明白为什么某些类被承认,而另一些类则不被承认,我看到的主要区别是,“TClasses”位于evernote-sdk-php/lib/transport/*.php
和evernote-sdk-php/lib/protocol/*.php
和用户StoreClient有一个额外文件夹 evernote-sdk-php/lib/packages/userStore/*.php
我将解释我是如何把 evennote -sdk -php 包括到我的 CodeIgniter 安装:
这是我的 CoDIgniter 配置/ 自动装入. php
$autoload[ libraries ] = array( database , session , form_validation , security , tank_auth , Evernote_bootstrap );
这是我的季注 - bouts trap.php 文件
<?php if (!defined( BASEPATH )) exit( No direct script access allowed );
define("EVERNOTE_LIBS", dirname(__FILE__) . DIRECTORY_SEPARATOR . "evernote-sdk-php/lib");
// add ourselves to include path
ini_set("include_path", ini_get("include_path") . ":" . EVERNOTE_LIBS);
require_once("evernote-sdk-php/lib/autoload.php");
require_once("evernote-oauth/functions.php");
class Evernote_Bootstrap
{
function __construct()
{
// log_message( debug , Evernote_Bootstrap );
}
}
?>
Enternote_Bootsstrap 类的主要目的是 rererere_once of evernote-sdk-php/lib/autoload.php
, 该类是使用 -phpa Thrift 生成器旗帜自动生成的, 我只是添加一些记录来看到问题 。
自动load.php:
<?php
/**
* Copyright (c) 2006- Facebook
* Distributed under the Thrift Software License
*
* See accompanying file LICENSE or visit the Thrift site at:
* http://developers.facebook.com/thrift/
*
* @package thrift
* @author Mark Slee <[email protected]>
*/
/**
* Include this file if you wish to use autoload with your PHP generated Thrift
* code. The generated code will *not* include any defined Thrift classes by
* default, except for the service interfaces. The generated code will populate
* values into $GLOBALS[ THRIFT_AUTOLOAD ] which can be used by the autoload
* method below. If you have your own autoload system already in place, rename your
* __autoload function to something else and then do:
* $GLOBALS[ AUTOLOAD_HOOKS ][] = my_autoload_func ;
*
* Generate this code using the -phpa Thrift generator flag.
*/
/**
* This parses a given filename for classnames and populates
* $GLOBALS[ THRIFT_AUTOLOAD ] with key => value pairs
* where key is lower-case d classname and value is full path to containing file.
*
* @param String $filename Full path to the filename to parse
*/
function scrapeClasses($filename) {
$fh = fopen($filename, "r");
while ($line = fgets($fh)) {
$matches = array();
if ( preg_match("/^s*classs+([^s]+)/", $line, $matches)) {
if (count($matches) > 1)
$GLOBALS[ THRIFT_AUTOLOAD ][strtolower($matches[1])] = $filename;
}
}
}
function findFiles($dir, $pattern, &$finds) {
if (! is_dir($dir))
return;
if (empty($pattern))
$pattern = "/^[^.][^.]?$/";
$files = scandir($dir);
if (!empty($files)) {
foreach ($files as $f) {
if ($f == "." || $f == "..")
continue;
if ( is_file($dir . DIRECTORY_SEPARATOR . $f) && preg_match($pattern, $f)) {
$finds[] = $dir . DIRECTORY_SEPARATOR . $f;
} else if ( is_dir($dir . DIRECTORY_SEPARATOR . $f) && substr($f, 0, 1) != ".") {
findFiles($dir . DIRECTORY_SEPARATOR . $f, $pattern, $finds);
}
}
}
}
function str_var_dump($object)
{
ob_start();
var_dump($object);
$dump = ob_get_clean();
return $dump;
}
// require Thrift core
require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . "Thrift.php");
if (! isset($GLOBALS[ THRIFT_ROOT ]))
$GLOBALS[ THRIFT_ROOT ] = dirname(__FILE__);
log_message( debug , bootstrap autoload.php is executing );
// stuff for managing autoloading of classes
$GLOBALS[ THRIFT_AUTOLOAD ] = array();
$GLOBALS[ AUTOLOAD_HOOKS ] = array();
$THRIFT_AUTOLOAD =& $GLOBALS[ THRIFT_AUTOLOAD ];
// only populate if not done so already
if (empty($GLOBALS[ THRIFT_AUTOLOAD ])) {
//$allLibs = glob( dirname(__FILE__) . "/**/*.php"); // oh poor winblows users can t use glob recursively
$allLibs = array();
findFiles( dirname(__FILE__), "/.php$/i", $allLibs);
log_message( debug ,str_var_dump($allLibs));
if (!empty($allLibs)) {
foreach ($allLibs as $libFile) {
scrapeClasses($libFile);
}
log_message( debug , all scrapped classes: . str_var_dump($GLOBALS[ THRIFT_AUTOLOAD ]));
}
}else{
log_message( debug , $GLOBALS[THRIFT_AUTOLOAD] already defined );
}
// main autoloading
if (!function_exists( __autoload )) {
function __autoload($class) {
log_message( debug , __autoload );
global $THRIFT_AUTOLOAD;
$classl = strtolower($class);
if (isset($THRIFT_AUTOLOAD[$classl])) {
// log_message( debug , $THRIFT_AUTOLOAD[$classl] is set, do require_once );
//include_once $GLOBALS[ THRIFT_ROOT ]. /packages/ .$THRIFT_AUTOLOAD[$classl];
require_once($THRIFT_AUTOLOAD[$classl]);
} else if (!empty($GLOBALS[ AUTOLOAD_HOOKS ])) {
log_message( debug , $GLOBALS[AUTOLOAD_HOOKS]is no empty, lets foreach );
foreach ($GLOBALS[ AUTOLOAD_HOOKS ] as $hook) {
// log_message( debug , iterate );
$hook($class);
}
} else {
log_message( debug , nothing to do );
}
}
}
然后,我登录了该库,似乎工作良好。您可以看到主要的重要日志 : log_meessage (调试,str_var_dump ($allLibs));
和 log_mesage (调试,所有已拆解的分类 :.str_var_dump ($GLOBALS[THRIFT_AUTOLOAD] ) );
和输出 : http://pastebin.com/8w1MCKx9 :
正如你所看到的,用户玩具类似乎 与ThttpClient 或TBontal协议一样精细的装货... 任何关于这个问题的想法?
我不知道是否重要,但我注意到,在自动装入.php上定义的$GLOBALS[THRIFT_ROOT]
无法从CI主计长处获得。 可能我遗漏了一些关于CI结构的东西。