GithubHelp home page GithubHelp logo

lab7's Introduction

Доработать программу из лабораторной работы №6 следующим образом:

  1. Организовать хранение коллекции в реляционной СУБД (PostgresQL). Убрать хранение коллекции в файле.
  2. Для генерации поля id использовать средства базы данных (sequence).
  3. Обновлять состояние коллекции в памяти только при успешном добавлении объекта в БД.
  4. Все команды получения данных должны работать с коллекцией в памяти, а не в БД.
  5. Организовать возможность регистрации и авторизации пользователей. У пользователя есть возможность указать пароль.
  6. Пароли при хранении хэшировать алгоритмом SHA-512.
  7. Запретить выполнение команд не авторизованным пользователям.
  8. При хранении объектов сохранять информацию о пользователе, который создал этот объект.
  9. Пользователи должны иметь возможность просмотра всех объектов коллекции, но модифицировать могут только принадлежащие им.
  10. Для идентификации пользователя отправлять логин и пароль с каждым запросом.

Необходимо реализовать многопоточную обработку запросов:

  • Для многопоточного чтения запросов использовать создание нового потока (java.lang.Thread).
  • Для многопотчной обработки полученного запроса использовать ForkJoinPool.
  • Для многопоточной отправки ответа использовать Fixed thread pool.
  • Для синхронизации доступа к коллекции использовать потокобезопасные аналоги коллекции из java.util.concurrent.

Порядок выполнения работы:

  • В качестве базы данных использовать PostgreSQL.
  • Для подключения к БД на кафедральном сервере использовать хост pg, имя базы данных - studs, имя пользователя/пароль совпадают с таковыми для подключения к серверу.

lab7's People

Contributors

dmittrey avatar

Watchers

 avatar

lab7's Issues

Проверять логин и пароль перед каждой командой

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

S - Single responsibility

Нужно внимательно следить за ответственностью каждого класса.

DBWorker не должен формировать какие-то сообщения для клиента (об ошибке, например) - он должен просто отдавать какой-то объект с результатом исполнения команды и статусом/бросать исключение.

Сервер не должен форматировать сообщения (добавлять цвета и пр.) - это задача клиента.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.