с помощью jQuery $.ajax для вызова функции PHP
это может быть простой ответ,но я использую $jQuery.ajax для вызова PHP-скрипта. То, что я хочу сделать, это в основном поместить этот PHP-скрипт внутри функции и вызвать функцию PHP из javascript.
<?php
if(isset($_POST['something'] {
//do something
}
?>
этой
<?php
function test() {
if(isset($_POST['something'] {
//do something.
}
}
?>
Как бы я назвал эту функцию в javascript? Сейчас я просто использую $.ajax с файлом PHP в списке.
6 ответов
использовать $.ajax
для вызова контекста сервера (или URL-адреса или чего-либо еще) для вызова определенного "действия". То, что вы хотите, это что-то вроде:
$.ajax({ url: '/my/site',
data: {action: 'test'},
type: 'post',
success: function(output) {
alert(output);
}
});
на стороне сервера action
параметр POST должен быть прочитан, и соответствующее значение должно указывать на метод для вызова, например:
if(isset($_POST['action']) && !empty($_POST['action'])) {
$action = $_POST['action'];
switch($action) {
case 'test' : test();break;
case 'blah' : blah();break;
// ...etc...
}
}
Я считаю, что это просто воплощение команда.
Я разработал плагин jQuery, который позволяет вызывать любую основную функцию PHP или даже определенные пользователем функции PHP в качестве методов плагина:С помощью jQuery.в PHP
после включения jquery и jquery.php в голове нашего документа и размещение request_handler.php на нашем сервере мы бы начали использовать плагин следующим образом.
для удобства использования ссылка на функцию простым способом:
var P = $.fn.php;
затем инициализировать плагин:
P('init',
{
// The path to our function request handler is absolutely required
'path': 'http://www.YourDomain.com/jqueryphp/request_handler.php',
// Synchronous requests are required for method chaining functionality
'async': false,
// List any user defined functions in the manner prescribed here
// There must be user defined functions with these same names in your PHP
'userFunctions': {
languageFunctions: 'someFunc1 someFunc2'
}
});
и теперь некоторые сценарии использования:
// Suspend callback mode so we don't work with the DOM
P.callback(false);
// Both .end() and .data return data to variables
var strLenA = P.strlen('some string').end();
var strLenB = P.strlen('another string').end();
var totalStrLen = strLenA + strLenB;
console.log( totalStrLen ); // 25
// .data Returns data in an array
var data1 = P.crypt("Some Crypt String").data();
console.log( data1 ); // ["$Tk1b01rk$shTKSqDslatUSRV3WdlnI/"]
демонстрация цепочки функций PHP:
var data1 = P.strtoupper("u,p,p,e,r,c,a,s,e").strstr([], "C,A,S,E").explode(",", [], 2).data();
var data2 = P.strtoupper("u,p,p,e,r,c,a,s,e").strstr([], "C,A,S,E").explode(",", [], 2).end();
console.log( data1, data2 );
демонстрация отправки JSON-блока PHP псевдо-кода:
var data1 =
P.block({
$str: "Let's use PHP's file_get_contents()!",
$opts:
[
{
http: {
method: "GET",
header: "Accept-language: en\r\n" +
"Cookie: foo=bar\r\n"
}
}
],
$context:
{
stream_context_create: ['$opts']
},
$contents:
{
file_get_contents: ['http://www.github.com/', false, '$context']
},
$html:
{
htmlentities: ['$contents']
}
}).data();
console.log( data1 );
конфигурация бэкэнда предоставляет белый список, поэтому вы можете ограничить, какие функции могут быть вызваны. Есть несколько других шаблонов для работы с PHP, описанных плагином.
Я бы придерживался обычного подхода к вызову файла напрямую, но если вы действительно хотите вызвать функцию, посмотрите на JSON-RPC (удаленный вызов процедуры JSON).
вы в основном отправляете строку JSON в определенном формате на сервер, например
{ "method": "echo", "params": ["Hello JSON-RPC"], "id": 1}
который включает функцию для вызова и параметры этой функции.
конечно, сервер должен знать, как обрабатывать такие запросы.
Вот плагин jQuery для JSON-RPC и, например,сервер Zend JSON как реализация сервера в PHP.
Это может быть перебор для небольшого проекта или меньше функций. Проще всего было бы Карима. С другой стороны, JSON-RPC является стандартом.
вы не можете вызвать функцию PHP с помощью Javascript, так же как вы не можете вызывать произвольные функции PHP при загрузке страницы (просто подумайте о последствиях для безопасности).
Если вам нужно обернуть свой код в функцию по какой-либо причине, почему бы вам не поместить вызов функции под определение функции, например:
function test() {
// function code
}
test();
или используйте PHP include:
include 'functions.php'; // functions.php has the test function
test();
вы можете использовать мою библиотеку, которая делает это автоматически, я улучшаю ее в течение последних 2 лет http://phery-php-ajax.net
Phery::instance()->set(array(
'phpfunction' => function($data){
/* Do your thing */
return PheryResponse::factory(); // do your dom manipulation, return JSON, etc
}
))->process();
javascript будет простым, как
phery.remote('phpfunction');
вы можете передать всю динамическую часть javascript на сервер с помощью построителя запросов, такого как chainable interface, и вы можете передать любой тип данных обратно в PHP. Например, некоторые функции, которые занимают слишком много места на стороне javascript, могут быть вызваны в сервер, использующий это (в этом примере mcrypt, что в javascript было бы почти невозможно выполнить):
function mcrypt(variable, content, key){
phery.remote('mcrypt_encrypt', {'var': variable, 'content': content, 'key':key || false});
}
//would use it like (you may keep the key on the server, safer, unless it's encrypted for the user)
window.variable = '';
mcrypt('variable', 'This must be encoded and put inside variable', 'my key');
и на сервере
Phery::instance()->set(array(
'mcrypt_encrypt' => function($data){
$r = new PheryResponse;
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
$encrypted = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $data['key'] ? : 'my key', $data['content'], MCRYPT_MODE_ECB, $iv);
return $r->set_var($data['variable'], $encrypted);
// or call a callback with the data, $r->call($data['callback'], $encrypted);
}
))->process();
теперь variable
будет иметь зашифрованные данные.
вам придется выставить и конечную точку (URL) в вашей системе, которая примет запрос POST от вызова ajax в jQuery.
затем при обработке этого url-адреса из PHP вы вызовете свою функцию и вернете результат в соответствующем формате (скорее всего, JSON или XML, если хотите).