>데이터 베이스 >MySQL 튜토리얼 >MySQL과 Python을 사용하여 간단한 온라인 불만 제안 시스템을 개발하는 방법

MySQL과 Python을 사용하여 간단한 온라인 불만 제안 시스템을 개발하는 방법

WBOY
WBOY원래의
2023-09-21 08:01:571402검색

MySQL과 Python을 사용하여 간단한 온라인 불만 제안 시스템을 개발하는 방법

MySQL 및 Python을 사용하여 간단한 온라인 불만 사항 및 제안 시스템을 개발하는 방법

소개:
인터넷이 발전하면서 점점 더 많은 사람들이 불만 사항 및 제안을 온라인으로 제출하기 시작했습니다. 사용자 요구를 더 잘 이해하고 서비스 기회를 개선하는 기관입니다. 이 기사에서는 MySQL과 Python을 사용하여 간단한 온라인 불만 제안 시스템을 개발하는 방법을 소개하고 해당 코드 예제를 제공합니다.

1. 시스템 요구 사항 분석
개발을 시작하기 전에 시스템 요구 사항을 명확히 해야 합니다. 간단한 온라인 민원 및 제안 시스템은 다음과 같은 기능을 갖추어야 합니다.

  • 사용자 등록 및 로그인
  • 민원 및 제안 접수 및 관리
  • 불만 및 제안 조회 및 회신
  • 시스템 관리 기능

2.
MySQL에서 "complaint_system"이라는 데이터베이스를 만들고 다음 테이블을 만듭니다.

  • users 테이블: 사용자 ID, 사용자 이름, 비밀번호 및 기타 필드를 포함한 사용자 정보를 저장하는 데 사용됩니다.

    CREATE TABLE users (
      id INT PRIMARY KEY AUTO_INCREMENT,
      username VARCHAR(50) NOT NULL,
      password VARCHAR(50) NOT NULL
    );
  • 불만사항 테이블: 불만사항 ID, 불만사항 내용, 제출 시간, 처리 상태 및 기타 필드를 포함한 불만사항 제안 정보를 저장하는 데 사용됩니다.

    CREATE TABLE complaints (
      id INT PRIMARY KEY AUTO_INCREMENT,
      user_id INT,
      content TEXT NOT NULL,
      submit_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
      status VARCHAR(50)
    );
  • replies 테이블: 답장 ID, 답장 내용, 답장 시간 및 기타 필드를 포함한 답장 정보를 저장하는 데 사용됩니다.

    CREATE TABLE replies (
      id INT PRIMARY KEY AUTO_INCREMENT,
      complaint_id INT,
      content TEXT NOT NULL,
      reply_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
    );

3. 백엔드 개발
저희는 Python의 Flask 프레임워크를 사용하여 백엔드 인터페이스를 개발합니다. 먼저 Flask 및 MySQL 연결 라이브러리를 설치합니다.

pip install flask
pip install flask-mysql

그런 다음 "app.py"라는 Python 파일을 백엔드 항목 파일로 작성합니다. 해당 라이브러리를 파일에 삽입하고 데이터베이스 연결을 구성합니다:

from flask import Flask, request, jsonify
from flask_mysqldb import MySQL

app = Flask(__name__)

app.config['MYSQL_HOST'] = 'localhost'
app.config['MYSQL_USER'] = 'root'
app.config['MYSQL_PASSWORD'] = 'password'
app.config['MYSQL_DB'] = 'complaint_system'

mysql = MySQL(app)

