#php #laravel-5
#php #laravel-5
Вопрос:
Я получаю ошибку несоответствия токенов при попытке загрузить большой файл в laravel 5. Я использую поле токена в своей форме.
TokenMismatchException in VerifyCsrfToken.php line 53:
Я уже пробовал несколько методов:
- увеличение upload_max_filesize и post_max_size.
- изменение файла php.ini и перезапуск служб apache.
- отключение промежуточного программного обеспечения csrf для этого маршрута, но в этом случае файл не извлекается!
Вот мое мнение:
<form id="csvform22345" role="form" class="form-horizontal" enctype="multipart/form-data" method="POST" action="{{ URL::to('admin/QC/uploadtomaindbcsv') }}">
{!! Form::token() !!}
{{--<input type="hidden" name="_token" value="{{ csrf_token() }}">--}}
<input type="hidden" name="pid" value="{{ $pid }}">
<div class="row">
<div class="col-sm-8">
<label class="control-label">Select File</label>
<input id="csvfile2" type="file" name="file2" required class="file-loading">
</div>
<div class="col-sm-4">
<div class="alert alert-info small mar-top">Only .csv files allowed.</div>
</div>
</div>
</form>
Функция контроллера:
public function upload_to_maindb()
{
try
{
ini_set('upload_max_filesize', '2G');
ini_set('post_max_size', '4G');
ini_set('max_execution_time', '5000000');
ini_set('max_input_time', '5000000');
ini_set('memory_limit', '200M');
//echo "try block" ; die;
$now = new DateTime();
$timestamp = $now->format('Y-m-d H:i:s');
$pid = Input::get('pid');
$file = Input::file('file2');
$project = Projects::select('project_type')->where('project_id',$pid)->get()->first();
$pt = $project->project_type;
if($file !='') {
$pid = Input::get('pid');
$fp = fopen($file, 'r');
//echo "its here";
//die;
$datas = array();
unset($datas);
while (($row = fgetcsv($fp)) !== FALSE) {
$contact['company_name'] = $row[0];
$contact['website'] = $row[1];
$contact['contact_name'] = $row[2];
$contact['first_name'] = $row[3];
$contact['last_name'] = $row[4];
$contact['email'] = $row[5];
$contact['title'] = $row[6];
$contact['address'] = $row[7];
$contact['city'] = $row[8];
$contact['state'] = $row[9];
$contact['zip_code'] = $row[10];
$contact['country'] = $row[11];
$contact['phone_number'] = $row[12];
$contact['fax_number'] = $row[13];
$contact['industry'] = $row[14];
$contact['sub_industry'] = $row[15];
$contact['revenue'] = $row[16];
$contact['employees'] = $row[17];
$contact['data_category'] = $pt;
/*
$contact['sic_code'] = $row[18];
$contact['naics_code'] = $row[19];
$contact['linkedin_source'] = $row[20];
*/
$contact['last_updated_via_project_id'] = $pid;
$datas[] = $contact;
}
foreach (array_chunk($datas, 200) as $data) {
Master_datarecords::insertIgnore($data);
}
}
unset($datas);
//echo "done"; die;
$msg= "successfully inserted";
}
catch(Exception $e)
{
$msg = "some error occured, please check the file.";
}
$approved_projects= array();
$pids= array();
$i=0;
$projstat = ProjectuserHelpers::GetProjectStatusId("approved");
$projects_object=Projects::where('project_status',$projstat)->get();
if(!($projects_object->isEmpty())) {
$projects = $projects_object->toArray();
foreach ($projects as $val) {
$approved_projects[$i]['pid'] = $val['project_id'];
$approved_projects[$i]['projectname'] = $val['project_name'];
$approved_projects[$i]['record_count'] = Transitional_records::where('fk_project_id', $val['project_id'])->count();
$i ;
}
}
return View::make('admin/home_page/QC/QCtomaindb',compact('approved_projects','msg'));
}
Я не мог найти ничего, кроме этого, в Интернете. Есть ли какое-либо другое решение?
Комментарии:
1. Сообщите мне размер файла и предоставьте свой код представления и контроллера для
2. вот так @MayankPandey
3. Можете ли вы показать свои конфигурации сеанса?
4. Почему — дефисы присутствуют в {{—<тип ввода =»скрытый» имя=»_token» значение=»{{ csrf_token() }}»>—}}
5. См. Piya, ошибка несоответствия токенов возникает, когда вы отправляете форму, а значение токена отсутствует.
Ответ №1:
Я думаю, что это происходит из-за post_max_size
ограничения.
Я увеличил его, 50M
а также увеличил максимальный размер загружаемого файла.
Теперь это работает.
Ответ №2:
Вы в файл php.ini. Найдите это :
max_execution_time и max_input_time.
Редактировать
max_input_time = 1440 и max_execution_time = 1440.
Я попробовал и преуспел