Skip to content

Dcom-KHU/refrigerator-api-server

Repository files navigation

header

'냉장고를 부탁해' 프로젝트의 백엔드 서버에 사용되는 레포지토리입니다.

👉 연계 Frontend Repo

https://github.com/Dcom-KHU/refrigerator-front

👉 사용된 API 확인하기 (서버 구동 후 확인 가능)

http://localhost:8080/swagger-ui.html


프로젝트 소개

'냉장고를 부탁해'는 자신의 냉장고 속 재료의 관리와 가지고 있는 재료에 맞는 음식 레시피 추천 서비스입니다.

개발 동기 및 개발 목적

냉장고에 있는 식재료로만으로 음식을 하면서 장보기 비용을 최소화하는 '냉장고 파먹기'가 유행중입니다.

또한 냉장고 속에 재료들을 잊고 있다가 유통기한이 지나 버리게 되어 환경 오염이 되는 경우가 많습니다.

'냉장고를 부탁해'는 이러한 사회 현상에 맞게, 자신의 냉장고 속 음식 재료들을 한번에 관리하고, 냉장고 속 재료들로 만들 수 있는 레시피를 추천함으로써 환경 오염을 줄이고 경제적인 낭비를 줄이고자 서비스를 개발하게 되었습니다.

개발 환경 및 사용 기술

  • FrontEnd : Next.js, TypeScript, Styled-Component
  • BackEnd : Spring Boot, MySQL, Elastic Search, Kibana, Docker, EC2
  • 공통 : Git, Postman
  • 협업툴 : Notion, GitHub

페이지별 기능

메인 페이지

로그인을 하지 않은 경우는 랜덤으로 오늘의 추천 음식이 나오며,

로그인을 한 경우에는 사용자의 가진 재료로 만들 수 있는 음식 중 랜덤으로 오늘의 추천 음식이 나옵니다.

오늘의 추천 음식은 매일 자정에 갱신 됩니다.

음식 종류(한식, 중식, 양식, 일식)에 따라 레시피를 조회가 가능하며, 검색을 통해서도 레시피 조회가 가능합니다.

우측 하단의 레시피 등록 버튼을 통해 레시피 등록이 가능합니다.

레시피 등록 페이지

로그인 상태에서만 가능하며,

음식 이름, 음식 설명, 음식 종류, 음식 사진,

재료 이름, 재료 양, 재료 사진,

조리 방법을 등록할 수 있습니다.

같은 음식이라도 사람들의 레시피가 다를 수 있으므로 음식 이름이 중복되어도 등록 될 수 있게끔 하였습니다.

로그인 페이지

아이디와 비밀번호를 입력받는 일반 로그인과, 네이버, 카카오를 통한 소셜 로그인을 지원합니다.

회원가입 페이지

아이디(이메일), 비밀번호, 이름, 닉네임을 입력 받아 회원가입을 진행합니다.

유저 정보 페이지

로그아웃과 닉네임, 비밀번호 변경이 가능합니다.

나의 냉장고 페이지

자신의 냉장고 속 재료들을 조회, 등록, 수정할 수 있으며,

유통기한 3일 이하의 재료들은 유통기한 임박 탭에서 조회할 수 있습니다.

우측 하단에 '내 재료로 요리하기'를 통해 유저 냉장고 속 재료로 만들 수 있는 음식 레시피들을 조회할 수 있는데,

레시피에 필요한 모든 재료가 있는 경우에만 레시피가 조회됩니다.

기대 효과

  • 효율적인 냉장고 파먹기가 가능해져 불필요한 장보기가 줄 것으로 기대됩니다.
  • 유통기한이 지나 버리게 되는 음식 재료가 줄어 환경오염이 줄 것으로 기대됩니다.

백엔드 개발환경

  • IDE: Intellij IDEA Ultimate

  • OS: Windows 11, Ubuntu 20.04 LTS

  • Language: Java SE 11

  • SDK: Java SE Devlopment Kit 11

  • Application: SpringBoot 2.7.2 (Gradle)

  • Database: MySQL 8.0

  • Infrastructure: Docker 20.10.12

  • AWS EC2 AMI: Ubuntu 20.04.5 LTS

AWS EC2 배포 방법(실행 전)

sudo apt-get update
sudo apt install docker.io

sudo apt install docker-compose

sudo usermod -aG docker ${USER}

sudo reboot
sudo apt install openjdk-11-jdk

nano ~/.bashrc

export JAVA_HOME= $(dirname $(dirname $(readlink -f $(which java))))
export PATH=$PATH:$JAVA_HOME/bin

source ~/.bashrc

실행

git clone https://github.com/Dcom-KHU/refrigerator-api-server.git

cd ./refrigerator-api-server

[Write down {NAVER CLIENT_ID + SECRET} / {KAKAO CLIENT_ID + SECRET} / {JWT SECRET KEY} in /src/main/resources/application-oauth.yml] 

docker-compose up -d

sudo chmod 777 ./gradlew

./gradlew build

java -jar ./build/libs/api-0.0.1-SNAPSHOT.jar

About

API Server For Refrigerator Web Service

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages