不用数据库的多用户文件自由上传投票系统(1)

下面是详细讲解“不用数据库的多用户文件自由上传投票系统(1)”的完整攻略。

系统简介

本系统是一个基于Flask框架开发的多用户投票系统,完全不依赖于数据库,所有数据都以文件的形式存储在本地。用户可以自由上传图片或视频、创建投票项目,其它用户可以对项目进行投票和评论。

系统架构

系统主要分为三个部分:

  • 用户管理模块
  • 文件上传模块
  • 投票模块

技术栈

  • Python 3.7
  • Flask 1.1.2
  • Bootstrap 4.5.0

准备工作

  1. 安装Python和Flask

本系统的开发需要使用Python和Flask框架,请确保你已经安装了Python3.X.x版本,然后使用pip命令安装Flask框架。

pip install Flask
  1. 创建项目结构

使用下面的命令创建项目目录:

mkdir flask-vote && cd flask-vote
mkdir static templates upload
touch app.py

创建的目录结构如下:

.
├── app.py
├── static
├── templates
└── upload
  1. 初始化Flask应用

app.py文件中编写Flask应用初始化代码:

from flask import Flask

app = Flask(__name__)
app.config['UPLOAD_FOLDER'] = 'upload'
app.config['ALLOWED_EXTENSIONS'] = {'png', 'jpg', 'jpeg', 'gif', 'mp4'}

我们需要配置文件上传目录和允许上传的文件类型。

  1. 编写用户管理模块

在Flask应用中编写用户管理模块代码,实现用户注册、登录和注销功能:

from flask import render_template, request, redirect, session

@app.route('/register', methods=['GET', 'POST'])
def register():
    if request.method == 'POST':
        # 处理用户提交的注册请求
        username = request.form['username']
        password = request.form['password']
        confirm = request.form['confirm']
        if password != confirm:
            return '两次输入的密码不一致'
        session[username] = password
        return '注册成功'
    # 显示注册页面
    return render_template('register.html')

@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'POST':
        # 处理用户提交的登录请求
        username = request.form['username']
        password = request.form['password']
        if session.get(username) == password:
            session['username'] = username
            return '登录成功'
        else:
            return '用户名或密码错误'
    # 显示登录页面
    return render_template('login.html')

@app.route('/logout')
def logout():
    session.pop('username', None)
    return redirect('/')

上面的代码实现了用户注册、登录和注销功能,使用Flask的Session来存储用户信息。

  1. 编写文件上传模块

在Flask应用中编写文件上传模块代码,实现文件上传和预览功能:

import os
from flask import send_from_directory, redirect, url_for

def allowed_file(filename):
    return '.' in filename and \
           filename.rsplit('.', 1)[1].lower() in app.config['ALLOWED_EXTENSIONS']

@app.route('/upload', methods=['GET', 'POST'])
def upload():
    if 'username' not in session:
        return redirect(url_for('login'))
    if request.method == 'POST':
        # 处理用户提交的文件上传请求
        file = request.files['file']
        if file and allowed_file(file.filename):
            filename = secure_filename(file.filename)
            file.save(os.path.join(app.config['UPLOAD_FOLDER'], filename))
            return redirect('/')
    # 显示文件上传页面
    return render_template('upload.html')

@app.route('/uploads/<filename>')
def uploaded_file(filename):
    return send_from_directory(app.config['UPLOAD_FOLDER'],
                               filename)

上面的代码实现了文件上传和预览功能。

  1. 编写投票模块

在Flask应用中编写投票模块代码,实现投票和评论功能:

votes = []

@app.route('/', methods=['GET', 'POST'])
def vote():
    if request.method == 'POST':
        # 处理用户提交的投票请求
        vote_id = request.form['vote_id']
        option_id = request.form['option_id']
        for vote in votes:
            if vote['id'] == vote_id:
                for option in vote['options']:
                    if option['id'] == option_id:
                        option['count'] += 1
                        break
                break
        return redirect('/')
    # 显示投票页面
    return render_template('vote.html', votes=votes)

@app.route('/vote/<vote_id>', methods=['GET', 'POST'])
def show_vote(vote_id):
    if request.method == 'POST':
        # 处理用户提交的评论请求
        comment = request.form['comment']
        for vote in votes:
            if vote['id'] == vote_id:
                vote['comments'].append(comment)
                break
        return redirect('/vote/' + vote_id)
    # 显示投票详细页面
    for vote in votes:
        if vote['id'] == vote_id:
            return render_template('vote_detail.html', vote=vote)
    return '投票项目不存在'

def init_votes():
    vote = {
        'id': '1',
        'title': '投票项目 1',
        'description': '这是一个演示用的投票项目',
        'options': [
            {'id': '1', 'title': '选项 1', 'count': 0},
            {'id': '2', 'title': '选项 2', 'count': 0},
            {'id': '3', 'title': '选项 3', 'count': 0},
        ],
        'comments': []
    }
    votes.append(vote)

