|  | 
|  | 1 | +package AirportSimulator.Servlet.UserRegForm; | 
|  | 2 | + | 
|  | 3 | +/* http://localhost:8080/registration | 
|  | 4 | + | 
|  | 5 | +Логика нашего приложения была описана в первой части, | 
|  | 6 | +см. DOC/MVC_Chart_with_comment.jpeg, три глобальных | 
|  | 7 | +уровня связанных логически, и четыре технологических | 
|  | 8 | +уровня (общающиеся между собой реализуя принципы MVC): | 
|  | 9 | +- HTML/JSP - страницы (View) общается с сервлетами; | 
|  | 10 | +- Servlets - страницы (Controller) общается с уровнем сервисов; | 
|  | 11 | +- Services - java классы (Model) приемо-передатчики между уровнем | 
|  | 12 | + DAO и Servlet, а фактически между Model и Controller; | 
|  | 13 | +- DAO - java классы (Model)позволяющие максимально просто | 
|  | 14 | + пользователю общаться с базой данных (реализуют CRUD принципы); | 
|  | 15 | + | 
|  | 16 | +Для работы с пользователями создадим в базе данных | 
|  | 17 | +таблицу пользователей: см. create_users_table.sql | 
|  | 18 | + | 
|  | 19 | +*/ | 
|  | 20 | + | 
|  | 21 | +import AirportSimulator.DTO.CreateUserDto; | 
|  | 22 | +import AirportSimulator.Entity.EntityEnum.Gender; | 
|  | 23 | +import AirportSimulator.Entity.EntityEnum.Role; | 
|  | 24 | +import AirportSimulator.Exception.ValidationException; | 
|  | 25 | +import AirportSimulator.Service.UserService; | 
|  | 26 | +import PartThree.UtilHelper.JspPathHelper; | 
|  | 27 | +import jakarta.servlet.ServletException; | 
|  | 28 | +import jakarta.servlet.annotation.WebServlet; | 
|  | 29 | +import jakarta.servlet.http.HttpServlet; | 
|  | 30 | +import jakarta.servlet.http.HttpServletRequest; | 
|  | 31 | +import jakarta.servlet.http.HttpServletResponse; | 
|  | 32 | + | 
|  | 33 | +import java.io.IOException; | 
|  | 34 | + | 
|  | 35 | +@WebServlet("/registration") | 
|  | 36 | +public class UserRegForm extends HttpServlet { | 
|  | 37 | + | 
|  | 38 | + private UserService userService = UserService.getInstance(); | 
|  | 39 | + /* | 
|  | 40 | + На doGet возвращаем *.jsp страничку на которой мы | 
|  | 41 | + введем данные нашего пользователя и передадим эти | 
|  | 42 | + сведения в базу данных через POST запрос | 
|  | 43 | + */ | 
|  | 44 | + @Override | 
|  | 45 | + protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws | 
|  | 46 | + ServletException, IOException { | 
|  | 47 | + req.setAttribute("roles", Role.values()); // Role.values() подобен List.of("USER","ADMIN") | 
|  | 48 | + req.setAttribute("genders", Gender.values()); // Gender.values() подобен List.of("MALE","FEMALE") | 
|  | 49 | + | 
|  | 50 | + req.getRequestDispatcher(JspPathHelper.getJspPath("jstl_reg_form")).forward(req,resp); | 
|  | 51 | + } | 
|  | 52 | + /* На doPost возвращаем запрос */ | 
|  | 53 | + @Override | 
|  | 54 | + protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws | 
|  | 55 | + ServletException, IOException { | 
|  | 56 | + /* | 
|  | 57 | + Извлекаем все необходимые параметры из нашей | 
|  | 58 | + формы регистрации (уровень view), чтобы передать | 
|  | 59 | + на уровень сервисов (уровень controller) | 
|  | 60 | + */ | 
|  | 61 | + CreateUserDto userDto = CreateUserDto.builder(). | 
|  | 62 | + name(req.getParameter("name")). | 
|  | 63 | + birthday(req.getParameter("birthday")). | 
|  | 64 | + email(req.getParameter("email")). | 
|  | 65 | + password(req.getParameter("password")). | 
|  | 66 | + role(req.getParameter("role")). | 
|  | 67 | + gender(req.getParameter("gender")). | 
|  | 68 | + build(); | 
|  | 69 | + | 
|  | 70 | + try { | 
|  | 71 | + /* | 
|  | 72 | + Создаем пользователя на уровне Service и | 
|  | 73 | + перенаправляем запрос на сервлет login | 
|  | 74 | + */ | 
|  | 75 | + userService.create(userDto); | 
|  | 76 | + resp.sendRedirect("/login"); | 
|  | 77 | + } catch (ValidationException exception) { | 
|  | 78 | + req.setAttribute("errors", exception.getApp_errors()); | 
|  | 79 | + doGet(req, resp); | 
|  | 80 | + } | 
|  | 81 | + } | 
|  | 82 | +} | 
0 commit comments