BBS論壇(一)


1.1.項目結構搭建

(1)創建flask項目Perfect_bbs,然后搭建項目結構如下:

(2)構建藍圖

cms/views.py

# cmd/views.py

from flask import Blueprint

bp = Blueprint("cms",__name__,url_prefix='/cms')

@bp.route('/')
def index():
    return 'cms index'

cms/init.py

from .views import bp

common/views.py

# common/views.py

from flask import Blueprint

bp = Blueprint("common",__name__,url_prefix='/common')

@bp.route('/')
def index():
    return 'common index'

common/init.py

from .views import bp

 front/views.py

# front/views.py

from flask import Blueprint

bp = Blueprint("front",__name__)

@bp.route('/')
def index():
    return 'front index'

front/init.py

from .views import bp

 config.py

DEBUG = True

Perfect_bbs.py

# Perfect_bbs.py

from flask import Flask
from apps.cms import bp as cms_bp
from apps.front import bp as front_bp
from apps.common import bp as common_bp
import config

app = Flask(__name__)
app.config.from_object(config)

#注冊藍圖
app.register_blueprint(cms_bp)
app.register_blueprint(front_bp)
app.register_blueprint(common_bp)

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

運行項目,瀏覽器訪問

http://127.0.0.1:5000
http://127.0.0.1:5000/cms/
http://127.0.0.1:5000/common/

 

1.2.cms用戶模型定義

建立CMS模型

(1)config.py

# config.py
__author__ = 'derek'

DEBUG = True

DB_URI = "mysql+pymysql://root:123456@127.0.0.1:3306/bbs?charset=utf8"

SQLALCHEMY_DATABASE_URI = DB_URI
SQLALCHEMY_TRACK_MODIFICATIONS =False

(2)exts.py

# exts.py
__author__ = 'derek'

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

(3)cms/models.py

# cms/models.py
__author__ = 'derek'

from exts import db
from datetime import datetime

class CMSUser(db.Model):
    __tablename__='cms_user'
    id = db.Column(db.Integer,primary_key=True,autoincrement=True)
    username = db.Column(db.String(50),nullable=False)   #不能為空
    password = db.Column(db.String(100),nullable=False)
    email = db.Column(db.String(50),nullable=False,unique=True)    #不能重復
    join_time = db.Column(db.DateTime,default=datetime.now)

(4)manage.py

# manage.py
__author__ = 'derek'

from flask_script import Manager
from flask_migrate import Migrate,MigrateCommand
from Perfect_bbs import app
from exts import db
from apps.cms import models as cms_models

manager = Manager(app)

Migrate(app,db)   #綁定app跟db
manager.add_command('db',MigrateCommand)

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

(5)進cmd終端運行命令,生成到數據庫

python manage.py db init               # 初始化

python manage.py db migrate         #創建遷移腳本

python manage.py db upgrade         #生成到數據庫

進數據庫查看

 

項目下面也會多一個migrations目錄

 

添加CMS用戶

(1)Perfect_bbs.py

# Perfect_bbs.py
__author__ = 'derek'

from flask import Flask
from apps.cms import bp as cms_bp
from apps.front import bp as front_bp
from apps.common import bp as common_bp
import config
from exts import db

def create_app():
    app = Flask(__name__)
    app.config.from_object(config)
    app.register_blueprint(cms_bp)
    app.register_blueprint(front_bp)
    app.register_blueprint(common_bp)
    db.init_app(app)
    return app

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

(2)manage.py

# manage.py
__author__ = 'derek'

from flask_script import Manager
from flask_migrate import Migrate,MigrateCommand
from Perfect_bbs import create_app
from exts import db
from apps.cms import models as cms_models

CMSUser = cms_models.CMSUser
app = create_app()

manager = Manager(app)

Migrate(app,db)   #綁定app跟db
manager.add_command('db',MigrateCommand)

@manager.option('-u','--username',dest='username')
@manager.option('-p','--password',dest='password')
@manager.option('-e','--email',dest='email')
def create_cms_user(username,password,email):
    user = CMSUser(username=username,password=password,email=email)
    db.session.add(user)
    db.session.commit()
    print('cms用戶添加成功')

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

(3)cmd終端添加用戶

python manage.py create_cms_user -u derek -p 123456 -e 1184405959@qq.com

進數據庫查看是否添加成功

發現密碼是明文保存的,顯然不行

 

 密碼加密

(1)cms/models.py

對外是‘passwor‘’顯示,對內是”_password

# cms/models.py
__author__ = 'derek'

from exts import db
from datetime import datetime
from werkzeug.security import generate_password_hash,check_password_hash

class CMSUser(db.Model):
    __tablename__='cms_user'
    id = db.Column(db.Integer,primary_key=True,autoincrement=True)
    username = db.Column(db.String(50),nullable=False)   #不能為空
    _password = db.Column(db.String(100),nullable=False)
    email = db.Column(db.String(50),nullable=False,unique=True)    #不能重復
    join_time = db.Column(db.DateTime,default=datetime.now)

    def __init__(self,username,password,email):
        self.username = username
        self.password = password
        self.email = email

    @property
    def password(self):
        return self._password

    @password.setter
    def password(self,raw_password):
        self._password = generate_password_hash(raw_password)

    def check_password(self,raw_password):
        result = check_password_hash(self.password,raw_password)
        return result

(2)cmd終端重新添加用戶

更改了字段之后要migrate和upgrade一下

python manage.py db migrate         #創建遷移腳本

python manage.py db upgrade         #生成到數據庫

添加用戶

python manage.py create_cms_user -u derek -p 123456 -e 1184405959@qq.com

可以看到現在密碼是加密保存的了

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM