Ответы пользователя по тегу Spring
  • Как сделать авторизацию в Spring Framework без Spring Security?

    enovoselov
    @enovoselov
    Инженер
    Все правильно. Нужно реализовать интерфейс HttpFilter и добавить его в контекст.

    При аутентификации пользователя добавляете данные в сессию, при запросах, до контроллера, будет вызываться метод в фильтре, получаете параметр сессии из HttpServletRequest и выполняете нужные действия.
    Ответ написан
    Комментировать
  • Почему не отображается картинка Thymeleaf?

    enovoselov
    @enovoselov
    Инженер
    На сколько я понимаю подход, который вы выбрали для загрузки картинки, используется для статических ресурсов, которые могут находятся в другом месте от приложения и вряд ли предоставят гибкости для вашего большого проекта. Лучше воспользоваться данным гайдом https://spring.io/guides/gs/uploading-files/

    Более лучшее решение написать свой контроллер и сервис для обработки запроса на предоставление файлов, это вам предоставит больше гибкости.

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

    Протестировал у себя и ниже предоставляю рабочий вариант

    application.properties который использовал
    file-storage-directory=/home/user_name/storage

    Представление upload.html
    <!DOCTYPE html>
    <html lang="en" xmlns:th="http://www.thymeleaf.org">
    <head>
        <meta charset="UTF-8">
        <title>Upload form</title>
    </head>
    <body>
    <form th:action="@{/upload}" method="post" enctype="multipart/form-data">
        <input type="file" name="image" id="image" accept="image/*">
        <button type="submit">Save</button>
    </form>
    <img th:if="${imageName}" th:src="@{'/images/' + ${imageName}}" alt="Uploaded Image">
    </body>
    </html>


    Контроллер
    @Controller
    public class ImageController {
        private final String fileStorageDirectory;
    
        public ImageController(@Value("${file-storage-directory}") String fileStorageDirectory) {
            this.fileStorageDirectory = fileStorageDirectory;
        }
    
        @GetMapping("/upload")
        public String getUploadForm() {
            return "upload";
        }
    
        @PostMapping("/upload")
        public String processUpload(@RequestParam MultipartFile image, Model model) {
            try {
                Files.write(Path.of(fileStorageDirectory, image.getOriginalFilename()), image.getBytes());
                model.addAttribute("imageName", image.getOriginalFilename());
            } catch (IOException e) {
                throw new RuntimeException(e);
            }
            return "upload";
        }
    }


    Конфигуратор
    @Configuration
    @EnableWebMvc
    public class MvcConfig implements WebMvcConfigurer {
        private final String fileStorageDirectory;
    
        public MvcConfig(@Value("${file-storage-directory}") String fileStorageDirectory) {
            this.fileStorageDirectory = fileStorageDirectory;
        }
    
        @Override
        public void addResourceHandlers(ResourceHandlerRegistry registry) {
            registry
                    .addResourceHandler("/images/**")
                    .addResourceLocations("file:" + fileStorageDirectory + File.separator)
                    .setCachePeriod(3600)
                    .resourceChain(true)
                    .addResolver(new PathResourceResolver());
        }
    }
    Ответ написан
    Комментировать
  • Почему картинка Thymeleaf показывается только после перезапуска Spring-Boot-приложения?

    enovoselov
    @enovoselov
    Инженер
    Сохраняйте в другом месте, не в ресурсах приложения. Это ведь загружаемые и внешние данные, создайте под них папку на сервере например /home/user/app_name/, затем можете через nginx или через запрос на контроллер приложения с помощью сервиса читать картинку и возвращать на клиент
    Ответ написан
    2 комментария
  • Возможно ли в фрагмент thymeleaf "вшить" id текущего пользователя?

    enovoselov
    @enovoselov
    Инженер
    Хранить данные в сессии и передавать данные в модель, через фильтр. Нужно создать класс, который переопределяет метод HttpFilter. В его методе нужно будет добавить атрибут который понадобится в шаблоне.
    Например:
    request.setAttribute("user", user);
    Ответ написан
    2 комментария
  • Как удалить запись при связи many to many с составным ключем?

    enovoselov
    @enovoselov Автор вопроса
    Инженер
    Была проблема в связи из-за свойства
    cascade = CascadeType.ALL
    поменял на
    cascade = CascadeType.REMOVE
    и убрал у сущности листа.
    orphanRemoval = true
    Так же из-за исправлений поправил добавление и редактирование новых элементов
    Ответ написан
    Комментировать
  • Как поменять тип столбца в postgresql через spring boot?

    enovoselov
    @enovoselov
    Инженер
    @Type(type = "text")
    private String log = "";
    Ответ написан
    Комментировать