OpenConf




Принцип обмена данными из 1С с сайтом (на MySQL) и выдачи (публикации) этих данных по запросу.
PHP-Скрипт автоматической загрузки данных из файла данных в формате CSV в базу данных сайта работающего на WordPress.

В продолжение моей темы: 1С:Альфа-Авто Автосалон Автосервис: обмен с сайтом.
С помощью данного скрипта можно загружать в автоматическом режиме, по расписанию, данные сервисных книжек (ремонтов авто) из 1С:Альфа-Авто Автосалон Автосервис.
Также можно загружать данные в ручном режиме: для этого делается скрытая страница, где размещается специальная кнопка.
Комментарии размещенные внутри скрипта разъяснят логику и порядок действия.
Комментарии с "/////    echo" использовались для отладки.
Дополнительно создана таблица для журналирования результатов загрузки данных.
Скрипт включает в себя защиту от SQL инъекций (думаю безопасность соблюдена в полной мере).
В кратце:
1. Пишется скрипт, который запускает этот.
2. Создается регламентное задание в WordPress, по которому запускается скрипт из п.1. 
3. Этот скрипт осуществляет проверку на существование файла обмена в папке.
4. Если данные не новые, загрузка не производится.
5. Если данные новые, очищается таблица сервисных книжек.
6. Загружаются новые данные.

Собственно сам скрипт:

<?php // Полная загрузка сервисных книжек, создан 2024-01-05 12:44:55

global $wpdb2;
global $failure;
global $file_hist;

/////  echo '<H2><b>Старт загрузки</b></H2><br>';

$failure=FALSE;
//подключаемся к базе
$wpdb2 = include_once 'connection.php'; ; // подключаемся к MySQL
// если не удалось подключиться, и нужно оборвать PHP с сообщением об этой ошибке
if (!empty($wpdb2->error))
{
/////   echo '<H2><b>Ошибка подключения к БД, завершение.</b></H2><br>';
$failure=TRUE;
wp_die( $wpdb2->error );
}

$m_size_file=0;
$m_mtime_file=0;
$m_comment='';
/////проверка существования файлов выгрузки из 1С
////файл выгрузки сервисных книжек
$file_hist = ABSPATH.'/_1c_alfa_exchange/AA_hist.csv';
if (!file_exists($file_hist))
{
/////   echo '<H2><b>Файл обмена с сервисными книжками не существует.</b></H2><br>';
$m_comment='Файл обмена с сервисными книжками не существует';
$failure=TRUE;
}

/////инициируем таблицу лога
/////если не существует файла то возврат и ничего не делаем
if ($failure){
///включает защиту от SQL инъекций и данные можно передавать как есть, например: $_GET['foo']
/////   echo '<H2><b>Попытка вставить запись в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>$m_comment));
wp_die();
/////    echo '<H2><b>Возврат в начало.</b></H2><br>';
return $failure;
}
/////проверка лога загрузки, что бы не загружать тоже самое
$masiv_data_file=stat($file_hist);   ////передаем в массив свойство файла
$m_size_file=$masiv_data_file[7];    ////получаем размер файла
$m_mtime_file=$masiv_data_file[9];   ////получаем дату модификации файла
////создаем запрос на получение последней удачной загрузки
////выбираем по штампу времени создания (редактирования) файла загрузки AA_hist.csv, $m_mtime_file

/////   echo '<H2><b>Размер файла: '.$m_size_file.'</b></H2><br>';
/////   echo '<H2><b>Штамп времени файла: '.$m_mtime_file.'</b></H2><br>';
/////   echo '<H2><b>Формирование запроса на выборку из лога</b></H2><br>';
////препарируем запрос
$text_zaprosa=$wpdb2->prepare("SELECT * FROM `vin_logs` WHERE `last_mtime_upload` = %s", $m_mtime_file);
$results=$wpdb2->get_results($text_zaprosa);

