Flask+Pycharm(专业版)+mysql编写一个简单登录注册页面

1.首先,看一下项目的存放和数据库中的表

1.1 存放

Flask+Pycharm(专业版)+mysql编写一个简单登录注册页面_第1张图片

1.2 数据库

Flask+Pycharm(专业版)+mysql编写一个简单登录注册页面_第2张图片

博主建立了一个名为cat1的数据库,表名为students

students中的具体内容如下:

Flask+Pycharm(专业版)+mysql编写一个简单登录注册页面_第3张图片

 

 

 2.下面是所有的源代码

model文件夹下的loginc.py文件(其中连接数据库的部分要修改成自己的用户名和密码)

import pymysql

conn=pymysql.connect(host='localhost',user='root',password='12345',db='cat1',charset='utf8')
cur = conn.cursor()
def is_null(username,password):
	if(username==''or password==''):
		return True
	else:
		return False
def close(conn,cur):
	if cur:
		cur.close
	if conn:
		conn.close


def is_existed(username,password):
	sql="SELECT * FROM students WHERE name ='"+username+"' and password ='"+password+"'"
	conn.ping(reconnect=True)
	cur.execute(sql)
	result = cur.fetchall()
	conn.commit()
	if (len(result) == 0):
		return False
	else:
		return True

def exist_user(username):
	sql = "SELECT * FROM students WHERE name ='"+username+"'"
	conn.ping(reconnect=True)
	cur.execute(sql)
	result = cur.fetchall()
	conn.commit()
	if (len(result) == 0):
		return False
	else:
		return True

model文件夹下的regist.py文件(其中连接数据库的部分要修改成自己的用户名和密码)

import pymysql
conn=pymysql.connect(host='localhost',user='root',password='12345',db='cat1',charset='utf8')
cur = conn.cursor()

def add_user(username, password):
    # sql commands
    sql = "INSERT INTO students(name, password) VALUES ('"+username+"','"+password+"')"
    conn.ping(reconnect=True)
    # execute(sql)
    cur.execute(sql)
    # commit
    conn.commit()  # 对数据库内容有改变,需要commit()
    conn.cursor()
    conn.close()

static文件夹下的style.css文件

body{
    background-color: lightcyan;
}
div{
    margin: 0 auto;
    width: 500px;
    height: 300px;
    border: 1px solid skyblue;
    text-align: center;
}

templates文件夹的index.html文件




    
    
    
    学籍系统


    

您好,{{ username }},欢迎来到学籍系统

退出

templates文件夹的login.html文件




    
    
    
    登录


    

学籍系统



{% if message %} {{message}} {% endif %}
注册

templates文件夹的register.html文件




    
    
    
    登录


    

用户登录



{% if message %} {{message}} {% endif %}
注册

app.py文件

from flask import Flask,render_template
from flask import redirect
from flask import url_for
from flask import request
from model.loginc import is_existed,exist_user,is_null
from model.regist import add_user

app = Flask(__name__)

@app.route('/')
def index():
    return redirect(url_for('user_login'))

@app.route('/user_login',methods=['GET','POST'])
def user_login():
    if request.method=='POST':  # 注册发送的请求为POST请求
        username = request.form.get('username')
        password = request.form.get('password')
        if is_null(username,password):
            login_massage = "温馨提示:账号和密码是必填"
            return render_template('login.html', message=login_massage)
        elif is_existed(username, password):
            return render_template('index.html', username=username)
        elif exist_user(username):
            login_massage = "温馨提示:密码错误,请输入正确密码"
            return render_template('login.html', message=login_massage)
        else:
            login_massage = "温馨提示:不存在该用户,请先注册"
            return render_template('login.html', message=login_massage)
    return render_template('login.html')

@app.route("/register",methods=["GET", 'POST'])
def register():
    if request.method == 'POST':
        username = request.form.get('username')
        password = request.form.get('password')
        if is_null(username,password):
            login_massage = "温馨提示:账号和密码是必填"
            return render_template('register.html', message=login_massage)
        elif exist_user(username):
            login_massage = "温馨提示:用户已存在,请直接登录"
            # return redirect(url_for('user_login'))
            return render_template('register.html', message=login_massage)
        else:
            add_user(request.form['username'], request.form['password'] )
            return render_template('index.html', username=username)
    return render_template('register.html')

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


3.顺便给大家看一下我安装的扩展软件包

用以借鉴,可能有初学者不太知道这个项目用了哪些安装包

Flask+Pycharm(专业版)+mysql编写一个简单登录注册页面_第4张图片

4.让我们浏览一下效果吧

Flask+Pycharm(专业版)+mysql编写一个简单登录注册页面_第5张图片

Flask+Pycharm(专业版)+mysql编写一个简单登录注册页面_第6张图片 

 Flask+Pycharm(专业版)+mysql编写一个简单登录注册页面_第7张图片

 

 后记:由于博主本人是为了完成学校作业,有时间限制,所以完成的匆匆忙忙,也主要是借鉴的多,自己只是做了一下将数据库这个板块加进去

借鉴的文章:http://t.csdn.cn/1EuTJ

你可能感兴趣的:(flask,python,后端,mysql)