다음으로 라우팅 및 해당 처리 기능을 정의하여 시스템의 다양한 기능을 구현합니다.

  • 사용자 등록 및 로그인:

    @app.route('/register', methods=['POST'])
    def register():
      username = request.form['username']
      password = request.form['password']
    
      cur = mysql.connection.cursor()
      cur.execute("INSERT INTO users (username, password) VALUES (%s, %s)", (username, password))
      mysql.connection.commit()
      cur.close()
    
      return jsonify({'message': 'Registration success'})
    
    @app.route('/login', methods=['POST'])
    def login():
      username = request.form['username']
      password = request.form['password']
    
      cur = mysql.connection.cursor()
      cur.execute("SELECT * FROM users WHERE username = %s AND password = %s", (username, password))
      user = cur.fetchone()
      cur.close()
    
      if user:
          return jsonify({'message': 'Login success'})
      else:
          return jsonify({'message': 'Invalid username or password'})
  • 불만 사항 제출 및 제안 및 관리:

    @app.route('/complaints', methods=['POST'])
    def submit_complaint():
      user_id = request.form['user_id']
      content = request.form['content']
    
      cur = mysql.connection.cursor()
      cur.execute("INSERT INTO complaints (user_id, content, status) VALUES (%s, %s, %s)", (user_id, content, 'Pending'))
      mysql.connection.commit()
      cur.close()
    
      return jsonify({'message': 'Complaint submitted'})
    
    @app.route('/complaints/<complaint_id>', methods=['PUT'])
    def update_complaint(complaint_id):
      status = request.form['status']
    
      cur = mysql.connection.cursor()
      cur.execute("UPDATE complaints SET status = %s WHERE id = %s", (status, complaint_id))
      mysql.connection.commit()
      cur.close()
    
      return jsonify({'message': 'Complaint updated'})
  • 불만 및 제안 문의 및 답변:

    @app.route('/complaints', methods=['GET'])
    def get_complaints():
      cur = mysql.connection.cursor()
      cur.execute("SELECT * FROM complaints")
      complaints = cur.fetchall()
      cur.close()
    
      return jsonify({'complaints': complaints})
    
    @app.route('/complaints/<complaint_id>/reply', methods=['POST'])
    def reply_complaint(complaint_id):
      content = request.form['content']
    
      cur = mysql.connection.cursor()
      cur.execute("INSERT INTO replies (complaint_id, content) VALUES (%s, %s)", (complaint_id, content))
      mysql.connection.commit()
      cur.close()
    
      return jsonify({'message': 'Reply submitted'})
  • 시스템 관리 기능:
    (생략, 실제 필요에 따라 해당 라우팅 및 처리 기능 개발)

마지막으로 Flask 애플리케이션 실행:

if __name__ == '__main__':
    app.run()

4. 프론트엔드 개발
프론트엔드 인터페이스 개발은 HTML, CSS, JavaScript 등의 프론트엔드 기술을 이용하여 진행할 수 있습니다. 여기서는 단순화를 위해 Bootstrap을 프런트 엔드 프레임워크로 사용하고 AJAX 요청 및 동적 디스플레이에는 jQuery를 사용합니다. 다음은 간단한 프런트 엔드 예입니다.

<!DOCTYPE html>
<html>
<head>
    <title>Complaint System</title>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
    <div class="container">
        <h1>Complaint System</h1>
        <form id="register_form">
            <h2>Register</h2>
            <div class="form-group">
                <input type="text" class="form-control" name="username" placeholder="Username">
            </div>
            <div class="form-group">
                <input type="password" class="form-control" name="password" placeholder="Password">
            </div>
            <button type="submit" class="btn btn-primary">Register</button>
        </form>

        <form id="login_form">
            <h2>Login</h2>
            <div class="form-group">
                <input type="text" class="form-control" name="username" placeholder="Username">
            </div>
            <div class="form-group">
                <input type="password" class="form-control" name="password" placeholder="Password">
            </div>
            <button type="submit" class="btn btn-primary">Login</button>
        </form>

        <!-- 其他功能界面 -->

    </div>

    <script>
        // 注册事件
        $("#register_form").submit(function(event) {
            event.preventDefault();

            var url = "/register";
            var data = $(this).serialize();

            $.post(url, data, function(response) {
                alert(response.message);
            });
        });

        // 登录事件
        $("#login_form").submit(function(event) {
            event.preventDefault();

            var url = "/login";
            var data = $(this).serialize();

            $.post(url, data, function(response) {
                alert(response.message);
            });
        });

        // 其他事件....

    </script>
</body>
</html>

이제 브라우저에서 HTML 파일을 열어 시스템 기능을 테스트할 수 있습니다.

결론:
이 기사에서는 MySQL과 Python을 사용하여 간단한 온라인 불만 제안 시스템을 개발하는 방법을 소개합니다. 데이터베이스 설계 및 백엔드 인터페이스 개발을 통해 사용자 등록 및 로그인, 불만 및 제안 제출 및 관리, 불만 및 제안에 대한 질의 및 회신, 시스템 관리 등의 기능이 구현됩니다. 프런트엔드는 인터페이스 개발 및 이벤트 처리를 위해 Bootstrap 및 jQuery를 사용합니다. 이 시스템을 통해 기업과 기관은 사용자 피드백을 더 잘 수집하고 서비스 품질을 향상시킬 수 있습니다.

위 내용은 MySQL과 Python을 사용하여 간단한 온라인 불만 제안 시스템을 개발하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.