if ($results)
{   foreach ( $results as $r)
{
////если штамп времени и размер файла совпадают, возврат
if (($r->last_mtime_upload==$m_mtime_file) && ($r->last_size_upload==$m_size_file))
{////echo '<H2><b>Возврат в начало, т.к. найдена запись в логе.</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>'Загрузка отменена, новых данных нет, т.к. найдена запись в логе.'));
wp_die();
return $failure;
}
}
}
////если данные новые, пишем в лог запись о начале загрузки
/////echo '<H2><b>Попытка вставить запись о начале загрузки в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>0, 'last_size_upload'=>$m_size_file, 'comment'=>'Начало загрузки'));

////очищаем таблицу
$clear_tbl_zap=$wpdb2->prepare("TRUNCATE TABLE %s", 'vin_history');
$clear_tbl_zap_repl=str_replace("'","`",$clear_tbl_zap);
$results=$wpdb2->query($clear_tbl_zap_repl);
/////   echo '<H2><b>Очистка таблицы сервисных книжек</b></H2><br>';
if (empty($results))
{
/////   echo '<H2><b>Ошибка очистки таблицы книжек, завершение.</b></H2><br>';
//// если очистка не удалась, возврат
$failure=TRUE;
wp_die();
return $failure;
}

////загружаем данные
$table='vin_history';         // Имя таблицы для импорта
//$file_hist Имя CSV файла, откуда берется информация     // (путь от корня web-сервера)
$delim=';';          // Разделитель полей в CSV файле
$enclosed='"';      // Кавычки для содержимого полей
$escaped='\

