Мне нужно написать небольшое приложение Grails (или Java), которое будет обрабатывать аутентификацию (из нашей проприетарной системы единого входа), а затем, после аутентификации, разрешить пользователю загружать файлы. Это очень просто, если я просто включаю файлы в WAR-файл приложения, однако я хотел бы избежать этого, поскольку файлов будет несколько, и я бы предпочел не загружать новый WAR-файл каждый раз, когда мы добавить новый файл. Можно ли добиться этого, если приложение находится в файле WAR, но файлы вне файла WAR, если да, то как мне настроить такую настройку? Мы будем запускать это на Tomcat.
Приложение Grails на Tomcat для защиты файлов паролем
Ответы:
Да, это возможно. Не зная всех ваших требований или того, что вы пробовали и почему это не сработало, лучшее, что я могу сделать, это дать вам общее представление о том, как этого добиться.
Имейте контроллер, который принимает идентификатор файла, который вы хотите, чтобы пользователь загрузил. На основе этого ключа найдите связанный экземпляр домена. Домен должен хранить имя файла файла. Затем используйте это имя файла для разрешения файла из локальной файловой системы (путь, настроенный в конфигурации вашего приложения). Откройте файл и выполните потоковую передачу содержимого в браузер. Обязательно правильно установите заголовки, чтобы указать имя файла и размер.
Здесь задействовано много движущихся частей, но это можно сделать. Теперь, если вы застряли на чем-то, я предлагаю вам опубликовать то, что вы пробовали, и что в этом не работает. В противном случае лучшее, что мы/я можем сделать, это дать вам общее руководство/совет.
Надеюсь это поможет!
Изменить Настоящий ключ будет находиться в контроллере для загрузки файлов. Вот краткий фрагмент того, как это может выглядеть:
String fileName = "something.zip" // should come from your domain instance
String filePathAndName = "/downloads/${fileName}" // should come from your configuration
response.setContentType("application/octet-stream")
response.setHeader("Content-disposition", "attachment;filename=${fileName")
// this will actually buffer/stream the file in 8k chunks instead of reading the entire file into memory.
org.apache.commons.io.IOUtils.copy((new File(filePathAndName)).openStream(), response.outputStream)
response.outputStream.flush()
response.outputStream.close()