Laravel Ajax Post请求返回空数组

时间:2018-06-01 07:52:38

标签: php ajax laravel dropify

因此,对于此作业,我需要在Laravel应用程序中为Dropify上传器添加进度条。但它似乎无法根据键找到会话,当我用键打印出会话时,它所做的就是返回一个空的Array()。

我的表格

{{ Form::open(array('url' => route('admin.templates.store'), 'files' => true, 'id' => 'myForm')) }}
            <input type="hidden" value="myForm" name="{{ ini_get('session.upload_progress.name') }}">

                <div class="form-group{{ $errors->has('title') ? ' has-error' : '' }}">
                    {{ Form::text('name', null, ['class' => 'form-control', 'required' => 'required']) }}
                    {{ Form::label('name', 'Template name', ['class' => 'control-label']) }}
                    <i class="bar"></i>
                    {{ $errors->first('name', '<p class="help-block">:message</p>') }}
                </div>

                <div class="form-group{{ $errors->has('title') ? ' has-error' : '' }}">
                    {{ Form::textarea('description', null, ['class' => 'form-control', 'required' => 'required', 'size' => '1x1']) }}
                    {{ Form::label('description', 'Template omschrijving', ['class' => 'control-label']) }}
                    <i class="bar"></i>
                    {{ $errors->first('description', '<p class="help-block">:message</p>') }}
                </div>

                <div class="form-group{{ $errors->has('number_of_screens') ? ' has-error' : '' }}">
                    {{ Form::number('number_of_screens', '1', ['class' => 'form-control', 'required' => 'required']) }}
                    {{ Form::label('number_of_screens', 'Aantal objecten', ['class' => 'control-label']) }}
                    <i class="bar"></i>
                    {{ $errors->first('number_of_screens', '<p class="help-block">:message</p>') }}
                </div>

                <div class="form-group{{ $errors->has('templatefile') ? ' has-error' : '' }}">
                    {{ Form::label('templateFile', 'Browse') }}
                    {{ Form::file('templateFile' , ['class' => 'dropify', 'data-allowed-file-extensions' => 'zip', 'required' => 'required']) }}
                    <div id="bar_blank">
                       <div id="bar_color"></div>
                    </div>
                    <div id="status"></div>
                </div>

                <div class="button-container">
                    {{ Form::submit('Uploaden', ['class' => 'button button-medium']) }}
                </div>

            {{ Form::close() }}

我的Ajax请求

$.ajax({
                        type: "POST",
                        url: "{{route('admin.templates.uploadprogress')}}",
                        data: {
                            "data": $('#myForm').serialize(),
                            "_token": "{{ csrf_token() }}",
                        },
                        success: function() {
                            console.log("Geodata sent");
                        }
                    });

我的路线

Route::post('/uploadprogress', 'AdminTemplateController@callSessionData')->name('uploadprogress');

我的控制器功能

public function callSessionData(Request $request){
    $key = ini_get("session.upload_progress.prefix") . "myForm";
    print_r($_SESSION);

    if (!empty($_SESSION[$key])) {
        $current = $_SESSION[$key]["bytes_processed"];
        $total = $_SESSION[$key]["content_length"];
        echo $current < $total ? ceil($current / $total * 100) : 100;
    }
    else {
        echo 100;
    }
}

我以前问过更多的人,他们似乎也不知道这个问题,所以如果有人能帮我解决这个问题,我会非常高兴。

2 个答案:

答案 0 :(得分:0)

一些事情,在你的ajax中,你不应该使用php为什么不选择你已经在表单中创建的路线,这样会更加干净。

也许它什么都不返回,因为这不是你应该如何在laravel上访问SESSION。

你应该这样做:

$yourSessionArray = $request->session()->get('key');

请阅读有关如何使用SESSION with laravel on their docs.

的信息

答案 1 :(得分:-1)

在网址中使用url: "{{route('/uploadprogress')}}",,在路由中使用Route::get()而不是Route::post(),如:

Route::get('/uploadprogress', 'AdminTemplateController@callSessionData')->name('uploadprogress');

并在Ajax中使用:

$.ajax({
    type: "POST",
    url: "/uploadprogress",
    data: {
        "data": $('#myForm').serialize(),
        "_token": "{{ csrf_token() }}",
    },
    success: function() 
    {
        console.log("Geodata sent");
    }
});