[python][web] Separate Front-end from Back-end with Flask+AJAX

Separate Front-end from Back-end with Flask+AJAX

Here I am sharing the information that I’ve just tried out for my work. I needed to integrate a new app that I wrote with Flask to a platform based on Odoo. The problem was it would not be a time efficient way to rewrite the app with Odoo and I have to update my code easily so I need to host it in my own server. So I wrote an API with Flask and I used AJAX in the GUI so they can communicate each other from different servers.

In this article I’ll show you how to use Flask and AJAX together with a very simple example. Lets start with installing modules that we need. I assume that you have Python 3 installed on your machine:

~$ sudo pip3 install flask

And thats it all w need to install is flask! Now let’s create our environment:

~$ mkdir flask-ajax
~$ cd flask-ajax
~/flask-ajax$ nano app.py

That’s it we created our directory and created our Python file or the API. Now we can create a simple API:

from flask import Flask, request, jsonifyapp = Flask(__name__)@app.route('/api/', methods=["POST"])
def main_interface():
    response = request.get_json()
    print(response)
    return jsonify(response)if __name__ == '__main__':
    app.run(debug=True)

Here we are created a simple POST request handler that gets the JSON serialized data as a Python dict and print it and send it back as JSON. But if we want our API to work separately we have to ad some more code… We have to ad response headers into our response like this:

from flask import Flask, request, jsonifyapp = Flask(__name__)@app.route('/api/', methods=["POST"])
def main_interface():
    response = request.get_json()
    print(response)
    return jsonify(response)@app.after_request
def add_headers(response):
    response.headers.add('Access-Control-Allow-Origin', '*')
    response.headers.add('Access-Control-Allow-Headers', 'Content-Type,Authorization')
    return responseif __name__ == '__main__':
    app.run(debug=True)

That’s it our API is ready. Now we can dive into the Front-end:

~/flask-ajax$ nano app.html

We created our HTML file. Now we can create a simple form:

<!DOCTYPE html>
<html>
<body><p>Send a message to the api!</p>
message: <input id="message">
<button id="send">Send</body>
</html>

That will look like this:

Now create our JS file to write our AJAX request:

~/flask-ajax$ touch app.js

Now we can add the AJAX request code but first we need to include jQuery library and link our JS file:

<!DOCTYPE html>
<html><head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
</head><body><p>Send a message to the api!</p>
message: <input id="message">
<button id="send">Send<script src="app.js"></script></body>
</html>

Finally we can start write our AJAX request:

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

$("document").ready(function(){
    $("#send").click(function(){
        var message = $("#message").val();        $.ajax({
            url: "http://localhost:5000/api/",
            type: "POST",
            contentType: "application/json",
            data: JSON.stringify({"message": message})        }).done(function(data) {
            console.log(data);        });    });});

That’s it we finished our app. To try it out run your code and open your HTML file with your favorite browser. If you send a message you can see it printed in your terminal that you run your Python code and you can also see it in your browser’s console.

I know that this is an easy example but I build a working app using this example as my base knowledge. I hope this will help you as well.

Here you can find the code in the tutorial:

Check out my other tutorials:

 

 
 
[출처] https://gokhang1327.medium.com/separate-front-end-from-back-end-with-flask-ajax-a5b22b12d001

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
372 [Python 인공지능] TextRank 를 이용한 키워드 추출과 핵심 문장 추출 (구현과 실험) file 졸리운_곰 2021.11.22 25
371 [python][image processing][파이썬][이미지프로세싱] 파이썬 영상 처리 (OpenCV) file 졸리운_곰 2021.11.12 29
370 [python] Python Console Input & Output Tutorial 졸리운_곰 2021.11.06 20
369 [Python 데이터분석] [pandas] 공공데이터(csv) 활용시 한글 깨짐 현상 해결 file 졸리운_곰 2021.09.30 13
368 [Python 데이터분석] 공공데이터포털::공휴일 데이터 조회 (REST API) file 졸리운_곰 2021.09.30 54
367 [Python 데이터 분석] pandas의 to_csv()를 사용해서 csv 파일로 저장하기(save 하기) 졸리운_곰 2021.09.29 16
366 [Python 데이터 분석] 데이터 과학을 단순하게 만드는 3가지 Python 패키지 file 졸리운_곰 2021.09.24 48
365 [Python][Dash] DASH PLOTLY 설치부터 튜토리얼까지 졸리운_곰 2021.09.11 68
364 python - 국가공휴일 데이터 가져오기 (data.go.kr) file 졸리운_곰 2021.09.05 34
» [python][web] Separate Front-end from Back-end with Flask+AJAX file 졸리운_곰 2021.08.13 11
362 [python][파이썬 조건문(if-elif-else)] 졸리운_곰 2021.07.24 26
361 [python] 파이썬 for 문 졸리운_곰 2021.07.24 19
360 [python][파이썬 기초] 48 파이썬으로 파일 만들기 졸리운_곰 2021.07.24 30
359 [Python] UnicodeEncodeError: 'ascii' codec can't encode file 졸리운_곰 2021.07.24 36
358 [python] *args 와 **kwargs 사용하기 - 슬기로운 파이썬 트릭 中 file 졸리운_곰 2021.07.24 39
357 [python] *args 와 **kwargs 졸리운_곰 2021.07.24 18
356 [python] 파이썬 f-string (파이썬 스트링 앞에 f') file 졸리운_곰 2021.07.17 42
355 [Python] 파이썬으로 복리 계산하기 file 졸리운_곰 2021.07.17 50
354 [python, 파이썬] 연습 문제: 복리 이자 계산 졸리운_곰 2021.07.17 602
353 python - 읽은 후 kafka 메시지를 삭제하는 방법 졸리운_곰 2021.07.13 326
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED