Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
py12306
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
python
py12306
Commits
b1e826b2
Commit
b1e826b2
authored
Jan 12, 2019
by
Jalin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
优化结果
parent
c49ac26f
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
50 additions
and
28 deletions
+50
-28
config.py
py12306/config.py
+3
-2
app.py
py12306/web/handler/app.py
+1
-3
query.py
py12306/web/handler/query.py
+34
-0
stat.py
py12306/web/handler/stat.py
+1
-3
user.py
py12306/web/handler/user.py
+3
-4
web.py
py12306/web/web.py
+8
-16
No files found.
py12306/config.py
View file @
b1e826b2
...
...
@@ -63,12 +63,13 @@ class Config:
WEB_ENABLE
=
0
WEB_USER
=
{}
WEB_PORT
=
8080
envs
=
[]
retry_time
=
5
last_modify_time
=
0
disallow_update_cofigs
=
[
disallow_update_co
n
figs
=
[
'CLUSTER_ENABLED'
,
'NODE_IS_MASTER'
,
'NODE_NAME'
,
...
...
@@ -147,7 +148,7 @@ class Config:
from
py12306.query.query
import
Query
from
py12306.user.user
import
User
for
key
,
value
in
envs
:
if
key
in
self
.
disallow_update_cofigs
:
continue
if
key
in
self
.
disallow_update_co
n
figs
:
continue
if
value
!=
-
1
:
old
=
getattr
(
self
,
key
)
setattr
(
self
,
key
,
value
)
...
...
py12306/web/handler/app.py
View file @
b1e826b2
from
flask
import
Blueprint
,
request
from
flask.json
import
jsonify
from
flask_jwt_extended
import
(
JWTManager
,
jwt_required
,
create_access_token
,
get_jwt_identity
)
from
flask_jwt_extended
import
(
jwt_required
)
from
py12306.config
import
Config
from
py12306.query.query
import
Query
...
...
py12306/web/handler/query.py
0 → 100644
View file @
b1e826b2
from
flask
import
Blueprint
,
request
from
flask.json
import
jsonify
from
flask_jwt_extended
import
(
jwt_required
)
from
py12306.config
import
Config
from
py12306.query.job
import
Job
from
py12306.query.query
import
Query
query
=
Blueprint
(
'query'
,
__name__
)
@
query
.
route
(
'/query'
,
methods
=
[
'GET'
])
@
jwt_required
def
query_lists
():
"""
查询任务列表
:return:
"""
jobs
=
Query
()
.
jobs
result
=
list
(
map
(
convert_job_to_info
,
jobs
))
return
jsonify
(
result
)
def
convert_job_to_info
(
job
:
Job
):
return
{
'name'
:
job
.
job_name
,
'left_dates'
:
job
.
left_dates
,
'stations'
:
job
.
stations
,
'allow_seats'
:
job
.
allow_seats
,
'allow_train_numbers'
:
job
.
allow_train_numbers
,
'passengers'
:
job
.
passengers
,
'allow_less_member'
:
job
.
allow_less_member
,
'passengers'
:
job
.
passengers
,
}
py12306/web/handler/stat.py
View file @
b1e826b2
from
flask
import
Blueprint
,
request
from
flask.json
import
jsonify
from
flask_jwt_extended
import
(
JWTManager
,
jwt_required
,
create_access_token
,
get_jwt_identity
)
from
flask_jwt_extended
import
(
jwt_required
)
from
py12306.config
import
Config
from
py12306.query.query
import
Query
...
...
py12306/web/handler/user.py
View file @
b1e826b2
from
flask
import
Blueprint
,
request
from
flask.json
import
jsonify
from
flask_jwt_extended
import
(
JWTManager
,
jwt_required
,
create_access_token
,
get_jwt_identity
)
from
flask_jwt_extended
import
(
jwt_required
,
create_access_token
)
from
py12306.config
import
Config
from
py12306.user.job
import
UserJob
...
...
@@ -27,13 +25,14 @@ def login():
@
user
.
route
(
'/users'
,
methods
=
[
'GET'
])
@
jwt_required
def
users
():
"""
用户任务列表
:return:
"""
jobs
=
User
()
.
users
result
=
map
(
convert_job_to_info
,
jobs
)
result
=
list
(
map
(
convert_job_to_info
,
jobs
)
)
return
jsonify
(
result
)
...
...
py12306/web/web.py
View file @
b1e826b2
import
json
from
datetime
import
timedelta
from
flask
import
Flask
,
request
from
flask_jwt_extended
import
(
JWTManager
,
jwt_required
,
create_access_token
,
get_jwt_identity
)
JWTManager
)
from
py12306.config
import
Config
from
py12306.helpers.func
import
*
# app.config['JWT_TOKEN_LOCATION'] = ['json']
# @flask.route('/', methods=['GET'])
# def test():
# print(111111)
# def run(port=8080):
# flask.run(debug=True, port=port if port else 8080, host='0.0.0.0')
@
singleton
class
Web
:
session
=
None
...
...
@@ -28,7 +17,8 @@ class Web:
def
__init__
(
self
):
self
.
session
=
Flask
(
__name__
)
self
.
register_blueprint
()
self
.
session
.
config
[
'JWT_SECRET_KEY'
]
=
'super-secret'
# Change this!
self
.
session
.
config
[
'JWT_SECRET_KEY'
]
=
'secret'
# 目前都是本地,暂不用放配置文件
self
.
session
.
config
[
'JWT_REFRESH_TOKEN_EXPIRES'
]
=
timedelta
(
seconds
=
60
*
60
*
24
*
7
)
# Token 超时时间 7 天
self
.
jwt
=
JWTManager
(
self
.
session
)
pass
...
...
@@ -36,9 +26,11 @@ class Web:
from
py12306.web.handler.user
import
user
from
py12306.web.handler.stat
import
stat
from
py12306.web.handler.app
import
app
from
py12306.web.handler.query
import
query
self
.
session
.
register_blueprint
(
user
)
self
.
session
.
register_blueprint
(
stat
)
self
.
session
.
register_blueprint
(
app
)
self
.
session
.
register_blueprint
(
query
)
@
classmethod
def
run
(
cls
):
...
...
@@ -47,7 +39,7 @@ class Web:
pass
def
start
(
self
):
self
.
session
.
run
(
debug
=
True
,
port
=
8080
,
host
=
'0.0.0.0'
)
self
.
session
.
run
(
debug
=
Config
()
.
IS_DEBUG
,
port
=
Config
()
.
WEB_PORT
,
host
=
'0.0.0.0'
)
if
__name__
==
'__main__'
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment