不用数据库的多用户文件自由上传投票系统(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日

相关文章

  • vue部署后静态文件加载404的解决

    针对 vue 应用部署后静态文件加载 404 的情况,以下是解决方法的完整攻略。 现象 应用部署后,访问应用的静态文件(如 CSS、JS、图片等)时会出现 404 错误。 原因 原因通常是因为静态资源文件的路径找不到或者没有正确引入。 解决方案 解决该问题,可以采用以下两种方案: 方案一:history 模式 在 Vue Router 中,mode 可以设置…

    css 2023年6月9日
    00
  • Chrome 83稳定版发布 更新内容汇总介绍

    Chrome 83稳定版发布 更新内容汇总介绍 Chrome 83是谷歌最新发布的一个版本,带来了一些新的功能和优化。以下是具体的更新内容。 安全性增强 Chrome 83包含了多项安全性增强功能,其中最重要的是“SameSite”标识符的更新。这将有助于防止一些跨站攻击(CSRF)的发生。更具体地说,Chrome 83会对Cookie的SameSite值进…

    css 2023年6月10日
    00
  • border 边框属性在浏览器中的渲染方式

    border是CSS中一个常用的属性,用于定义元素的边框样式、宽度和颜色。在浏览器中,对于border属性的渲染方式主要包括以下几个方面: 1. 边框样式 border有以下几种常见的样式: solid:实线 dotted:点状线 dashed:虚线 double:双线 groove:3D凹槽线 ridge:3D垄状线 inset:3D凹边线 outset:…

    css 2023年6月9日
    00
  • Asp.net MVC SignalR来做实时Web聊天实例代码

    下面是详细的攻略: Asp.net MVC SignalR来做实时Web聊天实例代码 1. 什么是SignalR SignalR是一个基于ASP.NET的第三方开源库,为web应用程序添加实时Web功能。它使用了Web Sockets协议来保持浏览器和服务端之间的持久连接,同时还兼容其他较老的浏览器(如IE)使用轮询技术来保持连接。SignalR可以将服务器…

    css 2023年6月11日
    00
  • js+css实现的圆角边框TAB选项卡滑动门代码分享(2款)

    本文将为大家介绍如何使用JavaScript和CSS实现圆角边框TAB选项卡滑动门效果,本文将会分享两款实现方案,让大家得以更好的理解和掌握这个知识点。 一、实现方案1 1.1 HTML结构 首先,我们需要如下HTML结构: <div class="tab"> <ul class="tab-list"…

    css 2023年6月10日
    00
  • HTML5之SVG 2D入门6—视窗坐标系与用户坐标系及变换概述

    下面我来详细讲解“HTML5之SVG 2D入门6—视窗坐标系与用户坐标系及变换概述”的完整攻略。 标题 HTML5之SVG 2D入门6—视窗坐标系与用户坐标系及变换概述 正文 SVG是一种可缩放矢量图形格式,支持多种图形元素,通过控制这些图形元素,我们可以实现各种各样的视觉效果。其中,坐标系与变换是SVG中非常重要的概念。在SVG中,坐标系分为视窗坐标系和用…

    css 2023年6月10日
    00
  • javascript实现在指定元素中垂直水平居中

    实现在指定元素中垂直水平居中的方法有很多,这里介绍两种常用的方法。 方法一:使用绝对定位和transform属性 这种方法需要将要居中的元素的父元素设置为相对定位,目标元素使用绝对定位,并使用transform属性进行位置调整。 HTML代码示例: <div class="parent"> <div class=&quo…

    css 2023年6月10日
    00
  • 功能强大的jquery.validate表单验证插件

    下面是“功能强大的jquery.validate表单验证插件”的详细攻略,包含两个示例说明。 什么是jquery.validate表单验证插件 jquery.validate表单验证插件是通过使用jQuery及其插件,帮助开发者轻松地实现Web表单的验证功能的一个强大工具。 使用该插件,可以非常方便地为表单添加各种验证规则、错误提示信息等功能,大大减少了开发…

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