> 백엔드 개발 > 파이썬 튜토리얼 > Flask-SocketIO를 사용하여 실시간 통신 애플리케이션을 구현하는 방법

Flask-SocketIO를 사용하여 실시간 통신 애플리케이션을 구현하는 방법

王林
풀어 주다: 2023-08-03 21:57:22
원래의
1493명이 탐색했습니다.

Flask-SocketIO를 사용하여 실시간 통신 애플리케이션을 구현하는 방법

소개:
웹 애플리케이션에서 실시간 통신은 사용자가 실시간으로 정보를 교환하거나 서버에서 푸시한 데이터를 받을 수 있는 매우 중요한 기능입니다. 실시간. Flask-SocketIO는 Flask 프레임워크 기반 플러그인으로, WebSocket을 사용하여 실시간 통신을 달성할 수 있는 기능을 제공합니다. 이 기사에서는 Flask-SocketIO를 사용하여 간단한 실시간 통신 애플리케이션을 구현하는 방법을 소개합니다.

준비:
먼저 Flask-SocketIO 플러그인을 설치해야 합니다. 다음 명령을 통해 설치할 수 있습니다:

1

pip install flask-socketio

로그인 후 복사

또한 프런트 엔드에서 실시간 통신을 위해 Socket.IO JavaScript 라이브러리도 설치해야 합니다. 다음 명령으로 설치할 수 있습니다:

1

npm install socket.io-client

로그인 후 복사

이러한 준비가 완료되면 코드 작성을 시작할 수 있습니다.

코드 예:
다음은 간단한 Flask-SocketIO 실시간 통신 애플리케이션 코드 예입니다.

  1. 필요한 라이브러리 및 모듈 소개

    1

    2

    from flask import Flask, render_template

    from flask_socketio import SocketIO, emit

    로그인 후 복사
  2. Flask 애플리케이션 생성 및 구성

    1

    2

    3

    app = Flask(__name__)

    app.config['SECRET_KEY'] = 'secret!'

    socketio = SocketIO(app)

    로그인 후 복사
  3. 라우팅 정의 및 이벤트 처리 기능

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    @app.route('/')

    def index():

     return render_template('index.html')

     

    @socketio.on('message')

    def handle_message(message):

     print('received message: ' + message)

     emit('response', {'data': 'Server response'})

     

    @socketio.on('connect')

    def handle_connect():

     print('client connected')

     

    @socketio.on('disconnect')

    def handle_disconnect():

     print('client disconnected')

    로그인 후 복사
  4. 프런트 엔드 HTML 파일 생성
    프로젝트 루트 디렉터리에 index.html이라는 파일을 생성하고 다음 코드를 추가합니다.

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    <!DOCTYPE html>

    <html>

    <head>

     <title>Real-time Communication</title>

     <script src="//code.jquery.com/jquery-3.5.1.min.js"></script>

     <script src="//cdnjs.cloudflare.com/ajax/libs/socket.io/2.3.1/socket.io.js"></script>

    </head>

    <body>

     <h1>Real-time Communication</h1>

     <input id="message-input" type="text" placeholder="Enter message">

     <button id="send-button">Send</button>

     <div id="response-div"></div>

     

     <script type="text/javascript">

         var socket = io.connect();

     

         $('#send-button').click(function() {

             var message = $('#message-input').val();

             socket.emit('message', message);

         });

     

         socket.on('response', function(data) {

             $('#response-div').text(data.data);

         });

     </script>

    </body>

    </html>

    로그인 후 복사
  5. 애플리케이션 시작
    애플리케이션의 애플리케이션 시작을 위한 항목 파일 :

    1

    2

    if __name__ == '__main__':

     socketio.run(app, debug=True)

    로그인 후 복사

    어플리케이션을 실행한 후 브라우저에서 http://localhost:5000에 접속하면 간단한 실시간 통신 애플리케이션 인터페이스를 볼 수 있습니다. 메시지 입력 상자에 메시지를 입력하고 보내기 버튼을 클릭하면 실시간으로 메시지를 보내고 받는 기능을 실현할 수 있습니다.

    요약:
    이 글에서는 Flask-SocketIO를 사용하여 실시간 통신 애플리케이션을 구현하는 방법을 소개합니다. Flask-SocketIO 플러그인을 통해 서버와 클라이언트 간의 실시간 메시지 전송을 실현하는 실시간 통신 애플리케이션을 쉽고 빠르게 구축할 수 있습니다. 이 기사가 Flask-SocketIO를 사용하여 실시간 통신 애플리케이션을 구현하는 방법을 이해하는 데 도움이 되기를 바랍니다.

    위 내용은 Flask-SocketIO를 사용하여 실시간 통신 애플리케이션을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