function import($db) { $IMPORT_STEP = 100; //переменная, определяющая сколько будет обработано строк за 1 прогон //ini_set("max_execution_time", "60"); //1 мин $html = ""; //html который возвращаем клиенту //ключевые параметры, обозначают текущую строку в обработке, если 1, то еще не было загрузки $file_name = ""; if (isset($_POST['filename'])) { $file_name = stripslashes($_POST['filename']); } $upload_failure = false; //загрузку файла и подсчет количества строк делаем 1 раз при первой загрузке if ($file_name == "") { $upload_file_field = "uploadedfile"; $uploaddir = $_SERVER['DOCUMENT_ROOT'] . dirname($_SERVER['PHP_SELF']) . "/" . "upload" . "/"; if (strpos($_FILES[$upload_file_field]['name'], ".csv") === false) { $html .= date('m.d.Y H:m:s') . ": " . "<p style='color:red;'>Выберите файл в формате *.csv file!</p>"; $upload_failure = true; } else { if (move_uploaded_file($_FILES[$upload_file_field]['tmp_name'], $uploaddir . $_FILES[$upload_file_field]['name'])) { $html .= date('m.d.Y H:m:s') . ": " . "Файл успешно загружен! Импорт начинается..." . "<br />"; $file_name = $uploaddir . $_FILES[$upload_file_field]['name']; } else { $html .= date('m.d.Y H:m:s') . ": " . "<p style='color:red;'>Что-то пошло не так при загрузке файла: " . $_FILES['uploadedfile']['error'] . "</p>"; $upload_failure = true; } } } else { //if (isset($_POST['filename'])) $file_name = intval($_POST['filename']); //else $currentRow = 1; } if (!$upload_failure) { $makeImportCategories = false; $makeImportManufacturers = false; $makeImportProducts = false; //Комментируем блок, если это необходимо $makeImportCategories = true; $makeImportManufacturers = true; $makeImportProducts = true; //подключение к БД $db->connectToDb(); $table_prefix = $db->getTablePrefix() . $db->getVMTablePrefix(); if ($makeImportCategories) { $category_import = new Categories(); } if ($makeImportManufacturers) { $manufacturer_import = new Manufacturers(); } if ($makeImportProducts) { $product_import = new Products(); } //инициализируем начальные номера основных записей таблиц if ($makeImportCategories) { $html .= $category_import->init($db, $table_prefix); } if ($makeImportManufacturers) { $html .= $manufacturer_import->init($db, $table_prefix); } if ($makeImportProducts) { $html .= $product_import->init($db, $table_prefix); } //принимаени POST переменные //ключевые параметры, обозначают текущую строку в обработке, если 1, то еще не было загрузки if (isset($_POST['currow'])) { $currentRow = intval($_POST['currow']); } else { $currentRow = 1; } if (isset($_POST['wh'])) { $warehouse = $_POST['wh']; } if (isset($_POST['rowcount'])) { if ($_POST['rowcount'] > 1) { $rowCount = intval($_POST['rowcount']); } else { $rowCount = count(file($file_name)); } } else { $rowCount = count(file($file_name)); } if (isset($_POST['maxrow'])) { if ($_POST['maxrow'] > 0) { $max_row = intval($_POST['maxrow']); } else { $max_row = 100000; } //максимальное количество строк для импорта } else { $max_row = 100000; } //максимальное количество строк для импорта if (isset($_POST['startrow'])) { if (intval($_POST['startrow']) > 0) { $init_row = intval($_POST['startrow']) - 2; } else { $init_row = 0; } //пропускаем все строки до данной строки (начинаем прием с этой строки) } else { $init_row = 0; } //пропускаем все строки до данной строки (начинаем прием с этой строки) //если начальная строка пользователя меньше текущей строки обработки, то должны обрабатывать с текущей строки if ($init_row < $currentRow) { $init_row = $currentRow + $init_row; } //2. read csv file $fileArr = file($file_name); $row = 1; //счетчик итераций в одной обработке $opCount = count($fileArr); $fileArr = array_slice($fileArr, $init_row); for ($j = $init_row; $j < $opCount; $j++) { if ($row + $currentRow < $max_row) { $data = fgetcsv_array($fileArr, ";"); if (trim($data[0]) != "") { //основной импорт for ($i = 0; $i < count($data); $i++) { $dataUTF[$i] = iconv('windows-1251', 'UTF-8', $data[$i]); } if ($makeImportCategories) { $html .= $category_import->process($dataUTF); } if ($makeImportManufacturers) { $html .= $manufacturer_import->process($dataUTF); } if ($makeImportProducts) { $html .= $product_import->process($dataUTF, $category_import->getCategory(), $manufacturer_import->getManufacturer(), $warehouse); } } } if ($row > $IMPORT_STEP) { if ($html != "") { $html = date('m.d.Y H:m:s') . ": " . $html; } echo '{"currow":"' . ($row + $currentRow) . '", "rowcount":"' . intval($rowCount) . '", "filename":"' . addslashes($file_name) . '", "state":"process", "log":"' . $html . '"}'; flush(); return; } $row++; } $html = '<br />' . date('m.d.Y H:m:s') . ": " . "Импорт завершен!" . '<br />' . "<strong>Не забудьте обновить карту сайта на закладке Админ</strong>" . '<br />' . $html; echo '{"currow":"' . ($row + $currentRow) . '", "rowcount":"' . $rowCount . '", "filename":"' . addslashes($file_name) . '", "state":"complete", "log":"' . $html . '"}'; } }
public static function getCategory($id) { $categories = new Categories(); return $categories->getCategory($id); }
<?php include_once "../core/model.php"; include_once "../models/categories.php"; include_once "../views/functions.php"; $id_category = getIdFromUrl(); $category = new Categories(); $category->getCategory($id_category); include_once "admin-header.php"; echo "<a href='" . PATHSITE . "/admin-categories'>Вернуться</a>"; // or href="javascript:history.go(-1)" ?> <h2>Просмотр категории</h2> <form name="admin-category" action="http://localhost/iba/category/update" method="post" onsubmit="alert('Данные успешно сохранены!');"> <label>Номер категории:</label> <input type="text" id="id_category" name="id_category" maxlength="11" value="<?php echo $category->id; ?> " readonly="readonly"> <label>Название категории:</label> <input type="text" id="name" name="name" maxlength="30" value="<?php echo $category->name; ?> "> <label>Родительская категория:</label> <input type="text" id="id_parent" name="id_parent" maxlength="11" value="<?php echo $category->id_parent; ?>