31 Comments

  1. antonrost

    Напиши, хоть кратко, о возможностях для тех, кто еще не знает (если такие есть).

    Reply
  2. mdzen

    + 1 Давно пользую. Очень облегчает жизнь. Весчь!!!

    P.S.Помнится установка вроде была через инсталлятор.

    Может лучше его выложить. Там и скрипты уже прикручены полезные.

    Reply
  3. lalex23

    какие уж тут комментарии… это МЕГАВЕСЧЬ

    ускорила работу в РАЗЫ

    однозначно +1

    Reply
  4. CheBurator

    Поддержива. АнтонРост — с 1- примеров с картинками — буквально пару слов по каждому…

    Reply
  5. orefkov

    Инсталятор ОпенКонфа с набором скриптов и плагинов- не моя разработка.

    Поэтому могу дать только ссылку: http://kuntashov.narod.ru/openconf-installer.html

    Reply
  6. sergebozz

    AntonRost, посмотри:

    http://infostart.ru/projects/index.php?id=430

    Reply
  7. CheBurator

    Скачиваем, читаем в помощи раздел установка

    Для того, чтобы эта схема заработала, проделайте следующее:

    В каталоге bin исполняемых файлов 1С-Предприятия создайте каталог config

    Файл config.dll, находящийся в каталоге bin, переместите в каталог config

    На его место в каталог bin запишите файл config.dll из поставки OpenConf

    Установка завершена.

    Данный файл загружается только в режиме «Конфигуратора», и не оказывает влияния на работу 1С в режиме «Предприятия».

    Вопрос: что делать с *.tlb?

    Он нужен или нет?

    Reply
  8. orefkov

    Положить в bin

    Нужен

    Reply
  9. The gray Cardinal

    О ручной установке и использовании OpenConf + Телепат + Intellisense читаем здесь:

    http://www.script-coding.info/OpenConf.html

    http://www.script-coding.info/Telepat.html

    http://www.script-coding.info/Intellisense.html

    Reply
  10. CheBurator

    > Положить в bin

    > Нужен

    Ок. сделаем. Положим.

    Но.Почему.Об.Этом.Не.Написано.В.Установке.!

    Reply
  11. vasilykushnir

    1C77.027 скульная. установил OpenConf. в конфигураторе в хожу в меню OpenConf — ОПрограмме, Появляется информационная формочка, а через небольшое время конфигуратор вылетает — «1C:V7 starter program (for SQL) — обнаружена ошибка. Приложение будет закрыто. Приносим извинения за неудобства.» Где руки искривил?

    Reply
  12. artbear

    Оказывается, забыл плюс поставить 🙂

    Очень кульная вещь !

    Reply
  13. Protman

    Большой набор скриптов и дополнительных компонент для OpenConf с описаниями (11-Февраль-2008): http://infostart.ru/projects/1876

    Reply
  14. MRAK

    (0) чета за такую вещь рейтинг низкий! когда на 7.7 был, без сабжа работу не представлял!

    Reply
  15. White__

    а под Win 2003 OpenConf не работает? 🙁

    Reply
  16. Ёпрст

    (15) да.

    Reply
  17. orefkov

    (16)

    Как это? Работает под Win2003.

    Говорят (в openconf light pack) и под Win7 работает.

    Reply
  18. Ёпрст

    (17) блин ..читаю между строк.. 🙂 НЕ не увидел в вопросе..

    Reply
  19. White__

    а у меня не заработало под Win 2003 😐 при старте конфигуратора вылетает дебагер Visual Studio… после чего 1С закрывается.

    может у меня тупо с системой что-то не так? 😮

    дело в том, что мне удобней на своем локальном компе работать с серверной ОС, чтобы тестить всякие штуки на аналогичном сервером софте (W2K3 + SQL EE 2005 +1C:7.7).

    Reply
  20. orefkov

    (19)

    Ну так старым проверенным способом — отключай по одному скрипты/плагины, пока ошибка не пропадет. Тогда и найдешь виновника. Либо WSH надо обновить.

    Либо ищи здесь openconf light pack — довольно стабильный набор скриптов/плагинов, закрывает 90% потребностей.

    Reply
  21. pt_olga

    openconf light pack стал, как родной!!! Спасибище! 🙂

    Reply
  22. bsturtle

    ничего не понятно, но что-то мегакрутое! поставил +

    Reply
  23. SnegAvik

    Очень ускоряет работу,автору огромное спасибо!+

    Reply
  24. Draconus

    С семеркой работал всего несколько раз (не нравится она мне… но это на любителя), но работа с 7.7 благодаря этой програмке заметно увеличила как КПД и мое пребывание в (ненавистной) семерке стало намного приятнее! Автору спасибо.

    Reply
  25. maljaev

    (26) Draconus, спасибо улыбнуло 🙂 У меня то же самое ощущение возникает при разработке в «ненавистной» восьмерке. Надеюсь что Снегопат исправит ситуацию. А на данный момент лучше связки openconf+телепат+intellisence+colored я в 1С еще не видел, восьмерка пока от этого далека даже со Снегопатом. Это в плане непосредственного написания кода, остальные механизмы (подавляющее большинство) в восьмерке мне нравятся.

    Reply
  26. orefkov

    (27)

    Почитай вот это, счастье все ближе 🙂

    Reply
  27. s0nya

    Да, чем дальше, тем больше и больше уходим от привычных в 90х работы ручками, которые просто на автомате команды набирали…

    Reply
  28. orefkov

    (29)

    Ну не скажи — помню на ямахах бэйсиком занимались — там на функциональные клавиши вешался ввод целых фраз.

    Как мы ликовали, когда нам показали немного магии по назначению вместо штатных list run и т.п. своих команд.

    А фокспро, в котором любую команду можно сократить до 4х символов?

    Это вам не ПроцессорВыводаРезультатаКомпо­новкиДанныхВТабличныйДокумент­ИмениНуралиева.

    Имхо во все времена человек старался чтобы руками делать меньше.

    Reply
  29. s0nya

    Забыл уж, и сам с Спектрума начинал…

    Просто наболело. Был на курсах по 1С 8.2, так 30% программирования свелось к правильной расстановке галочек в конфигураторе. Меня лично, это бесит. А к любой системе автоматизированного ввода ещё привыкнуть нужно. В том же бейсике, на кнопке L — LIST был а LOAD хз где.

    Reply
  30. ODmitriy

    Очень помогает в разработке на 7.7. Спасибо большое!

    Reply
  31. an_2

    Идрен батон.

    Никогда не подумал бы, что представится возможность orefkov-у спасибо сказать.

    Ей богу большое человеческое спасибо за килотонны сэкономленного времени и не только времени.

    Наверно инфостарту тоже можно сказать спасибо за неожиданные возможности 🙂

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *