-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflaskapp.py
115 lines (97 loc) · 3.19 KB
/
flaskapp.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import socket
import threading
import sqlite3
from flask import Flask, jsonify, request
from flask_cors import CORS
from flask_socketio import SocketIO, emit
import sqlalchemy
from sqlalchemy.orm import sessionmaker
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import create_engine
from sqlalchemy import Column, Integer, String
app = Flask(__name__)
CORS(app)
socketio = SocketIO(app)
engine = create_engine('sqlite:///users.db')
Session = sessionmaker(bind=engine)
Base = declarative_base()
class User(Base):
__tablename__ = 'users'
account = Column(String,primary_key=True)
password = Column(String)
nickname = Column(String)
merit = Column(Integer)
Base.metadata.create_all(engine)
clients = []
import smtplib
import random
# @app.before_request
# def log_request_info():
# # app.logger.debug('Request Headers: %s', request.headers)
# # app.logger.debug('Request Body: %s', request.get_data())
# print('Request Headers: %s', request.headers)
# print('Request Body: %s', request.get_data())
@app.route('/users')
def get_users():
conn = sqlite3.connect('users.db')
cursor = conn.cursor()
cursor.execute('SELECT * FROM users')
rows = cursor.fetchall()
users = []
for row in rows:
user = {'account': row[0], 'name': row[1], 'message': row[2]}
users.append(user)
conn.close()
return jsonify(users)
@app.route('/addusers', methods=['POST'])
def add_user():
account = request.form.get('account')
password = request.form.get('password')
nickname = request.form.get('nickname')
session = Session()
user = User(account=account, password=password,nickname=nickname, merit=0)
session.add(user)
session.commit()
session.close()
return '1'
@app.route('/rename', methods=['POST'])
def rename():
account = request.form.get('account')
nickname = request.form.get('nickname')
session = Session()
user = session.query(User).filter_by(account=account).first()
user.nickname = nickname
session.commit()
session.close()
return jsonify({'success': True})
@app.route('/login', methods=['POST'])
def login():
account = request.form.get('account')
password = request.form.get('password')
session = Session()
user = session.query(User).filter_by(account=account, password=password).first()
nickname = user.nickname
if user:
success = 1
return jsonify({'nickname': nickname})
else:
return '0'
@app.route('/send_verification_code', methods=['POST'])
def send_verification_code():
email = request.form.get('email')
code = str(random.randint(100000, 999999))
sender_email = '[email protected]'
sender_password = 'KFNGWDEVBLAHUZVI'
receiver_email = email
message = 'Subject: Verification Code\n\nYour verification code is: ' + code
server = smtplib.SMTP('smtp.163.com', 25)
server.starttls()
server.login(sender_email, sender_password)
server.sendmail(sender_email, receiver_email, message)
server.quit()
return code
@app.route('/test', methods=['POST'])
def test():
return jsonify({'message': 'success'})
if __name__ == '__main__':
socketio.run(app, host='192.168.31.229', port=11455)