使用Jquery和Ajax从PHP调用特定函数

对我来说这是一个新的东西,所以我只是研究这个并试图理解它.
正如您在PHP脚本中看到的那样,有两个函数,我试图用 jquery调用一个特定的函数.

现在,如果我有一个功能,那么我可以做到,但当我有2个或更多时,我开始卡住了.
我想,当我有2个函数时,我可以做到这一点,但是只要有更多的变量在运行或更多的函数,我只是在我的PHP中制作大量的if语句?

问题是当我附加数据库时,我需要考虑可能发生的所有输入.
使用jquery&时,如何指定特定的PHP函数? AJAX?

//function.PHP
<?PHP
    function firstFunction($name)
    {
        echo "Hello - this is the first function";
    }

    function secondFunction($name)
    {
        echo "Now I am calling the second function";
    }

?>

<?PHP
    $var = $_POST['name'];

    if(isset($var))
    {       
        $getData = firstFunction($var);
    }
    else if(isset($var))
    {
        $getData = secondFunction($var);
    }
    else
    {
        echo "No Result";
    }

?>

//index.html
<div id="calling">This text is going to change></div>

<script>

     $(document).ready(function() {
        $('#calling').load(function() {
        $.ajax({
            cache: false,type: "POST",url: "function.PHP",data: 'name=myname'
            success: function(msg)
            {
                $('#calling').html((msg));
            }

            }); // Ajax Call
        }); //event handler
    }); //document.ready

</script>

解决方法

您需要通过数据对象或URL上的GET变量传入参数.或者:
url: "function.PHP?action=functionname"

要么:

data: {
    name: 'myname',action: 'functionname'
}

然后在PHP中,您可以访问该属性并处理它:

if(isset($_POST['action']) && function_exists($_POST['action'])) {
    $action = $_POST['action'];
    $var = isset($_POST['name']) ? $_POST['name'] : null;
    $getData = $action($var);
    // do whatever with the result
}

注意:出于安全原因,更好的想法是将可以调用的可用函数列入白名单,例如:

switch($action) {
    case 'functionOne':
    case 'functionTwo':
    case 'thirdOKFunction':
        break;
    default:
        die('Access denied for this function!');
}

实施示例:

// PHP:
function foo($arg1) {
    return $arg1 . '123';
}

// ...
echo $action($var);

// jQuery:
data: {
    name: 'bar',action: 'foo'
},success: function(res) {
    console.log(res); // bar123
}

相关文章

jQuery插件的种类 1、封装对象方法 这种插件是将对象方法封装起来,用于对通过选择器获取的jQuery对象进...
扩展jQuery插件和方法的作用是非常强大的,它可以节省大量开发时间。 入门 编写一个jQuery插件开始于给...
最近项目中需要实现3D图片层叠旋转木马切换的效果,于是用到了jquery.roundabout.js。 兼容性如图: ht...
一、什么是deferred对象? 开发网站的过程中,我们经常遇到某些耗时很长的javascript操作。其中,既有异...
AMD 模块 AMD(异步模块定义,Asynchronous Module Definition)格式总体的目标是为现在的开发者提供一...