示例#1
0
def register():
    # 注册
    if request.method == 'GET':
        return render_template('register.html')
    else:
        username = request.form.get('username')
        password = request.form.get('password')
        repassword = request.form.get('repassword')

        db = get_db()

        msg, flag = None, 0
        if not all([username, password, repassword]):
            msg, flag = '* 请填写完整信息', 1
        elif len(username) > 16:
            msg, flag = '* 用户名太长', 1
        elif (
                db.execute("SELECT userid FROM user WHERE username = ?", (username,)).fetchone()
                is not None
        ):
            msg, flag = '* 用户名已注册', 1
        elif password != repassword:
            msg, flag = '* 两次密码不一致', 1
        elif len(password) < 6 or len(password) > 16:
            msg, flag = '* 密码长度必须在6和16之间', 1
        if flag:
            return render_template('register.html', msg=msg)
        else:
            db.execute(
                "INSERT INTO user (username, password) VALUES (?, ?)",
                (username, generate_password_hash(password)),
            )
            db.commit()
            return redirect(url_for('views.login'))
示例#2
0
def login():
    # 登录
    if request.method == 'GET':
        return render_template('login.html')
    else:
        username = request.form.get('username')
        password = request.form.get('password')

        msg = None
        if not all([username, password]):
            msg = '* 请填写好完整的信息'
            return render_template('login.html', msg=msg)

        db = get_db()
        user = db.execute(
            "SELECT * FROM user WHERE username = ?", (username,)
        ).fetchone()
        if user is None:
            msg = "* 错误的用户名或密码"
        elif not check_password_hash(user["password"], password):
            msg = "* 错误的用户名或密码"
        if msg:
            return render_template('login.html', msg=msg)
        else:
            session.clear()
            session['userid'] = user['userid']
            session['username'] = user['username']
            return redirect(url_for('views.home'))
示例#3
0
def get_graph(node_id):
    """According to the node name to serach detail infomation in neo4j
    """
    graph = {"nodes": [], "links": [], "categories": categories}
    source_type = request.args.get("sourceType")
    if not TYPE_TO_LABEL.get(source_type):
        return jsonify({
            'data': graph,
            'message': MESSAGES.get("source_type_error")
        })
    # node_id = "CNVD-2020-35433"
    graph_db = get_db()
    cql = "MATCH p=(n:%s{name:'%s'})-[]-() RETURN p LIMIT 100" % (
        TYPE_TO_LABEL.get(source_type), node_id)

    try:
        result = graph_db.run(cql)
        paths = result.data()
        if not paths:
            return jsonify({'data': graph, "message": MESSAGES.get("no_data")})

        nodes, links = consturct_graph(paths)
        graph["nodes"] = list(dedup(nodes, lambda x: x["name"]))
        graph["links"] = list(
            dedup(links, lambda x: (x["source"], x["target"])))
        print(nodes)
    except Exception as e:
        current_app.logger.error(str(e))

    return jsonify({'data': graph, "message": MESSAGES.get("success")})
示例#4
0
def load():
    # 加载
    userid = session.get('userid')

    if userid is None:
        g.user = None
    else:
        g.user = get_db().execute("SELECT * FROM user WHERE userid = ?", (userid,)).fetchone()
示例#5
0
def main():
    # 主体
    if request.method == 'GET':
        db = get_db()
        total_goods = db.execute(
            "SELECT * FROM good"
        ).fetchall()

        num = 2
        total = len(total_goods)
        page = int(request.args.get('page', 1))
        maxpage = total//num + 1
        goods = total_goods[num*(page-1):num*page]

        return render_template('main.html', goods=goods, page=page, maxpage=maxpage, total=total)