如何通过 Slim php 和 Paris 将主干模型数据 POST 到 DB

2022-08-30 22:04:53

我试图了解Backbone.jsSlim PHPParis / Idiorm如何协同工作,但我在完成流程时遇到了麻烦,从模型属性数据开始,一直到数据库。问题:当我执行 model.save() 时,究竟会向服务器发送什么?

客户端:主干.js

var Donut = Backbone.Model.extend({
    defaults: {
        name: null,
        sparkles: false,
        creamFilled: false
    },
    url: function() {
        return '/donut';
    }
});

var bostonCream = new Donut({
    name: 'Bawston Cream',
    sparkles: true,
    creamFilled: true
});

bostonCreme.save();  // <-- Problem: Not sure what & format this is sending

我认为以上是我的主要问题。我的理解是,默认情况下,骨干将知道发送POST数据,因为它是新的。它把它发送到/donut,它被路由,但我的问题是它发送了什么?以什么格式?我想要的结果是将这些甜甜圈属性保存到我的数据库中。我可以使用jQuery $.post()传递这个服务器端代码一个这样的json...

var myDonut = {"name":"Jelly Filled", "sparkles":false, "creamFilled":true};
$.post('http://localhost/donut', myDonut);

...它很高兴地接受它,把它保存到我的数据库中。但是,由于当前设置尝试发送我的主干甜甜圈数据,我收到POST 500内部服务器错误。下面我有一些服务器端代码。

服务器端:带巴黎的超薄 PHP

class Donut extends Model {}

$app->post('/donut', function() use ($app) {  // Slim framework routes my POST...

    $donuts = Model::factory('Donut')->create();  // Paris stuff...

    $donuts->name = $app->request()->post('name');  // Slim request parameters...
    $donuts->sparkles = $app->request()->post('sparkles');
    $donuts->creamFilled = $app->request()->post('creamFilled');

    $donuts->save();   // Paris... Save name, sparkles, and creamFilled to my DB
});

我有一种感觉,答案就在那里,但我看过的每个例子似乎都缺少拼图的一块或另一块,我无法得到“A-hA!”的时刻。我提前感谢你,如果这是一个非常无知的问题,我道歉。:-P

跟进/编辑: 1

你能粘贴错误消息吗?

我在当前状态下收到 http://localhost:8888/donut 500(内部服务器错误)的开机自检。我可以通过以下代码获取更多信息。

bostonCream.save({}, {  // REPLACE bostonCream.save();
    success: function(model, response) {
        console.log('SUCCESS:');
        console.log(response);
    },
    error: function(model, response) {
        console.log('FAIL:');
        console.log(response);
    }
});

现在,当我运行backer的save()时,我仍然收到500错误,但也收到XMLHttpRequest作为我的FAIL响应。XMLHttpRequest 中唯一值得注意的线索是 responseText = SQLSTATE[23000]: 完整性约束违规: 1048 列 'name' 不能为 null。

所以我的猜测是,要么1)我用save()搞砸了一些东西,因为它没有正确捕获我的属性,2)它目前以我的服务器无法识别的格式发送我的属性,标准$app->request()->post()Slim方法(当我尝试直接访问_POST时,似乎也没有多大作用), 3)我的服务器未正确设置以接收正在发送的数据类型。

我注意到的另一件事,虽然我不知道该怎么做,但当我添加

echo $_POST;

它向我返回一个空数组。仍然给我失败。但是,如果我这样做...

echo json_encode($_POST);

它给了我一个成功,响应是一个[ ]。那里什么都没有。显然,我的POST数据仍然不稳定。


答案 1

我想出了一个解决方案来完成这个问题:如何使用默认的主干save()和.sync将数据从客户端获取到服务器 - 传递到Slim php框架并通过Paris / Idiorm到我的DB。

我在下面包含我的工作更新代码:

客户端:主干.js

var Donut = Backbone.Model.extend({
    defaults: {
        name: null,
        sparkles: false,
        creamFilled: false
    },
    url: function() {
        return '/donut';
    }
});

var bostonCream = new Donut({
    name: 'Bawston Cream',
    sparkles: true,
    creamFilled: true
});

bostonCream.save();

/***** If you want to check out the response to save() ? ***
bostonCream.save({}, {
    success: function(model, response) {
        console.log('SUCCESS:');
        console.log(response);
    },
    error: function(model, response) {
        console.log('FAIL:');
        console.log(response);
    }
});
************************************************************/

服务器侧:纤薄 PHP 带巴黎/Idorm

class Donut extends Model {}

$app->post('/donut', function() use ($app) {

    $donuts = Model::factory('Donut')->create();

    /* EDIT: Works... but not the Slim way
    $parameters = json_decode(file_get_contents('php://input'), true);
    $donuts->name = $parameters['name'];
    $donuts->sparkles = $parameters['sparkles'];
    $donuts->creamFilled = $parameters['creamFilled']; */

    /* SLIM: Using Slim Request Object */
    $requestBody = $app->request()->getBody();  // <- getBody() of http request
    $json_a = json_decode($requestBody, true);
    $donuts->name = $json_a['name'];
    $donuts->sparkles = $json_a['sparkles'];
    $donuts->creamFilled = $json_a['creamFilled'];

    $donuts->save();

    // echo json_encode($parameters); // Prove you've captured POST data, send it back
}

现在,我的代码很高兴地使用Backbone的默认设置.js(没有更改同步)并将正确的模型属性信息发送到我的服务器,该服务器似乎成功接受了数据并将其保存到我的数据库。

这里的关键似乎是这条线...

/* $parameters = json_decode(file_get_contents('php://input'), true); */
// EDITED: getBody() method not documented in Develop Doc, only Stable @ time of post

$requestBody = $app->request()->getBody();

答案 2

如果你想知道“究竟是什么被发送到服务器”,你应该看看Backbone代码中的Backbone.sync功能。它有很好的文档记录,一步一步。然后,实现所需内容的最干净方法是编写自己的同步功能,灵感来自Backbone的同步。

此外,查看发送到服务器的内容的快速方法是使用浏览器调试控制台(“网络”选项卡)。您可以在此处比较 Backbone 发送的内容与直接使用 $.post 时发送的内容。如果您需要更多帮助,请发布此信息!


推荐