728x90
반응형

분류 전체보기 206

API Project : (1) 영화 추천 API 개발 (DB 데이터 json으로 가져오기)

(DB 데이터 json으로 가져오기) > # 기본 설정은 이전 Project와 동일!- 크게 다른점이, 이전 API 들과는 다르게 추천시스템을 이용하게 이전에 DB에서 작업한 테이블을 Colab에 불러와서 데이터 가공을 먼저 진행해 주어야 한다. # DB를 json 파일로 저장하고 가져오는 방법- 영화 추천을 위해 movie와 review 테이블의 데이터가 필요- 원하는 테이블을 우측 클릭 후 Table Data Export Wizard 선택 후, json 형식으로 경로 설정하여 저장 # 저장된 데이터를 구글드라이브에 올려서 코랩으로 실행하거나 코랩 폴더에 옮겨서 작업ㄴ 데이터 가공후 확인이 필요하기 때문에, MySQL에서 하던 작업을 Colab에서 진행한다고 보면됨ㄴ 물론 Pandas, Numpy 기능..

API Project : 메모앱 API 서버 개발

※ 지금 까지 작성한 모든 개념을 적용해서 API 개발 프로젝트 진행 1) 화면 기획 2) MySQL Workbench를 실행시켜서 데이터에 맞게 DB와 Table 생성 및 전용 DB 커넥터 생성 3) Github에 레파지토리를 만들고, Window CMD에서 serverless로 API 폴더를 생성해서 Git 연동- Git 연동할때 .gitignore 에 node_modules/ 넣어주어야함- 왠만하면 이전에 잘실행된 파일꺼를 복사해서 사용하는게 좋음 4) Postman을 실행시켜서 API 기획 및 리퀘스트 생성 5) 기획한 API대로 Visual Studio Code에서 코드 작성- app.py 파일과 API 경로에 맞게 오고가며 코드 작성 작업 진행 1. app.py 파일 from flask imp..

API Project : 레시피 생성 API 개발

# 레시피를 생성하는 API 개발을 위해 우선 필요한 데이터를 MySQL Workbench를 이용하여 DB 및 테이블을 생성하고 recipe_db 전용 커넥터 생성- 개발 코드중 쿼리문 작성은 모두 MySQL에서 테스트를 먼저 진행하고 사용  # CMD로 serverless 실행하여 배포 폴더 생성하고 Github 연동 # Postman을 실행하여 API 설계 및 리퀘스트 생성 # Serverless로 생성한 폴더를 Visual Studio Code로 실행하여 설계한 API맞게 개발 시작- API 개발은 resources 폴더를 생성하여 그안에 파일로 작성- 보안관리와 비밀번호용 config.py와 utils.py 파일 생성- API 연결코드 작성은 app.py DB 커넥터는 mysql_connectio..

API Project : 전체 개발 과정 정리

# 본격적인 Project 진행 전에 전체 개발과정을 한번 정리!1) API 서버 개발을 위해, 파이썬 환경 설정- 먼저 파이썬 3.10 으로 가상환경 생성 (아나콘다 프롬포트)conda creat -n lambda_app python=3.10 - pip을 이용해서 필요한 라이브러리 설치 (flask 용)pip install flask flask-restful mysql-connector-python psycopg2-binary passlib flask-jwt-extended email-validator flask-uploads uuid numpy pandas scikit-learn==0.23.2 2) AWS에 배포하기 위한, Serverless framwork 설치- npm 설치(https://node..

Restful API : 로그아웃 API

# 이번엔 자동 로그아웃이 아니라 직접 로그아웃 하는 API를 개발- Postman 에서 우선 API 설계- DELETE로 선택하고 Headers에 Key는 Authorization, VALUE는 로그인하고 생성된 토큰을 Bearer 뒤에 입력해 주어야 한다! # 이제 user.py 에 로그아웃 코드 작성 # 로그아웃 API => 다른 user API들에비해 복잡도가 있다!# 로그아웃된 토큰을 저장할, set을 만든다.jwt_blacklist = set()class UserLogoutResource(Resource) :    @jwt_required()    def delete(self) :        # 메뉴얼대로 작성하는것!        jti = get_jwt()['jti']        jwt_..

AWS Lambda : (8) API 게이트웨이 & CloudWatch (배포&오류 확인)

# 배포가 완료되면 AWS의 Lambda를 들어가보면 배포된 서버가 등록된것 확인가능- 지역을 꼭 알맞게 설정해줘야함 # 배포된 서버 url을 확인하고 싶다면, Git Actions에서 앤드포인트를 로그로 직접 확인해도 되고, Lambda에서 배포된 API 게이트웨이를 확인해서 볼수도 있다.  # 중간에 오류가 발생하였을때는 CloudWatch를 활용해서 볼수 있다.- 참고 : https://sorktjrrb.tistory.com/150 # 혹시 로컬 환경이 아니라 서버 환경에서 에러가 났는지를 확인하고 싶을때는 AWS에 CloudWatch를 이용하면 된다.- AWS > CloudWatch > 로그 > " data-og-host="sorktjrrb.tistory.com" data-og-source-url..

Restful API : JWT 토큰 유효기간 만료 시키는 방법 (timedelta)

# 지금까지 회원 가입/로그인, 발급된 토큰을 활용한 API를 개발- 그렇다면, 발급된 토큰에 유효기간을 지정해서 특정한 시간이 지나면 사용하지 못하도록 설정해보자.- 주로, 은행앱이나 관공서앱같이 보안을 위해 일정시간이 지나면 자동으로 로그아웃이 되도록 할때 사용- 이전에 만들었던 회원가입, 로그인 API에 활용 (참고 : https://sorktjrrb.tistory.com/158) Restful API : 회원가입/로그인 API 에서, 토큰(JWT) 생성해서 처리하는 방법# 이전 장에서 환경세팅은 모두 완료하였고, 이제 진짜 회원관리 API 개발을 해보자- postman에서 우선 API 설계 및 리퀘스트 생성- POST로 선택하고, 경로와 Body문 작성 # 이제 Visual Studio Code를..

728x90
반응형