Skip to content

Jossindev/HospitalApp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

43 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

HospitalApp

Лікарня

Адміністратору системи доступний список Лікарів за категоріями (педіатр, травматолог, хірург, ...) і список Пацієнтів. Реалізувати можливість сортування:

  1. пацієнтів:
  • за алфавітом;
  • за датою народження;
  1. лікарів:
  • за алфавітом;
  • за категорією;

Адміністратор реєструє в системі пацієнтів і лікарів і призначає пацієнтові лікаря. Лікар визначає діагноз, робить призначення пацієнту (процедури, ліки, операції), які фіксуються в Лікарняній картці. Призначення може виконати Медсестра (процедури, ліки) або Лікар (будь-яке призначення). Пацієнт може бути виписаний з лікарні, при цьому фіксується остаточний діагноз. (Опціонально: реалізувати можливість збереження / експорта документа з інформацією про виписку пацієнта).

Завдання фінального проекту

Розробити веб-застосунок, що підтримує функціональність відповідно до варіанту завдання.

Вимоги до реалізації

  1. На основі сутностей предметної області створити класи, які їм відповідають.

  2. Класи і методи повинні мати назви, що відображають їх функціональність, і повинні бути рознесені по пакетам.

  3. Оформлення коду має відповідати Java Code Convention.

  4. Інформацію щодо предметної області зберігати у реляційній базі даних (в якості СУБД рекомендується використовувати MySQL або PostgreSQL).

  5. Для доступу до даних використовувати JDBC API із застосуванням готового або ж розробленого самостійно пулу з'єднань.

НЕ допускається використання ORM фреймворків.

  1. Застосунок має підтримувати роботу з кирилицею (бути багатомовним), в тому числі при зберіганні інформації в базі даних:

    • повинна бути можливість перемикання мови інтерфейсу;
    • повинна бути підтримка введення, виведення і зберігання інформації (в базі даних), записаної на різних мовах;
    • в якості мов обрати мінімум дві: одна на основі кирилиці (українська або російська), інша на основі латиниці (англійська).
  2. Архітектура застосунка повинна відповідати шаблону MVC.

НЕ допускається використання MVC-фреймворків.

  1. При реалізації бізнес-логіки необхідно використовувати шаблони проектування: Команда, Стратегія, Фабрика, Будівельник, Сінглтон, Фронт-контролер, Спостерігач, Адаптер та ін.

Використання шаблонів повинно бути обґрунтованим.

  1. Використовуючи сервлети і JSP, реалізувати функціональність, наведену в постановці завдання.

  2. Використовувати Apache Tomcat у якості контейнера сервлетів.

  3. На сторінках JSP застосовувати теги з бібліотеки JSTL та розроблені власні теги (мінімум: один тег custom tag library і один тег tag file).

  4. Реалізувати захист від повторної відправки даних на сервер при оновленні сторінки (реалізувати PRG).

  5. При розробці використовувати сесії, фільтри, слухачі.

  6. У застосунку повинні бути реалізовані аутентифікація і авторизація, розмежування прав доступу користувачів системи до компонентів програми. Шифрування паролів заохочується.

  7. Використовувати Впровадити у проект журнал подій із використанням бібліотеки log4j.

  8. Код повинен містити коментарі документації (всі класи верхнього рівня, нетривіальні методи і конструктори).

  9. Застосунок має бути покритим модульними тестами (мінімальний відсоток покриття 40%). Написання інтеграційних тестів заохочуються.

  10. Реалізувати механізм пагінації сторінок з даними.

  11. Всі поля введення повинні бути із валідацією даних.

  12. Застосунок має коректно реагувати на помилки та виключні ситуації різного роду (кінцевий користувач не повинен бачити stack trace на стороні клієнта).

  13. Самостійне розширення постановки задачі по функціональності заохочується (додавання капчі, формування звітів у різних форматах, тощо)!

  14. Використання HTML, CSS, JS фреймворків для інтерфейсу користувача (Bootstrap, Materialize, ін.) заохочується!

About

Web application . Use JDBC + JSP + Servlets

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published