728x90
반응형

API 개발 45

TypeError : Object of type ... is not JSON serializable 에러가 발생한 이유와 해결방법

에러가 발생한 이유와 해결방법 > # 바로 이전 게시글 형식과 이어짐 (https://sorktjrrb.tistory.com/143)# 이전 게시글에서 select 문에대해서 작성중에 해당 오류가 발생되는 경우가 있다.- TypeError : Object of type ... is not JSON serializable # 이유는 파이썬의 JSON 직렬화 불가능한 데이터 형식을 JSON으로 변환하려고 했기 때문- 이전 게시글에선 날짜와 시간을 ISO 형식의 문자열로 변환하여서 해결!- 이를 위해서는 datetime 객체의 isoformat() 메서드를 사용하면 된다.         # 클라이언트에 json 만들어서 응답한다. => 문자와 숫자로만 구성하여 보내야 한다.        ### 중요! DB에서..

Restful API : Python MySQL Connector 셀렉트 하는 방법

1) 전체 레시피 가져오는 API를 만들어 보자 우선, 포스트맨을 실행시켜 GET으로 설정하고, URL 입력!- insert 기능에서 이어서 진행! (참고 : https://sorktjrrb.tistory.com/142)- 겟(GET)과 딜리트(DELETE) 타입은 바디(Body)를 따로 입력하지 않는다!- 전체 데이터를 가지고 올때는 offset과 limit를 설정해서 25개씩만 가져오도록 설정하는게 페이지 구성에 좋기 때문에 이를 설정해서 가져오도록 하자- Params에 offset과 limit라는 키를 생성하고 값은 각각 0, 25로 설정 (URL 에도 추가한 offset 과 limit가 동작되도록 작성해 주어야함 http://127.0.0.1:5000/recipes?offset=0&limit=25..

Restful API : Python MySQL Connector 인서트 하는 방법

# 이제 DB 생성 및 가상환경 생성 그리고 실행에 필요한 프로그램들인 MySQL Workbench, Postman, Visual Studio Code 실행 및 세팅이 완료되었으니, API를 직접 코딩해 보자! # 포스트맨을 실행시켜 POST로 설정하고, URL 입력!- Body에 raw 선택 JSON 형식으로 DB에 추가하고 싶은 정보를 입력해준다. # VSCode에서 API 코드를 작성!- 작업의 용이성(실무적으로)을 위해 각 기능이 동작하는 API 코드를 작성할 파일들은 resource라는 폴더를 따로 생성하여 그안에서 작성 # recipe.py 파일 안에 레시피를 생성(insert) 하는 코드문 작성- query 문을 만들때는 꼭! MySQl Workbench로 실제 해당 문구가 정상 실행되는지를..

Restful API : Python 에서 MySQL 커넥션하는 법 (Config, mysql_connection 파일 만들기)

(Config, mysql_connection 파일 만들기) > # 이전장에서 전용 DB는 모두 생성을 완료하였으니, Python에 연결하여 코드를 작성하여야 한다!# 우선 실무에서도 적용할수 있도록 목적성에 맞게 파일을 나누어서 코드문을 작성하는것이 좋다! 보안 관리를 위한 config.py 파일과 DB 관리를 위한 mysql_connection.py 파일을 생성해 주자!ㄴ config.py 에선 보안관련 정보를 class로 만들어 따로 입력해서 관리 (보안관련 코드들이 추가되면 계속 config.py 파일 안에 새롭게 업로드하면서 관리하는것!)ㄴ mysql_connection.py 에선 config.py 에서 작성한 보안 class중 mysql db에 접속하는 함수를 작성하여 관리 # config.p..

Restful API : Python 에서 MySQL Connector 라이브러리 설치 (전용 DB 유저 생성 포함)

(전용 DB 유저 생성 포함) > # 본격적으로 API를 개발하기 전에 Python 코드 개발 환경과 MySQL DB를 커넥션 하여야 한다.- MySQL Workbench를 실행하여 새로운 파일을 열고 쿼리를 작성!-- recipe_db(작업할 전용 DB) 에만 전용으로 접속할 수 있는 계정을 만들어야 한다.-- use mysql; 로 먼저 실행하면 특정 db를 지정하지 않아도 sql문이 실행됨-- @ 뒤에 '%' 문은 꼭 넣어줘야한다!use mysql;create user 'abcd_db_user(사용할 이름)'@'%' identified by '1234 (사용할 비밀번호)';grant ALL privileges on abcd_db.* to 'abcd_db_user(사용할 이름)'@'%'; # MySQ..

Restful API : Python flask 에서, API 개발을 위해 Resource 클래스를 개발하는코드 (post : body의 json을 받아서 처리하는 방법)

Resource 클래스를 개발하는코드 (post : body의 json을 받아서 처리하는 방법) > # Class란 변수와 함수로 구성된 묶음 으로 상속이 가능한데, API를 만들기 위해서는 flask_restful 라이브러리의 Resource class를 상속해서 만들어야 한다!# recipe.py라는 파일을 생성하여 API를 처리하는 함수 개발(HTTP Method를 보고 동일한 형식으로 만들어준다.) # 우선 코드 작성에 필요한 라이브러리를 importfrom flask import requestfrom flask_restful import Resource # MySQL DB와 연동하기 위한 라이브러리from mysql_connection import get_connectionfrom mysql.c..

Restful API : API 경로와 Resource 클래스를 연결하는 코드

# API를 만들기 위한 클래스를 작성하여야 하는데, 대시보드 앱을 만들던 작업과 동일하게 파일을 구분하여 작성하는게 향후 실무에서 용이하다!# 그렇기 때문에 VScode에 베이스가되는 app.py 파일과 class를 생성할 파일을 구분하여 작업!  # 바로 이전글에서 작성하였던 경로와 리소스를 연결하는 코드에 대해서 정리! # 아래 코드는 app.py에 작성된 코드로, 생성된 클래스와 우리가 불러와서 실행시킬 경로를 연결해주는 코드이다. # 생성한 API class 사용을위해서 생성시마다 import 필요!from resources.recipe import RecipeListResource, RecipePublishResource, RecipeResourceapp = Flask(__name__)api ..

728x90
반응형