init_votes()

上面的代码实现了投票和评论功能,投票数据保存在内存中。

示例

下面是两个示例:

示例一

  1. 打开浏览器,进入系统主页(http://localhost:5000)。
  2. 点击“注册”按钮,填写用户名、密码和确认密码,点击“注册”按钮。
  3. 点击“上传”按钮,选择一张图片并上传。
  4. 在主页上,点击“投票”按钮,选择一项进行投票。
  5. 在主页上,点击“查看”按钮,查看投票结果和评论。

示例二

  1. 打开浏览器,进入系统主页(http://localhost:5000)。
  2. 点击“注册”按钮,填写用户名、密码和确认密码,点击“注册”按钮。
  3. 在主页上,点击“上传”按钮,选择一个视频并上传。
  4. 在主页上,点击“投票”按钮,选择一项进行投票。
  5. 在主页上,点击“查看”按钮,查看投票结果和评论。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:不用数据库的多用户文件自由上传投票系统(1) - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • 六种css3实现的边框过渡效果

    下面是详细讲解“六种css3实现的边框过渡效果”的完整攻略。 1. 边框过渡基础 在进行css3实现的边框过渡效果之前,我们首先需要了解边框过渡的基本概念和方法。 边框过渡的基本概念 边框过渡就是通过css3的transition属性来实现边框的渐变过渡效果,使得边框不再突兀地出现或消失,而是能够以柔和的方式出现或消失。 边框过渡的基本方法 利用css3的t…

    css 2023年6月10日
    00
  • CSS3结构性伪类选择器九种写法

    CSS3结构性伪类选择器可以根据元素在结构中的位置进行选择。在本文中,我将详细讲解CSS3结构性伪类选择器九种写法,并提供两个实际的示例来说明其用法。 1. :first-child 该选择器选取父元素的第一个子元素。 示例代码: <ul> <li>第一个</li> <li>第二个</li> &lt…

    css 2023年6月9日
    00
  • CSS实现三栏布局的四种方法示例

    CSS实现三栏布局是Web开发中常见的布局方式之一。以下是四种实现三栏布局的方法示例,包括两个示例说明: 1. 浮动布局 浮动布局是一种常见的实现三栏布局的方法。以下是一个简单的例: <div class="container"> <div class="left">Left Column&lt…

    css 2023年5月18日
    00
  • jQuery实现内容定时切换效果完整实例

    前言 本文章将详细讲解如何利用jQuery实现内容定时切换效果,适合对jQuery有初步认识和了解的读者。 准备工作 在开始之前,我们需要准备一些工具和资源: jQuery库文件; HTML页面。 jQuery库文件可以通过官方网站 (https://jquery.com/) 下载获取,也可以使用CDN来引入该文件。HTML页面可以采用VS Code、Sub…

    css 2023年6月11日
    00
  • 使用CamanJS在Web页面上处理图像的技巧

    如何使用CamanJS在Web页面上处理图像 CamanJS是一款JavaScript图像处理库,可以用来在Web页面上处理图像以及进行滤镜的效果等操作,接下来将详细讲解如何使用CamanJS处理图像的技巧。 步骤一:引入CamanJS库 在HTML文档中,需要先引入CamanJS库,可以使用以下代码: <script src="//cdn.…

    css 2023年6月11日
    00
  • 一些常被你忽略的CSS小知识【必看】

    一些常被你忽略的CSS小知识【必看】 1. calc()函数 calc() 函数可以用来计算一个长度值。该函数支持加、减、乘、除四种操作符,语法如下: width: calc(100% – 20px); 该例中,元素的宽度被设置为父元素宽度减去20像素。 例如,我们可以使用 calc() 函数实现两栏布局,左侧宽度为固定宽度,右侧占满剩余宽度。 .conta…

    css 2023年6月9日
    00
  • div+css纵向导航如何实现且为导航添加超链接

    在网页前端开发中,纵向导航是非常常见的一种导航方式。下面是一个完整的攻略,包含了如何使用 div+css 实现纵向导航以及如何为导航添加超链接的过程和两个示例说明。 使用 div+css 实现纵向导航 1. 创建 HTML 结构 首先,我们需要创建一个 HTML 结构,用于容纳纵向导航。下面是一个简单的 HTML 结构示例: <div class=&q…

    css 2023年5月18日
    00
  • 纯CSS3实现表单验证效果(非常不错)

    请看下面的详细讲解: 纯CSS3实现表单验证效果(非常不错) 介绍 这是一种使用纯CSS3技术实现输入表单的验证效果的方法,无需使用JavaScript。这种方法基于CSS3中的:checked伪类选择器实现,有助于简化代码并提高浏览器性能。这种方法可以用于输入表单的各种类型的验证,例如:是否位数符合要求、是否为空、是否是正确的邮箱格式等。 步骤 Step …

    css 2023年6月10日
    00
合作推广
合作推广
分享本页
返回顶部