используя 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 Server как реализация сервера в 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, если вы предпочитаете).
Comments