Разработка программного обеспечения для автоматизации формирования учебных программ - Дипломная работа

бесплатно 0
4.5 159
Анализ существующих систем автоматизации документооборота. Выбор шаблона проектирования. Microsoft SQL Server как комплексная высокопроизводительная платформа баз данных. Язык программирования C#. Разработка интерфейса и иллюстрация работы системы.

Скачать работу Скачать уникальную работу

Чтобы скачать работу, Вы должны пройти проверку:


Аннотация к работе
В СЭД должны автоматически отслеживаться изменения в документах, сроки исполнения документов, движение документов, а также контролироваться все их версии и подверсии. Настоящая система формирования учебных программ на кафедре ИТИКС не автоматизирована. Для достижения поставленной цели необходимо в процессе дипломного проектирования решить следующие задачи: - Разработать систему, позволяющую максимально автоматизировать процесс формирования учебных программ; В состав дипломного проекта входит пояснительная записка, которая включает в себя следующие материалы: - в первой главе произведен анализ структуры предприятия, рассмотрены вопросы актуальности и необходимости разработки ПО, аналоги разрабатываемой системы и поставлены задачи на проектирование; в третьей главе описан процесс разработки, структура и принцип работы программного обеспечения для формирования учебных программ, изучена и алгоритмизирована методика расчета стоимости заказа, описаны разработанные алгоритмы для работы системы, и обеспечена безопасность учетной записи пользователя;возможность быстрого переключения пользователей, позволяющая временно прервать работу одного пользователя и выполнить вход в систему под именем другого пользователя, оставляя при этом приложения, запущенные первым пользователем, включенными; программа восстановления системы, предназначенная для возвращения системы в определенное предшествующее состояние (эта функция является развитием аналогичной программы, включенной в Windows ME), а также улучшение других способов восстановления системы. Работа с архивами данного типа возможна в проводнике как с обычными папками, которые можно создавать и удалять, заходить в архив, добавлять/удалять файлы подобно работе с обычными папками. Visual Studio позволяет создавать и подключать сторонние дополнения (плагины) для расширения функциональности практически на каждом уровне, включая добавление поддержки систем контроля версий исходного кода (как например, Subversion и Visual SOURCESAFE), добавление новых наборов инструментов (например, для редактирования и визуального проектирования кода на предметно-ориентированных языках программирования или инструментов для прочих аспектов процесса разработки программного обеспечения (например, клиент Team Explorer для работы с Team Foundation Server). Обеспечивает связь между пользователем и системой: контролирует ввод данных пользователем и использует модель и представление для реализации необходимой реакции.В результате дипломного проектирования было разработано программное обеспечение для автоматизации формирования учебных программ на кафедре ИВТ факультета ИТИКС ОМГТУ. Разработанное ПО дает возможность автоматизировать процесс как создания новой учебной программы, так и редактирования уже существующего документа с помощью синтаксического анализа текста. В рамках проектирования были решены следующие задачи: - разработано приложение для упрощения составления учебных программ. Применение разработанного Desktop-приложения позволит значительно сократить время конструирования новой учебной программы; В таблицы заносятся и хранятся шаблоны, необходимые для формирования учебной программы, и считываемый из файлов текст, который понадобится для дальнейших операций;{return buffer[buffer.INDEXOF(buffer.FIRSTORDEFAULT(b => b.Contains("по дисциплине"))) 1].Split(new[] {"»" }, STRINGSPLITOPTIONS.REMOVEEMPTYENTRIES)[0].Substring(2); {return buffer[buffer.INDEXOF(buffer.FIRSTORDEFAULT(b => b.Contains("по дисциплине"))) 1].Split(new[] {"»" }, STRINGSPLITOPTIONS.REMOVEEMPTYENTRIES)[1].Trim(); {return buffer[buffer.INDEXOF(buffer.FIRSTORDEFAULT(b => b.Contains("для направления подготовки")))].Split( new[] {"для направления подготовки" }, STRINGSPLITOPTIONS.REMOVEEMPTYENTRIES)[0].Trim(); {return buffer[buffer.INDEXOF(buffer.FIRSTORDEFAULT(b => b.Contains("для направления подготовки"))) 1].Split(new[] {"«" }, STRINGSPLITOPTIONS.REMOVEEMPTYENTRIES)[0].Trim(); {return buffer[buffer.INDEXOF(buffer.FIRSTORDEFAULT(b => b.Contains("для направления подготовки"))) 1].Split(new[] {"«", "»" }, STRINGSPLITOPTIONS.REMOVEEMPTYENTRIES)[1].Trim();} private void button1_Click(object sender, EVENTARGS e) } private void COMBOBOX1_SELECTEDINDEXCHANGED(object sender, EVENTARGS e) } private void button2_Click(object sender, EVENTARGS e) Stream stream = new MEMORYSTREAM(file.Stream); TEXTBOX1.Text = string.Format("Degree = {0}{1}", degree, Environment.NEWLINE);using System.Collections.Generic; {public int FORMATTEXTID {get; set; } public int SUBJECTID {get; set; } public string Name {get; set; } public string Value {get; set; } public virtual Subject Subject {get; set; } using System.Collections.

Введение
Целью дипломного проекта является разработка программного обеспечения для автоматизации формирования учебных программ на кафедре ИВТ факультета ИТИКС ОМГТУ. Учебное заведение является одним из крупнейших и престижнейших в городе Омске.

Разрабатываемое программное обеспечение относится к классу систем электронного документооборота (СЭДО).

Главное назначение СЭДО - это организация хранения электронных документов, а также работы с ними (в частности, их поиска как по атрибутам, так и по содержимому). В СЭД должны автоматически отслеживаться изменения в документах, сроки исполнения документов, движение документов, а также контролироваться все их версии и подверсии. Комплексная СЭД должна охватывать весь цикл делопроизводства предприятия или организации - от постановки задачи на создание документа до его списания в архив, обеспечивать централизованное хранение документов в любых форматах, в том числе, сложных композиционных документов. СЭД должны объединять разрозненные потоки документов территориально удаленных предприятий в единую систему.

Они должны обеспечивать гибкое управление документами как с помощью жесткого определения маршрутов движения, так и путем свободной маршрутизации документов. В СЭДО должно быть реализовано жесткое разграничение доступа пользователей к различным документам в зависимости от их компетенции, занимаемой должности и назначенных им полномочий. Кроме того, СЭДО должна настраиваться на существующую организационно-штатную структуру и систему делопроизводства предприятия, а также интегрироваться с существующими корпоративными системами.

Настоящая система формирования учебных программ на кафедре ИТИКС не автоматизирована. В связи с этим, пользователю ПК требуется много времени для их создания.

Внедрение разрабатываемого программного обеспечения призвано: - автоматизировать систему формирования новых учебных программ;

- уменьшить время на создание и заполнение учебных программ.

Для достижения поставленной цели необходимо в процессе дипломного проектирования решить следующие задачи: - Разработать систему, позволяющую максимально автоматизировать процесс формирования учебных программ;

- спроектировать базу данных для хранения шаблонов, необходимых для формирования учебных программ;

- разработать простой удобный интерфейс;

- предусмотреть возможность хранения в БД версий и черновиков учебных программ.

В состав дипломного проекта входит пояснительная записка, которая включает в себя следующие материалы: - в первой главе произведен анализ структуры предприятия, рассмотрены вопросы актуальности и необходимости разработки ПО, аналоги разрабатываемой системы и поставлены задачи на проектирование;

- во второй главе представлен выбор и обоснование средств и технологий разработки системы;

- в третьей главе описан процесс разработки, структура и принцип работы программного обеспечения для формирования учебных программ, изучена и алгоритмизирована методика расчета стоимости заказа, описаны разработанные алгоритмы для работы системы, и обеспечена безопасность учетной записи пользователя;

- в четвертой главе представлена разработка пользовательского интерфейса и руководство пользователя программным обеспечением, проиллюстрированы основные моменты работы системы;

- в пятой главе дана организационно-экономическая часть, составлена смета на разработку системы;

- в шестой главе рассмотрены вопросы охраны труда.

1. Анализ предприятия

1.1 Структура предприятия

Омский государственный технический университет организован как Омский машиностроительный институт в 1942 году и является на данный момент одним из крупнейших и популярнейших вузов в городе Омске. В составе университета 6 факультетов, 5 институтов и 3 филиала. В университете обучаются более 17000 студентов дневной, вечерней и заочной формы обучения. В штате университета около 1600 сотрудников, более 850 из которых преподаватели, большая часть которых кандидаты и доктора наук. В состав вуза входит несколько зданий: - 9 учебных корпусов;

- здание военной кафедры;

- общежития.

В настоящее время ведутся работы по открытию 3 новых корпусов.

В состав вуза входят следующие факультеты: - факультет информационных технологий и компьютерных систем (ФИТИКС) (бывший факультет автоматизации);

- факультет транспорта, нефти и газа (ФТНГ);

- радиотехнический факультет (РТФ);

- факультет Элитного образования и магистратуры;

- факультет экономики и управления (ФЭУ);

- факультет гуманитарного образования (ФГО);

- факультет довузовской подготовки (ФДП).

Также Университет состоит из семи институтов: o Энергетический институт;

o Нефтехимический институт;

o Машиностроительный институт;

o Институт безопасности жизнедеятельности;

o Институт Военно-технического образования;

o Институт заочного обучения;

o Институт дополнительного профессионального образования.

Поскольку в данном дипломном проекте рассматривается внедрение ПО только для кафедры информатики и вычислительной техники факультета ИТИКС, то будет рассматриваться организация управления именно этой кафедры.

Управление кафедрой ИВТ осуществляет заведующий кафедры. Также в состав кафедры входят сотрудники, обладающие следующими должностями: - заместитель заведующего кафедры;

- профессор кафедры;

- старший преподаватель;

- ассистент;

- инженер.

Начальник отдела управления персоналом - отвечает за оперативную работу предприятия и управление персоналом.

Начальник отдела продаж - следит за работой филиалов отделов продаж.

В соответствии с рисунком 1.1 общая схема структуры предприятия имеет вид:

Рисунок 1.1 - Схема структуры с кафедры ИВТ автоматизация документооборот программирование интерфейс

Процесс формирования учебной программы осуществляется следующим образом: пользователь запускает на ПК графический редактор MS Word ищ офисного пакета приложений Microsoft Office. В нем пользователь вручную заполняет все пункты учебной программы. Далее пользователь имеет возможность сохранить созданный документ либо распечатать его.

В соответствии с рисунком 1.2 процесс формирования учебной программы происходит следующим образом:

Рисунок 1.2 - Процесс формирования новой учебной программы

В результате рассмотрения процесса создания учебной программы, был выявлены его недостатки в связи с ручным заполнением с помощью графического редактора: - настоящая система формирования документа учебной программы не автоматизирована;

- недопустимо много времени уходит на формирование готовой учебной программы.

Исходя из выше перечисленных недостатков, можно сделать вывод о том, что существующая система на кафедре «Информатика и вычислительная техника» ОМГТУ нуждается в переработке и может быть улучшена. В следующем разделе будут рассмотрены наиболее удачные программные решения в области систем электронного документооборота.

Вывод
В настоящем разделе была рассмотрена структура работников ОМГТУ, в частности кафедры ИВТ, для которой разрабатывается ПО, выявлены недочеты существующего процесса формирования учебных программ.

2. Анализ существующих систем автоматизации документооборота

При анализе работы программ были использованы материалы, находящиеся в открытом доступе. Программная реализация систем не анализировалась, потому что является собственностью владельцев программ и разглашению не подлежит.

В настоящее время существует достаточное количество программного обеспечения для предприятий, которые используют системы электронного документооборота. Они могут по-разному выбираться, формироваться и строиться в зависимости от вышеназванных условий, размера организации, характера и специфики ее деятельности, квалификации кадров, финансовых возможностей, набора подсистем (модулей), имеющих различную функциональную и технологическую наполненность, построенных с помощью разных программных продуктов, созданных одним или несколькими производителями.

Однако в последнее время все большее количество экспертов соглашается, что непременными атрибутами комплексной системы автоматизации документооборота должны быть композиции из трех программных технологий, уже достаточно давно предлагаемых компаниями-разработчиками. Ниже будут рассмотрены каждая из них.

2.1 WORKFLOW

Эта концепция была предложена компанией Staffware около 20 лет назад. Данная концепция рассматривает весь комплекс задач автоматизации бизнеса как совокупность бизнес-процессов. Инструменты, предоставляемые WORKFLOW-системой, обеспечивают формирование описаний процессов, данных, а также содержат средства описания электронных форм для обработки этих данных. Технология WORKFLOW подразумевает четкое исполнение процесса согласно его описанию. Сервисы системы поддерживают реализацию бизнес-процессов, формирование и подготовку очередей заданий к обработке, автоматически обеспечивают нужную активность стадий процесса, контроль своевременности исполнения этапов процесса и различные способы реакции на возникающие проблемы.

Современная индустриальная WORKFLOW-система должна быть достаточно гибкой и включать в себя инструменты моделирования процессов, актуальных для компании; отслеживания состояния процессов и получения информации о несоответствии их течения; накопления статистики об отклонениях. Таким образом, WORKFLOW-система позволяет непрерывно улучшать и реструктурировать бизнес-процессы компании; она содержит реальные инструменты для постоянной оценки, модификации и улучшения качества бизнес-процессов, средства маршрутизации документов и других объектов, интеграции с другими продуктами корпоративных информационных систем. Наличие подобных инструментов позволяет на практике реализовать концепцию непрерывного реинжиниринга бизнеса. Обеспечивая практически мгновенную передачу работ между участниками бизнес-процесса и имея режим напоминания пользователям о необходимых действиях, система WORKFLOW может существенным образом влиять на скорость реализации бизнес-процессов. Пример схемы алгоритма работы СЭДО на базе WORKFLOW проиллюстрирован на рисунке 2.1.

2.2 Document Management System (DMS)

DMS-системы появились достаточно давно и вначале обеспечивали несложные функции хранения файлов документов (или электронных архивов документов). Набор их был примерно таким: хранение и доступ к файлам; быстрый просмотр документов; разграничение прав доступа; ведение протокола доступа и контроль; отслеживание истории обработки документов; управление версиями.

Рисунок 2.1 - Пример схемы алгоритма работы СЭДО на базе WORKFLOW

Со временем они стали прирастать дополнительными функциями, среди которых: ведение картотеки документов и инструменты быстрой разработки электронных форм;

поддержка справочников с информацией для заполнения карточек;

описание процесса обработки документов (фиксированных маршрутов);

навигация и организация представления учетной информации о документах;

свободная маршрутизация документов и поддержка персональных очередей пользователей;

описание жизненного цикла обработки документа;

управление маршрутизацией и средствами мониторинга процессов.

Наличие подобных средств управления процессами контроля, движения и обработки документов делает систему применимой для решения гораздо более широкого круга задач, нежели только ведение архива документов. Именно функциональность DMS-систем позволяет добавить в СЭД столь необходимые функции обработки слабоструктурированных данных. На рисунке 2.2 представлена схема алгоритма системы на базе программной технологии Document Management System.

Рисунок 2.2 - Пример схемы алгоритма работы СЭДО на базе DMS

1. GROUPWARE

Данная концепция зародилась в начале 90-х годов прошлого столетия. Основной ее идеей было создание удобной среды доступа к разнородной информации и организация групповой работы с ней. Необходимо отметить, что термин GROUPWARE так и не получил формального толкования. В качестве примера можно назвать такие разные системы, как Link Works и Lotus Notes. В свое время к GROUPWARE относили и средства организации досок объявлений, и системы календарного планирования, и средства взаимодействия в реальном времени, организации телеконференций и группового пространства для доступа к файлам документов и многое другое. Однако с появлением таких продуктов, как Lotus Domino, Microsoft Exchange и Novell GROUPWISE, границы данной технологии определились довольно отчетливо.

GROUPWARE-компоненты умеют решать такие задачи и возможности, как: - создание баз данных группового доступа, в которых может храниться разнородная структурированная и неструктурированная (слабоструктурированная) информация;

- унифицированное клиентское рабочее место, обеспечивающее навигацию по всем приложениям, созданным в рамках системы;

- встроенные средства разработки электронных форм, обеспечивающих доступ к информации в базах данных системы;

- средства организации представлений (View), позволяющие создавать различные визуальные представления данных, хранящихся в БД, в зависимости от конкретных потребностей пользователей;

- встроенные возможности маршрутизации электронных форм, интеграция с электронной почтой и средствами группового планирования;

- широкие возможности управления гиперссылками и их использования в приложениях.

Наличие описанных функций позволило разработчикам решений создавать самые разнообразные приложения на базе систем класса GROUPWARE. Они, как правило, имеют унифицированный интерфейс и средства навигации, базируются на общем каталоге пользователей и образуют общую среду взаимодействия пользователей с информацией. Важную роль в развитии GROUPWARE-систем сыграла концепция универсального почтового ящика (Inbox), предназначенного для получения в виде электронных форм разнородной информации (сообщений электронной почты, факсов, приглашений, поручений, документов и др.), а также средства управления персональным расписанием.

На рисунке 2.3 проиллюстрирован пример схемы алгоритма работы СЭДО, построенной с помощью программной технологии GROUPWARE.

Рисунок 2.3 - Пример схемы алгоритма работы СЭДО на GROUPWARE

Ввиду сложности освоения и нехватки времени изучения вышеописанных программных технологий, было решено их не использовать.

2.3 Техническое задание на проектирование

Целью дипломного проектирования является разработка программного обеспечения для автоматизации процесса формирования учебных программ с помощью приложения.

Для достижения поставленной цели, необходимо решить следующие задачи: - разработать систему, позволяющую максимально автоматизировать процесс формирования учебных программ;

- спроектировать базу данных для хранения шаблонов, необходимых для формирования учебных программ;

- разработать простой удобный интерфейс;

- предусмотреть возможность хранения в БД версий и черновиков учебных программ.

В настоящем разделе были рассмотрены наиболее популярные программные технологии на рынке систем электронного документооборота, выявлены их особенности и функционал. Сделан вывод о недостижимости решения проблемы с помощью описанных технологий. Поставлены задачи на проектирование программного обеспечения для автоматизации процесса создания учебных программ, который должен ликвидировать основные недостатки существующего процесса их формирования.

3. Выбор и обоснование средств и технологий разработки программного обеспечения

3.1 Операционная система

Операционная система (ОС) - программное обеспечение, которое управляет работой аппаратной части персональных компьютеров, ноутбуков, КПК, смартфонов, коммуникаторов, GPS-навигаторов и других устройств. Кроме того, ОС обеспечивает работу пользовательских и системных приложений.

В любой операционной системе можно выделить 4 основные части: ядро, файловую структуру, интерпретатор команд пользователя и утилиты.

- Ядро - это основная, определяющая часть операционной системы, которая управляет аппаратными средствами и выполнением программ.

- Файловая структура - это система хранения файлов на запоминающих устройствах.

- Интерпретатор команд или оболочка - это программа, организующая взаимодействие пользователя с компьютером.

- Утилиты - это просто отдельные программы, которые, вообще говоря, ничем принципиально не отличаются от других программ, запускаемых пользователем, разве только своим основным назначением - они выполняют служебные функции.

Основные функции операционных систем: Загрузка приложений в оперативную память и их выполнение;

- стандартизованный доступ к периферийным устройствам (устройства ввода-вывода);

- управление оперативной памятью (распределение между процессами, виртуальная память);

- управление доступом к данным на энергонезависимых носителях (таких как жесткий диск, компакт-диск и т. д.), как правило, с помощью файловой системы;

- пользовательский интерфейс;

- сетевые операции, поддержка стека протоколов.

Дополнительные функции: - параллельное или псевдопараллельное выполнение задач (многозадачность);

- взаимодействие между процессами: обмен данными, взаимная синхронизация;

- защита самой системы, а также пользовательских данных и программ от действий пользователей (злонамеренных или по незнанию) или приложений;

- разграничение прав доступа и многопользовательский режим работы (аутентификация, авторизация).

Windows XP (внутренняя версия - Windows NT 5.1) - операционная система (ОС) семейства Windows NT корпорации Microsoft. Она была выпущена 25 октября 2001 года и является развитием Windows 2000 Professional.

По данным веб-аналитики от W3Schools (англ.) с сентября 2003 по июль 2011 года Windows XP была самой используемой операционной системой для доступа к сети Интернет в мире. По состоянию на апрель 2012 года, Windows XP находится на втором месте с долей 27,3%. Максимум этого значения составлял 76,1 % и был достигнут в январе 2007 года.

Новшества по сравнению с Windows 2000

Некоторыми из наиболее заметных улучшений в Windows XP по сравнению с Windows 2000 являются: - новое оформление графического интерфейса, включая более округлые формы и плавные цвета; а также дополнительные функциональные улучшения (такие, как возможность представления папки в виде слайд-шоу в проводнике Windows);

- поддержка метода сглаживания текста CLEARTYPE, улучшающего отображение текста на ЖК-дисплеях (по умолчанию отключена);

- возможность быстрого переключения пользователей, позволяющая временно прервать работу одного пользователя и выполнить вход в систему под именем другого пользователя, оставляя при этом приложения, запущенные первым пользователем, включенными;

- функция «удаленный помощник», позволяющая опытным пользователям и техническому персоналу подключаться к компьютеру с системой Windows XP по сети для разрешения проблем. При этом помогающий пользователь может видеть содержимое экрана, вести беседу и (с позволения удаленного пользователя) брать управление в свои руки;

- программа восстановления системы, предназначенная для возвращения системы в определенное предшествующее состояние (эта функция является развитием аналогичной программы, включенной в Windows ME), а также улучшение других способов восстановления системы. Так, при загрузке последней удачной конфигурации загружается также и прежний набор драйверов, что позволяет в ряде случаев легко восстановить систему при проблемах, возникших в результате установки драйверов; возможность отката драйверов и т. д.;

- улучшенная совместимость со старыми программами и играми. Специальный мастер совместимости позволяет эмулировать для отдельной программы поведение одной из предыдущих версий ОС (начиная с Windows 95). Впрочем, функция совместимости присутствует в Windows 2000 с пакетом обновления 2;

- возможность удаленного доступа к рабочей станции благодаря включению в систему миниатюрного сервера терминалов (только в издании Professional);

- более развитые функции управления системой из командной строки;

- windows XP включает технологии, разработанные фирмой Roxio, которые позволяют производить прямую запись CD из проводника, не устанавливая;

- windows XP может работать с архивами ZIP и CAB без установки дополнительного ПО. Работа с архивами данного типа возможна в проводнике как с обычными папками, которые можно создавать и удалять, заходить в архив, добавлять/удалять файлы подобно работе с обычными папками. Также возможна установка пароля на архив. При необходимости можно назначить для работы с этими архивами любое стороннее программное обеспечение;

- улучшения в подсистеме EFS, заключающиеся в необязательности агента восстановления, более безопасного сохранения ключей. Шифруемые файлы теперь не просто удаляются, а перезаписываются нулями, что гораздо надежнее. Начиная с SP1, становится возможным использовать (он и используется по умолчанию) алгоритм AES, наряду с DESX и 3-DES;

- настраиваемые панели инструментов, с помощью которых можно оптимизировать доступ к файлам, папкам и ресурсам Интернета. Достаточно разместить их на краю Рабочего стола (наподобие боковой панели) или на Панели задач (в форме ссылки).

Так как на всех рабочих местах кафедры ИВТ установлен Windows XP, это послужило основанием для выбора этой операционной системы, а также все достоинства, которые описаны в текущем подразделе.

3.2 Microsoft SQL Server 2008 R2

Microsoft SQL Server - это комплексная высокопроизводительная платформа баз данных, обеспечивающая управление данными в масштабе предприятия и оснащенная встроенными средствами бизнес-аналитики (Business Intelligence, BI). SQL Server позволяет организациям строить интегрированные решения для учета и анализа данных масштаба предприятия, предоставляя сервисы, обеспечивающие надежность, безопасность доступа и масштабируемость. Благодаря исчерпывающему набору функций, взаимодействию с существующими системами и автоматизации типовых задач, SQL Server представляет собой полное решение в области хранения, управления и анализа данных для широчайшего диапазона масштабов.

Каждая очередная версия SQL Server обогащается новыми возможностями, реализованными в соответствии с общим планом развития продукта и пожеланиями пользователей. С выпуском версии SQL Server 2008 и, в особенности, SQL Server 2008 R2 продукт Microsoft SQL Server стал не просто сервером баз данных, а целостной платформой построения систем управления корпоративной информацией. SQL Server 2008 R2 является более мощной системой, с поддержкой до 256 логических процессоров и неограниченной поддержкой памяти (в пределах ограничений операционной системы).

В SQL Server 2008 R2 включен ряд новых возможностей, в том числе: - аналитика «по требованию» на основе POWERPIVOT для Excel и SHAREPOINT;

- улучшения в отчетности, в частности, поддержка картографических отчетов;

- службы управления нормативно-справочной информацией Master Data Services;

- система комплексной обработки событий STREAMINSIGHT.

Основным фактором использования в качестве инструмента разработки Microsoft SQL Server 2008 R2 в данном дипломном проекте стал быстрый и удобный доступ к базе данных с помощью такого средства разработки, как Microsoft Visual Studio 2013.

На рисунке 3.1 проиллюстрирован пример схемы приложения, построенного с помощью SQL Server 2008 R2 и Visual Studio 2010.

Рисунок 3.1 - Пример приложения уровня данных в SQL Server 2008 R2 и Visual Studio 2010

3.3 Язык программирования C#

NET Framework - программная платформа, выпущенная компанией Microsoft в 2002 году. Основой платформы является общеязыковая среда исполнения Common Language Runtime (CLR), которая подходит для разных языков программирования. Функциональные возможности CLR доступны в любых языках программирования, использующих эту среду.

C# - объектно-ориентированный язык программирования. Разработан в компании Microsoft как язык разработки приложений для платформы Microsoft.NET Framework и впоследствии был стандартизирован как ECMA-334 и ISO/IEC 23270. Особенностью C# является то, что он разрабатывался как язык программирования прикладного уровня для CLR и, как таковой, зависит, прежде всего, от возможностей самой CLR. Исполняющая среда CLR предоставляет C#, как и всем другим. NET-ориентированным языкам, многие возможности.

Выбор языка C# обусловлен его относительной простотой в изучении, высокой расширяемостью системы, то есть в C# можно импортировать классы и объекты из других программ.

3.4 Visual Studio

Microsoft Visual Studio - линейка продуктов компании Майкрософт, включающих интегрированную среду разработки программного обеспечения и ряд других инструментальных средств. Данные продукты позволяют разрабатывать как консольные приложения, так и приложения с графическим интерфейсом, в том числе с поддержкой технологии Windows Forms, а также вебсайты, веб-приложения, веб-службы как в родном, так и в управляемом кодах для всех платформ, поддерживаемых Microsoft Windows, Windows Mobile, Windows CE,.NET Framework, Xbox, Windows Phone.NET Compact Framework и Microsoft Silverlight.

Visual Studio включает в себя редактор исходного кода с поддержкой технологии INTELLISENSE и возможностью простейшего рефакторинга кода. Встроенный отладчик может работать как отладчик уровня исходного кода, так и как отладчик машинного уровня. Остальные встраиваемые инструменты включают в себя редактор форм для упрощения создания графического интерфейса приложения, веб-редактор, дизайнер классов и дизайнер схемы базы данных. Visual Studio позволяет создавать и подключать сторонние дополнения (плагины) для расширения функциональности практически на каждом уровне, включая добавление поддержки систем контроля версий исходного кода (как например, Subversion и Visual SOURCESAFE), добавление новых наборов инструментов (например, для редактирования и визуального проектирования кода на предметно-ориентированных языках программирования или инструментов для прочих аспектов процесса разработки программного обеспечения (например, клиент Team Explorer для работы с Team Foundation Server).

Главными причинами выбора продукта Visual Studio в данном проекте являются: - интегрированный язык С#;

- простая реализация общих задач;

- технология INTELLISENSE, позволяющая ускорить кодирование, поскольку уменьшается количество текста, набираемого на клавиатуре, а также уменьшается необходимость обращаться к внешней документации;

- расширение Resharper, которое предусматривает синтаксический анализ кода, дополнительные средства автозаполнения и подсветки синтаксиса;

- Entity Framework - объектно-ориентированная технология доступа к данным, интегриреумая в линейку продуктов Visual Studio начиная с Visual Studio 2008 Service Pack 1.

На рисунке 3.2 приведено окно при запуске Visual Studio 2013.

Рисунок 3.2 - Главное окно в Visual Studio 2013

3.5 Выбор шаблона проектирования

Model-View-Controller (MVC, «Модель-представление-контроллер») - схема использования нескольких шаблонов проектирования, с помощью которых модель данных приложения, пользовательский интерфейс и взаимодействие с пользователем разделены на три отдельных компонента так, что модификация одного из них оказывает минимальное воздействие на остальные.

В соответствии с рисунком 3.3 шаблон MVC концепции имеет вид:

Рисунок 3.3 - Общая схема концепции MVC

В концепции MVC, описанной в 1979 году, была представлена сама идея и роль каждого из элементов: модели, представления и контроллера. Но связи между ними были описаны без конкретизации. Кроме того, различали две основные модификации: - пассивная модель - модель не имеет никаких способов воздействовать на представление или контроллер, и используется ими в качестве источника данных для отображения. Все изменения модели отслеживаются контроллером, и он же отвечает за перерисовку представления, если это необходимо. Такая модель чаще используется в структурном программировании, так как в этом случае модель представляет просто структуру данных, без методов их обрабатывающих;

- активная модель - модель оповещает представление о том, что в ней произошли изменения, а представления, которые заинтересованы в оповещении, подписываются на эти сообщения. Это позволяет сохранить независимость модели как от контроллера, так и от представления.

Концепция MVC позволяет разделить данные, представление и обработку действий пользователя на три отдельных компонента: - модель (Model). Модель предоставляет знания: данные и методы работы с этими данными, реагирует на запросы, изменяя свое состояние. Не содержит информации, как эти знания можно визуализировать;

- представление, вид (View). Отвечает за отображение информации (визуализацию). Часто в качестве представления выступает форма (окно) с графическими элементами;

- контроллер (Controller). Обеспечивает связь между пользователем и системой: контролирует ввод данных пользователем и использует модель и представление для реализации необходимой реакции.

Важно отметить, что как представление, так и контроллер зависят от модели. Однако модель не зависит ни от представления, ни от контроллера. Тем самым достигается назначение такого разделения: оно позволяет строить модель независимо от визуального представления, а также создавать несколько различных представлений для одной модели.

Основная цель применения этой концепции состоит в разделении модели от ее визуализации (представления, вида). За счет такого разделения повышается возможность повторного использования. Наиболее полезно применение данной концепции в тех случаях, когда пользователь должен видеть те же самые данные одновременно в различных контекстах и/или с различных точек зрения. В частности, выполняются следующие задачи: - к одной модели можно присоединить несколько представлений (Отображений), при этом, не затрагивая реализацию модели. Например, некоторые данные могут быть одновременно представлены в виде электронной таблицы, гистограммы и круговой диаграммы;

- не затрагивая реализацию видов, можно изменить реакции на действия пользователя (нажатие мышью на кнопке, ввод данных), для этого достаточно использовать другой контроллер;

- ряд разработчиков специализируется только в одной из областей: либо разрабатывают графический интерфейс, либо разрабатывают бизнес-логику. Поэтому возможно добиться того, что программисты, занимающиеся разработкой модели, вообще не будут осведомлены о том, какое представление будет использоваться.

В настоящем разделе были охарактеризованы средства для разработки программного обеспечения для автоматизации формирования учебных программ, обоснован их выбор. Согласно поставленным задачам, разрабатываемый проект имеет следующие технические характеристики: - клиентское приложение с оконным интерфейсом;

- шаблон проектирования - MVC;

- СУБД - Microsoft SQL Server 2008 R2;

- платформа для разработки -.NET (язык С#).

4. Разработка программного обеспечения для автоматизации формирования учебных программ

4.1 Проектирование программного обеспечения

Для разработки ПО использовался шаблон проектирования MVC. Данная концепция позволяет разделить данные, представление и обработку действий пользователя на три отдельных компонента - Модель - Представление - Контроллер.

Для обработки действий пользователей был разработан контроллер, который при запуске выполняет соответствующее действие, что обычно подразумевает создание соответствующих моделей и отображение необходимых представлений.

Таким образом, сформированы компоненты, соответствующие шаблону проектирования MVC, общая схема которых в соответствии с рисунком 4.1 имеет вид:

Рисунок 4.1 - Схема работы системы

4.2 Сохранение рабочей программы в базу данных

Схема алгоритма сохранения рабочей программы в базу данных представлена на рисунке 4.2:

Рисунок 4.2 - Схема алгоритма сохранения рабочей программы в БД.

Для внесения в базу данных пользователю необходимо сначала указать путь к файлу, с помощью которого будет сформирована новая учебная программа.

Схема алгоритма загрузки файла в приложение отображена на рисунке 4.3:

Рисунок 4.3 - Схема алгоритма загрузки файла в приложение

4.3 Разработка базы данных программного обеспечения

В результате анализа предметной области был выделен список свойств и атрибутов. База содержит 5 таблиц, отражающих принцип работы системы: шаблоны и черновики учебных программ, считываемый текст из текстового файла. В соответствии с рисунком 4.4 разработанная структурная схема БД имеет вид:

Рисунок 4.4 - Структурная схема БД

В базе содержатся следующие таблицы: файлы рабочих программ (WORKINGPROGRAMMSFILES), дисциплины (Subjects), считываемый текст (FORMATTEXTS), файлы шаблонов (TEMPLATEFILES), пользователи (Users).

Рассмотрим более детально структуру каждой таблицы.

В таблице файла рабочих программ содержится следующая информация: идентификатор имени файла - уникальное для каждого файла значение, является первичным ключом данной таблицы, имя файла, файл в виде массивов байтов, который хранится в памяти БД, а также идентификатор дисциплины.

Таблица 4.1 - Структура таблицы файлов рабочих программ

Название поля Тип данных Описание

WORKINGPROGRAMFILEID INT Идентификатор

FILENAME nvarchar(50) Имя файла

Stream varbinary(MAX) Файл в виде массивов байтов

SUBJECTID int Идентификатор дисциплины

Таблица дисциплин таблица 4.2 содержит идентификационный номер дисциплины - уникальное значение, первичный ключ данной таблицы, и название дисциплины.

Таблица 4.2 - Структура таблицы дисциплин

Название поля Тип данных Описание

SUBJECTID INT Идентификатор дисциплины

Name nvarchar(50) Название дисциплины

Таблица считываемого текста таблица 4.3 содержит информацию о тексте, который был считан парсером. Имеет следующие поля: идентификационный номер считанного текста - уникальное значение, первичный ключ данной таблицы, ссылку на дисциплину, название переменной и переменную, которая содержит значение из рабочей программы.

Таблица 4.3 - Структура таблицы считываемого текста

Название поля Тип данных Описание

FORMATTEXTID INT Идентификатор

SUBJECTID INT Ссылка на дисциплину

Name nvarchar(50) Название переменной

Value nvarchar(MAX) Значение из РП

Таблица TEMPLATEFILES таблица 4.4 представляет собой базу, содержащую шаблоны, помещенные туда пользователем ПО. Содержит поля: идентификационный номер шаблона - уникальное значение, первичный ключ данной таблицы, имя шаблона, файл в виде массива байт, ссылка на дисциплину.

Таблица 4.4 - Структура таблицы шаблонов

Название поля Тип данных Описание

TEMPLATEFILEID INT Идентификатор

TEMPLATEFILENAME nvarchar(50) Имя шаблона

Stream varbinary(MAX) Файл в виде массива байт

SUBJECTID INT Ссылка на дисциплину

Таблица Users таблица 4.5 содержит базу пользователей, помещенных туда администратором. Содержит поля: идентификационный номер шаблона - уникальное значение, первичный ключ данной таблицы, имя учетной записи, пароль учетной записи, права администратора.

Таблица 4.5 - Пользователи

Название поля Тип данных Описание

USERID INT Идентификатор

USERNAME nvarchar(MAX) Имя учетной записи

Password nvarchar(MAX) Пароль учетной записи

ADMINACCES bit Права администратора

В настоящем разделе описан процесс разработки, структура и принцип работы программного обеспечения для автоматизации формирования учебных программ: - исходя из требований разрабатываемой системы, разработана структура БД, включающая в себя 4 таблицы. База данных хранит шаблоны и черновики учебных программ и считываемый из текстовых файлов текст;

- разработана MVC структура программного обеспечения;

- разработан алгоритм работы системы;

- разработана схема работы системы.

5. Руководство пользователя программным обеспечением для автоматизации формирования учебных программ

В данном разделе будут описаны и проиллюстрированы окна разработанного графического интерфейса программного обеспечения, а также основные моменты работы системы.

5.1 Авторизация пользователя

При запуске ПО пользователю будет предложено пройти авторизацию. В соответствии с рисунком 5.1 окно авторизации имеет вид:

Рисунок 5.1 -Окно авторизации пользователей

Пользователь должен выбрать из списка его учетную запись и ввести соответствующий ей пароль. При этом если пароль будет введен неверно, на экране появится соответствующее сообщение. Данная ситуация проиллюстрирована на рисунке 5.2:

Рисунок 5.2 -Окно авторизации пользователей

Для удобства введения пароля предусмотрена флаговая кнопка «Показать пароль», при нажатии на которую можно увидеть вводимый пароль. В соответствии с рисунком 5.3 вышеописанная ситуация имеет вид:

Рисунок 5.3 -Отображение вводимого пароля

Если же пользователь ввел корректный пароль, то откроется главное окно программы.

5.2 Разработка интерфейса и иллюстрация работы системы

Работа приложения начинается с главного окна. В соответствии с рисунком 5.4 главное окно имеет вид:

Рисунок 5.4 -Окно при запуске приложения

При входе в программу любой пользователь может использовать ее функционал. Приложение имеет 3 вкладки: парсинг, генерация и администрирование.

Во вкладке «Парсинг» пользователь имеет возможность ввести свой текст или указать путь к существующему файлу для дальнейшего считывания. При нажатии на флажок «Парсинг из файла» появляется возможность указать путь к искомому файлу. Для этого необходимо нажать на кнопку «Document».

В соответствии с рисунком 5.5 выбор файла имеет вид:

Рисунок 5.5 - Выбор файла для считывания

Выбрав файл или введя произвольный текст можно производить считывание текста, нажав на кнопку «Read». В соответствии с рисунком 5.6 процесс считывания программой файла имеет вид:

Рисунок 5.6 - Процесс считывания программой файла

После того, как будет произведен парсинг всего текста, можно добавить считанный текст в шаблон. Для этого необходимо перейти во вкладку «Администрирование» и нажать на кнопку «Загрузить шаблон» и задать имя файлу шаблона. После всех этих действий будет выдано сообщение, что шаблон успешно загружен.

Добавление шаблона в базу данных проиллюстрировано на рисунке 5.7 и имеет вид:

Рисунок 5.7 - Добавление шаблона в базу данных

Также ненужный или неиспользуемый шаблон можно удалить из базы данных. Для этого нужно предварительно выбрать ненужный шаблон и нажать на кнопку «Удалить шаблон». После этого будет выведено соответствующее сообщение (рисунок 5.8). При этом если в базе отсутствует шаблон по выбранной дисциплине, то при попытке удалить шаблон будет выдано сообщение о том, что шаблон для данной дисциплины отсутствует (рисунок 5.9).

Рисунок 5.8 - Удаление шаблона из базы данных

Рисунок 5.9 - Сообщение об отсутствии шаблона для данной дисциплины

Существующий шаблон также можно сохранить на ПК в виде текстового документа с расширением DOCX. Для этого необходимо выбрать один из списка шаблонов и нажать на кнопку «Скачать шаблон». Будет предложено выбрать путь и название сохраняемого файла. Выполнив эти действия, будет выдано сообщение об успешном сохранении шаблона.

Сохранение шаблона из базы данных продемонстрировано на рисунке 5.10:

Рисунок 5.10 - Сохранение шаблона из базы данных

Также во вкладке «Администрирование» пользователь с правами администратора может добавлять учетные записи для других пользователей, а также удалять уже существующие. Для добавления администратору нужно ввести имя новой учетной записи в поле «Имя пользователя», затем ввести дважды одинаковый пароль для этой учетной записи. Далее необходимо нажать на кнопку «Добавить пользователя». Если введенные пароли не будут совпадать, то появится соответствующее сообщение (рисунок 5.11):

Рисунок 5.11 - Сообщение о несовпадающих паролях

При добавлении новой учетной записи, ей можно присвоить права администратора. Для этого необходимо нажать на флаговую кнопку «Права администратора». Если все поля для добавления учетной записи были корректно заполнены, то после нажатия кнопки «Добавить пользователя» появится сообщение об успешном создании данной учетной записи. Добавление новой учетной записи проиллюстрировано на рисунке 5.12:

Рисунок 5.12 - Добавление новой учетной записи

Для удаления существующей учетной записи необходимо в разделе «Удаление пользователей» выбрать из списка нужную учетную запись и нажать на кнопку «Удалить пользователя». В результате на экран будет выведено сообщение об успешном удалении учетной записи. В соответствии с рисунком 5.13 удаление учетной записи имеет вид:

Рисунок 5.13 - Удаление учетной записи

Во вкладке «Генерация» можно сгенерировать новую учебную программу из списка учебных дисциплин. Для этого пользователь должен выбрать из списка нужную ему дисциплину и нажать на кнопку «Сгенерировать программу», затем указать путь к предварительно сохраненному шаблону. После выполнения всех действий будет выдано сообщение об успешной генерации и сохранении файла. В соответствии с рисунком 5.14 генерация новой учебной программы по заданной дисциплине имеет вид:

Рисунок 5.14 - Генерация новой учебной программы

В настоящем разделе были наглядно проиллюстрированы пользовательский интерфейс и основные моменты работы программного обеспечения.

Таким образом, разработано программное обеспечение для автоматизации формирования учебных программ для кафедры ИВТ факультета ИТИКС ОМГТУ. В процессе разработки поставленные на проектирование задачи решены. Цель дипломного проекта была достигнута - разработанное ПО позволяет автоматизировать процесс создания новой учебной программы и сократить тем самым затраченное на этот процесс время.

6. Организационно-экономическая часть

В данном разделе приводится расчет затрат на разработку автоматизированного места сотрудника ОМГТУ. Калькуляция на разработку программного продукта включает следующие статьи: - основная заработная плата разработчика;

- дополнительная заработная плата разработчика;

- расходы на приобретение дополнительных средств ВТ и ПО;

- отчисления на социальные нужды;

- расходы по отладке программы;

- контрагентские расходы;

- накладные расходы.

Процесс программирования необходимо планировать, контролировать и завершать в срок. Кроме того, труд программистов должен оплачиваться по результатам. Для этих целей определяют затраты труда (трудоемкость) на разработку программного продукта. Трудоемкость характеризует время, необходимое одному специалисту или коллективу для создания некоторого программного продукта или выполнения определенного этапа работ.

Для определения трудоемкости разработки, прежде всего, составляется перечень всех стадий, этапов и видов работ (таблица 6.1), которые должны быть выполнены.

Таблица 6.1 - Перечень стадий, этапов и видов работ

Стадии и этапы разработки Вид работ

Техническое задание 1. Постановка задачи; 2. Сбор материалов и анализ существующих разработок; 3. Определение требований к системе

Эскизный проект 4. Анализ программных средств схожей тематики; 5. Разработка схемы БД; 6. Общее описание алгоритма решения задачи;

Технический проект 7. Разработка пояснительной записки. 8. Выбор инструментальных средств; 9. Определение свойств и требований к аппаратному обеспечению; 10. Составление плана мероприятий по внедрению программного продукта.

Рабочий проект 11. Программирование; 12. Тестирование программы; 13. Разработка программной документации.

Внедрение 14. Подготовка и передача программы и программной документации заказчику; 15. Опытная эксплуатация; 16. Анализ данных, полученных в результате эксплуатации; 17. Корректировка технической документации по результатам испытаний.

6.1 Расчет трудоемкости и продолжительности работ

Трудоемкость выполнения работ по созданию программы по сумме трудоемкости этапов и видов работ, оцениваемых экспертным путем в человекоднях, носит вероятностный характер, так как зависит от множества трудно учи

Список литературы
1. Википедия. Model-View-Controller [Электронный ресурс]. - Режим доступа: http://ru.wikipedia.org/wiki/Model-View-Controller. - Загл. с экрана.

2. Википедия. Visual Studio [Электронный ресурс]. - Режим доступа: http://ru.wikipedia.org/wiki/Visual_Studio. - Загл. с экрана.

3. ГОСТ 12.1.038-82 Система стандартов безопасности труда. Электробезопасность. Предельно допустимые значения напряжений прикосновения и токов. Дата введения 1983-07-01 М.: Изд-во стандартов, 1982. - 8 с.

4. ГОСТ 19.701 - 90 ЕСПД. Схемы алгоритмов, программ, данных и систем. - Взамен ГОСТ 19.002.80; введ. 1992.01.01. - М.: Изд-во стандартов, 1990. - 24 с.

5. ГОСТ 7.1 - 2003 Библиографическая запись. Библиографическое описание. Общие требования и правила составления. - Взамен ГОСТ 7.1-84; введ. 2004.07.01. - М.: ИПК Изд-во стандартов, 2004

6. Михайлов, А.А. Расчет затрат на разработку программного продукта: метод. указания по выполнению организационно-экономической части дипломного проекта / А.А. Михайлов, П.В. Рузанов. - Омск: Изд-во ОМГТУ, 2009. - 22 с.

7. Потапов, В.И. Дипломное проектирование: метод. указания для студентов, обучающихся по специальности 230101 и направления подгот. бакалавров 230100 / В.И. Потапов, Б.И. Елькин, О.П. Шафеева. - Омск: Изд-во ОМГТУ, 2007. - 64 с.

8. Программирование. Сравнение MYSQL с другими СУБД [Электронный ресурс]. - Режим доступа: http://program.rin.ru/razdel/html/490.html. - Загл. с экрана.

9. САНПИН 2.2.1/2.1.1.1278-03. Гигиенические требования к естественному, искусственному и совмещенному освещению жилых и общественных зданий: Санитарные правила и нормы. М.: Информ.-изд. центр Минздрава России, 2003. - 29 с.

10. САНПИН 2.2.4.1294-03. Гигиенические требования к аэроионному составу воздуха производственных и общественных помещений. Санитарные правила и нормы. М.: Информ.-изд. центр Минздрава России, 2003. - 5 с.

11. САНПИН 2.2.4.548-96. Гигиенические требования к микроклимату производственных помещений: Санитарные правила и нормы. М.: Информ.-изд. центр Минздрава России, 1997. - 11 с.

12. Tadviser. СЭД (Программные технологии) [Электронный ресурс]. - Режим доступа: http://www.tadviser.ru/index.php/Статья:СЭД_(Программные технологии)

Вы можете ЗАГРУЗИТЬ и ПОВЫСИТЬ уникальность
своей работы


Новые загруженные работы

Дисциплины научных работ





Хотите, перезвоним вам?