и как их отдавать. Реализовал аватар юзера, он хранится в папке со статикой, а в бд только уникальное имя этой картинки, по запросу бд отдает имя, далее уже с клиента делаю запрос по этому имени и получаю картинку. Вопрос в том (первый раз это делаю) не лучше ли хранить в бд саму картинку и по запросу сразу отдавать ее?
Вон там рядом с тем
на s3-подобных сервисах правильно хранить. А в бд просто пути до него. Ну само собой baseurl не в БД, а в конфиге
нет, не лучше, всё правильно делаешь
А можно пояснение почему?
Почему в бд нельзя хранить бинарщину?
храни ссылку на файл, images/fileName.png
ну а нафига? Бэкапить бинарщину отдельно удобнее, переносить.
Пет проект? Если да, то норм, если нет то не норм, как сделать норм зависит от сценариев, самое простое в s3 сторейдже хранить картинку, в отдельной табличке хэш и мета инфу аля название, миме итд
Пет проект, но хотелось бы знать почему тут я делаю так, чтобы в уже более серьезных проектах понимать какой подход лучше использовать
ещё такой момент - если применять для хранения статики какой-нибудь CDN или S3-хранилище, то там возможна такая штука, как кэш статики - чего с хранением картинок в БД тебе выйдет ооочень дорого
Я бы тогда чуть чуть поправил логику, имя хранить в базе, вместо него юзать sha1 хэш, так не будет дублей изображений. Точно не хранить в базе картинки(если точно не понимаешь зачем и что это дает), почему лучше у гугла спросить, будет полезно
Я и не говорю, что это норм
Если проект небольшой, можете хоть в base64 хранить
Обсуждают сегодня