создание и продвижение сайта (вбиваю в ТОП-10, как гвозди)Настройка и сопровождение платной рекламы яндекс.директ

PHP. Руководство по PHP. 2005

PHP / Java IntegrationПред.

След.

LIX. PHP / Java Integration

Введение

There are two possible ways to bridge PHP and Java: you can either integrate PHP into a Java Servlet environment, which is the more stable and efficient solution, or integrate Java support into PHP. The former is provided by a SAPI module that interfaces with the Servlet server, the latter by this Java extension.

The Java extension provides a simple and effective means for creating and invoking methods on Java objects from PHP. The JVM is created using JNI, and everything runs in-process.

Внимание
Это расширение является

ЭКСПЕРИМЕНТАЛЬНЫМ. Поведение этого расширения,

включая имена его функций и относящуюся к нему документацию, может

измениться в последующих версиях PHP без уведомления. Используйте

это расширение на свой страх и риск.

Требования

You need a Java VM installed on your machine to use this extension.

Установка

Это расширение PECL

не поставляется вместе с PHP.

В PHP4 исходные файлы этого расширения PECL

могут быть найдены в директории ext/ внутри исходных файлов

PHP или по ссылке PECL выше. In order to use these functions you must compile PHP with Java support by using the --with-java[=DIR] where DIR points to the base install directory of your JDK. This extension can only be built as a shared extension. Additional build extensions can be found in php-src/ext/java/README.

Windows users will enable php_java.dll inside of php.ini in order to use these functions. В PHP4 этот DLL находится в

директории extensions/ внутри директории бинарного

дистрибутива PHP для Windows. Вы можете скачать DLL этого

расширения PECL со страницы -PHP Downloads или -http://snaps.php.net/.

Замечание: In order to enable this module on a Windows environment with PHP <= 4.0.6, you must make jvm.dll available to your systems PATH. No additional DLL is needed for PHP versions > 4.0.6.

Настройка во время выполнения

-Поведение этих функций зависит от установок в php.ini.

Таблица 1. Java configuration options

NameDefaultChangeableChangelog
java.class.pathNULLPHP_INI_ALL
java.homeNULLPHP_INI_ALL
java.library.pathNULLPHP_INI_ALL
java.libraryJAVALIBPHP_INI_ALL

Для подробного описания констант

PHP_INI_*, обратитесь к документации функции ini_set().

Типы ресурсов

Данное расширение не определяет никакие типы ресурсов.

Предопределенные константы

Данное расширение не определяет никакие константы.

Примеры

Пример 1. Java Example

<?

//get instance of Java class java.lang.System in PHP

$system = new Java('java.lang.System');

//demonstrate property access

echo 'Java version=' . $system->getProperty('java.version') . '<br>';

echo 'Java vendor=' . $system->getProperty('java.vendor') . '<br>';

echo 'OS=' . $system->getProperty('os.name') . ' ' .

$system->getProperty('os.version') . ' on ' .

$system->getProperty('os.arch') . ' <br>';

//java.util.Date example

$formatter = new Java('java.text.SimpleDateFormat',

"EEEE, MMMM dd, yyyy 'at' h:mm:ss a zzzz");

echo $formatter->format(new Java('java.util.Date'));

?>

Пример 2. AWT Example

<?

//This example is only intended to be run as a CGI.

$frame = new Java('java.awt.Frame', 'PHP');

$button = new Java('java.awt.Button', 'Hello Java World!');

$frame->add('North', $button);

$frame->validate();

$frame->pack();

$frame->visible = True;

$thread = new Java('java.lang.Thread');

$thread->sleep(10000);

$frame->dispose();

?>

Notes:

  • new Java() will create an instance of a class if a suitable constructor is available. If no parameters are passed and the default constructor is useful as it provides access to classes like java.lang.System which expose most of their functionallity through static methods.
  • Accessing a member of an instance will first look for bean properties then public fields. In other words, print $date.time will first attempt to be resolved as $date.getTime(), then as $date.time.
  • Both static and instance members can be accessed on an object with the same syntax. Furthermore, if the java object is of type java.lang.Class, then static members of the class (fields and methods) can be accessed.
  • Exceptions raised result in PHP warnings, and NULL results. The warnings may be eliminated by prefixing the method call with an "@" sign. The following APIs may be used to retrieve and reset the last error:
  • java_last_exception_get()
  • java_last_exception_clear()
  • Overload resolution is in general a hard problem given the differences in types between the two languages. The PHP Java extension employs a simple, but fairly effective, metric for determining which overload is the best match.

    Additionally, method names in PHP are not case sensitive, potentially increasing the number of overloads to select from.

    Once a method is selected, the parameters are coerced if necessary, possibly with a loss of data (example: double precision floating point numbers will be converted to boolean).

  • In the tradition of PHP, arrays and hashtables may pretty much be used interchangably. Note that hashtables in PHP may only be indexed by integers or strings; and that arrays of primitive types in Java can not be sparse. Also note that these constructs are passed by value, so may be expensive in terms of memory and time.

    Java Servlet SAPI

    The Java Servlet SAPI builds upon the mechanism defined by the Java extension to enable the entire PHP processor to be run as a servlet. The primary advantage of this from a PHP perspective is that web servers which support servlets typically take great care in pooling and reusing JVMs. Build instructions for the Servlet SAPI module can be found in php4/sapi/README.

    Notes:

  • While this code is intended to be able to run on any servlet engine, it has only been tested on Apache's Jakarta/tomcat to date. Bug reports, success stories and/or patches required to get this code to run on other engines would be appreciated.
  • PHP has a habit of changing the working directory. sapi/servlet will eventually change it back, but while PHP is running the servlet engine may not be able to load any classes from the CLASSPATH which are specified using a relative directory syntax, or find the work directory used for administration and JSP compilation tasks.

    Содержание

    java_last_exception_clear -- Clear last Java exception

    java_last_exception_get -- Get last Java exception

    Пред.

    Начало

    След.

    ircg_whois

    Уровень выше

    java_last_exception_clear

  • Отвечу на любые вопросы. С уважением, Дмитрий Владимирович.

    Ваше письмо×
    Free Web Hosting