Я новичок в PHP и пытаюсь портировать веб-приложение, которое уже работает на Google App Engine.
Я прочитал документы GAE о файле конфигурации, который мне нужно написать (app.yaml)
Теперь я дошел до того, что программа запуска обслуживает приложение, но «поток PHP» достигает страницы совершенно пустой вместо окна с некоторыми данными и ожидаемой формой.
Каким образом я могу отладить этот поток PHP, чтобы увидеть, что происходит неправильно?
Подробно это файлы, которые работают неправильно:
index.php в корневом каталоге:
<?php
include_once('tao/install/init.php');
if(!tao_install_utils_System::isTAOInstalled()){
header("location:tao/install");
}
else{
header("location:tao/Main/entry");
}
?>
Таким образом, файл init.php в tao / install будет называться первым запуском приложения.
<?php
// -- Install bootstrap
$rootDir = dir(dirname(__FILE__).'/../../');
$root = realpath($rootDir->path) . DIRECTORY_SEPARATOR ;
define('TAO_INSTALL_PATH', $root);
define('GENERIS_PATH', $root.'generis/');
set_include_path(get_include_path() . PATH_SEPARATOR . $root. PATH_SEPARATOR . GENERIS_PATH);function install_loader($class_name){
foreach (array(TAO_INSTALL_PATH, GENERIS_PATH) as $dir) {
$path = str_replace('_', '/', $class_name);
$file = 'class.' . basename($path). '.php';
$filePath = $dir . dirname($path) . '/' . $file;
if (file_exists($filePath)){
require_once $filePath;
break;
}
else{
$file = 'interface.' . basename($path). '.php';
$filePath = $dir . dirname($path) . '/' . $file;
if (file_exists($filePath)){
require_once $filePath;
break;
}
}
}
}
spl_autoload_register('install_loader');
common_log_Dispatcher::singleton()->init(array(
array(
'class' => 'SingleFileAppender',
'threshold' => common_Logger::TRACE_LEVEL,
'file' => TAO_INSTALL_PATH.'tao/install/log/install.log',
)));
require_once (GENERIS_PATH.'vendor/autoload.php');
require_once ('tao/helpers/class.Display.php');
require_once ('tao/helpers/class.Uri.php');
?>
И это мой временный app.yaml
application: myapp
version: alpha-001
runtime: php
api_version: 1
handlers:
- url: /
script: index.php
- url: /tao/install
script: /tao/install/init.php
#- url: /stylesheets
# static_dir: stylesheets
- url: /(.*\.(gif|png|jpg))$
static_files: static/\1
upload: static/.*\.(gif|png|jpg)$
РЕДАКТИРОВАТЬ
Я думаю, что мне нужно отредактировать app.yaml для:
require_once (GENERIS_PATH.'vendor/autoload.php');
require_once ('tao/helpers/class.Display.php');
require_once ('tao/helpers/class.Uri.php');
Но я не поняла как
ВТОРОЕ РЕДАКТИРОВАНИЕ
Это журнал запуска GAE
2015-03-31 15:59:05 Running command: "['G:\\Python27\\python.exe', 'H:\\Program Files (x86)\\Google\\google_appengine\\dev_appserver.py', '--skip_sdk_update_check=yes', '--port=15080', '--admin_port=8007', u'F:\\davide\\tesi\\taov1']"INFO 2015-03-31 15:59:07,522 devappserver2.py:726] Skipping SDK update check.
INFO 2015-03-31 15:59:07,611 api_server.py:172] Starting API server at: http://localhost:63287
INFO 2015-03-31 15:59:07,617 dispatcher.py:186] Starting module "default" running at: http://localhost:15080
INFO 2015-03-31 15:59:07,618 admin_server.py:118] Starting admin server at: http://localhost:8007
INFO 2015-03-31 16:09:54,970 module.py:737] default: "GET / HTTP/1.1" 302 -
INFO 2015-03-31 16:09:55,045 module.py:737] default: "GET /tao/install HTTP/1.1" 200 -
INFO 2015-03-31 16:09:55,207 module.py:737] default: "GET /favicon.ico HTTP/1.1" 404 -
Я наконец нашел ответ. Проблема была в app.yaml, как сказал мне @Mars.
Это правильная форма:
application: mytaov1
version: alpha-test
runtime: php
api_version: 1
handlers:
- url: /
script: index.php
- url: /tao/install
script: /tao/install/index.html
Путь include () не был необходим в app.yaml, как путь required ().
Они были вызваны и обработаны без проблем.
Других решений пока нет …