Lumen:如何从DB中删除记录?

时间:2016-08-19 05:46:26

标签: php laravel lumen lumen-5.2 lumen-routing

使用流明,我正在显示"门票"。这是我的Tickets.blade.php

@foreach($tickets as $ticket)
<div>
    <p>{{ $ticket->id }}</p>
    <p>{{ $ticket->content }}</p>
    <button onclick="deleteTicket({{$ticket->id}})">Delete</button>
</div>
@endforeach

基本上,每次有人点击删除时,都会触发此脚本:

<script>
    function deleteTicket(id) {
        jQuery.ajax({
            type: "post",
            url: "/tickets/deleteTicket",
            data: id,
            dataType: "text",
            success: function () {
                console.log('deleted!');
            }
        });

    }
</script>

在我的routes.php中,我有这个:

$app->post('tickets/deleteTicket','TicketsController@deleteTicket');

最后,在我的TicketsController.php中,我有:

public function deleteTicket($id) {
    $ticket = Ticket::find($id);
    $ticket->delete();

    return redirect('/tickets');
}

我按下按钮(控制台)时遇到的问题:

  

POST http://example.com/tickets/deleteTicket 404(未找到)

我不明白我做错了什么,以及为什么找不到这种方法。任何人都可以帮忙吗?

编辑 - 我已将routes.php更改为:

$app->get('tickets/deleteTicket/{id}','TicketsController@deleteTicket');

我的脚本看起来一样,但我更改了&#34;类型&#34;到get而不是post

如果我访问此网站:http://mysite/tickets/deleteTicket/1,则会删除该故障单,并将其重定向到tickets页面。但是如果单击该按钮,则会发生以下错误:

  

http://MYSITE/tickets/deleteTicket?id=3 404(未找到)

此时,我认为我只需要将我的AJAX调用修改为正确的URL,但我想确保安全性是个问题。

2 个答案:

答案 0 :(得分:2)

或者你可以试试这个:

routes.php文件

$app->get('tickets/deleteTicket/{id}','TicketsController@deleteTicket');

好的,这是你的刀片: 将类添加到按钮并在单击时删除该功能。喜欢这个:

<button class="delete" data-id="{{$ticket->id}}>Delete</button>

你的剧本:

$(".delete").on("click", function(e) {
     e.preventDefault();
    var id = $(this).data('id');
    $.ajax({ 
       url : "tickets/deleteTicket/"+id+"",
       type : "get" or "post",
      success: function(data) {
          alert(data);    
       }
    });
});

答案 1 :(得分:0)

你必须改变的事情
- 在JS中

url: "/tickets/deleteTicket", // Try change to your full URL with http://
data: id, // Change to data: "id="+id,

- 在控制器中

public function deleteTicket(Request $request) {
    $ticket = Ticket::find($request->id);
    $ticket->delete();

    return redirect('/tickets');
}