服务器端:

#coding:utf-8
'''
ServerGui.py
设置比赛开始时间
设置比赛结束时间
若时间无误启动监听服务
'''
import time
import re
import tkinter as tk
from tkinter import simpledialog
from DenyServer import *
import threading

class ServerGui():

    def __init__(self):
        '''开始时间,结束时间'''
        self.getEndTime = ''
        self.getStartTime = ''
        '''定义窗口布局'''
        self.root = tk.Tk()
        self.serverMark = 1
        self.root.title('404监考服务器')
        self.curWidth = 450
        self.curHeight = 85
        scnWidth,scnHeight = self.root.maxsize()
        tmpcnf = '%dx%d+%d+%d'%(self.curWidth,self.curHeight,
                                (scnWidth-self.curWidth)/2,(scnHeight-self.curHeight)/2)
        self.root.geometry(tmpcnf)
        self.root.resizable(False, False)
        '''比赛开始时间Button'''
        self.setStartTimeButton = tk.Button(self.root,
                                       text='设置比赛开始时间:',
                                        height=1,width=15,padx=8,pady=1,
                                        font=("Arial",14),
                                        command=self.setStartTime)
        self.startTimeLable = tk.Label(self.root,text='00:00:00',font=("Arial",20))
        self.setStartTimeButton.grid(row=0,column=0,stick=tk.E)
        self.startTimeLable.grid(row=0,column=1,stick=tk.W)
        '''比赛结束时间Button'''
        self.setTimeButton = tk.Button(self.root,
                                       text='设置比赛结束时间:',
                                        height=1,width=15,padx=8,pady=1,
                                        font=("Arial",14),
                                        command=self.setEndTime)
        self.timeLable = tk.Label(self.root,text='00:00:00',font=("Arial",20))
        self.setTimeButton.grid(row=1,column=0,stick=tk.E)
        self.timeLable.grid(row=1,column=1,stick=tk.W)

        '''启动服务器'''
        if self.serverMark:
            self.threadStartServerServices = threading.Thread(target=self.checkTimeAndLocaltion)
            self.threadStartServerServices.start()

        self.root.mainloop()
    '''检查时间是否设置'''
    def checkTimeAndLocaltion(self):
        while True:
            if self.getEndTime != '' and self.getStartTime != '':
                self.serverStart()
                break
            time.sleep(1)
    '''设置比赛开始时间'''
    def setStartTime(self):
        ch = simpledialog.askstring("比赛开始时间:", "时间格式例如:2017-07-12 00:00:15")
        pattern=re.compile(r'(\d{4}-\d{2}-\d{2})((\s\d{2}:\d{2}:\d{2}|))')
        try:
            s = pattern.search(ch).group()
            self.getStartTime = s
            self.startTimeLable.configure(text=s)
        except AttributeError:
            tk.messagebox.showerror('警告', "格式错误")
            self.setStartTime()
        except TypeError:
            pass
    '''设置比赛结束时间'''
    def setEndTime(self):
        ch = simpledialog.askstring("比赛结束时间:", "时间格式例如:2017-07-12 00:00:15")
        pattern=re.compile(r'(\d{4}-\d{2}-\d{2})((\s\d{2}:\d{2}:\d{2}|))')
        try:
            s = pattern.search(ch).group()
            self.getEndTime = s
            self.timeLable.configure(text=s)
        except AttributeError:
            tk.messagebox.showerror('警告', "格式错误")
            self.setEndTime()
        except TypeError:
            pass
    '''启动服务器端'''
    def serverStart(self):
        self.serverMark = 0
        '''模块接口'''
        server = ThreadTCPServer(initServerIp(), TCPHandler)
        TCPHandler.startTime = datetime.datetime.strptime(self.getStartTime, "%Y-%m-%d %H:%M:%S")
        TCPHandler.endTime   = datetime.datetime.strptime(self.getEndTime,   "%Y-%m-%d %H:%M:%S")

        server_thread = threading.Thread(target=server.serve_forever())
        server_thread.daemon = True
        server_thread.start()
        server_thread.join()
        server.shutdown()

if __name__ == '__main__':
    servergui = ServerGui()
#coding:utf-8
'''
DenyServer.py
使用socketserver创建一个服务器端(用前辈的模块,不如自己写的灵活,导致很多功能在接口处卡死)
'''
from socket import *
import threading
import socketserver
import datetime
import logging
from DenyItem.ServerGui import *

class TCPHandler(socketserver.BaseRequestHandler):

    '''处理request请求'''
    def handle(self):  

        self.BUFSIZE = 1024
        self.version = '
        self.clientIP = []
        '''获取request数据并删除头尾空格'''
        self.data = self.request.recv(self.BUFSIZE).strip().decode('utf-8')
        self.senddata = ''
        '''配置日志格式'''
        logging.basicConfig(level=logging.DEBUG,
                format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s :%(message)s',
                datefmt='%a, %d %b %Y %H:%M:%S',
                filename='Serverlog.log',
                filemode='a')
        '''记录日志'''
        logging.info("{} send:" .format(self.client_address[0]) + str(self.data))
        '''响应客户端请求'''
        if self.data[0] == 'B':
            self.beginTime = self.data[2:]
            self.beginTime = datetime.datetime.strptime(self.beginTime,'%Y-%m-%d %H:%M:%S')
            if self.endTime == '' :
                self.senddata = '
            elif self.startTime <= self.beginTime:
                self.senddata = '-2'
            elif self.beginTime >= self.endTime:
                self.senddata = '-1'
            else:
                self.senddata = self.endTime
        elif self.data[0] == 'E':
            '''报警模块'''
            '''BUG,获取IP'''

            if self.data[-3] == '.':
                self.id = int(self.data[-2:])
                logging.error('502 IP:' + str(self.id) + '号,正在作弊!!!')
            else:
                self.id = int(self.data[-3:]) - 110
                logging.error('404:' + str(self.id) + '号,正在作弊!!!')
        elif self.data[0] == 'V':
            if self.data[-1:] == self.version:
                self.senddata = '
            else:
                self.senddata = '-1'
        elif self.data[:2] == 'IP':
            '''更新上线列表'''
            if self.data[-3] == '.':
                '''502IP未定'''
                '''502IP未定'''
                '''502IP未定'''
                logging.info('502 上线:' + self.data[-2:])
            else:
                logging.info('404 上线:' + str(int(self.data[-3:])-110))

        self.request.sendall(str(self.senddata).encode('utf-8'))

class ThreadTCPServer(socketserver.ThreadingMixIn,socketserver.TCPServer):
    pass

def initServerIp():
    ADDR = HOST, PORT = gethostbyname(gethostname()), 1122
    return ADDR

if __name__=='__main__':

    server = ThreadTCPServer(initServerIp(), TCPHandler)
    TCPHandler.endTime = datetime.datetime.strptime('2017-7-27 20:00:00', "%Y-%m-%d %H:%M:%S")
    server_thread = threading.Thread(target=server.serve_forever())
    server_thread.daemon = True
    server_thread.start()
    server_thread.join()
    server.shutdown()

python--DenyHttp项目(2)--ACM监考服务器端的更多相关文章

  1. Github上的python开源项目

    Python开源项目,期待大家和我们一起共同维护 github排名榜单 https://github.com/trending github搜索榜单:https://github.com/search ...

  2. Pycharm+django新建Python Web项目

    这两天初学Python,首先是学习Python语法有PyCharm就可以运行Console程序了,因为是初学所以,尽量写的比较详细,包括参考的资料地址...   1.下载Python,并安装[本文版本 ...

  3. Python(Django)项目与Apache的管理

    (开开心心每一天~ ---虫瘾师) Python(Django)项目交给Apache的管理(一) 准备:Django的环境(Python).Apache.Wsgi(必须文件) 首先需要电脑有Pytho ...

  4. Python(Django)项目与Apache的管理交互

    (开开心心每一天~ ---虫瘾师) Python(Django)项目交给Apache的管理(一) 准备:Django的环境(Python).Apache.Wsgi(必须文件) 首先需要电脑有Pytho ...

  5. 再一波Python实战项目列表

    前言: 近几年Python可谓是大热啊,很多人都纷纷投入Python的学习中,以前我们实验楼总结过多篇Python实战项目列表,不但有用还有趣,最主要的是咱们实验楼不但有详细的开发教程,更有在线开发环 ...

  6. 使用Nginx+Uwsgi部署Python Flask项目

    第一次用Flask做Web(也是第一次用Python做Web),在部署的时候遇到了不少问题,现在将过程就下来,供在这方面也有疑惑的人参考.(PS:使用Apache+mod_wsgi部署模式的可以参考另 ...

  7. 机器学习 Top 20 Python 开源项目

    转自:http://mp.weixin.qq.com/s?__biz=MzA4MjEyNTA5Mw==&mid=2652565022&idx=1&sn=9aa035097120 ...

  8. python实战===2017年30个惊艳的Python开源项目 (转)

    本文转自:http://www.sohu.com/a/216723120_115128 摘要:本文来自Mybridge,介绍了过去一年里30个惊艳的Python开源项目.点击每一个都可以在GitHub ...

  9. 10大Python开源项目推荐(Github平均star2135)

    翻译 | suisui 来源 | 人工智能头条(AI_Thinker) 继续假日充电系列~本文是 Mybridge 挑选的 10 个 Python 开源项目,Github 平均star 2135,希望 ...

随机推荐

  1. bootstrap-table前台和后台分页对json格式的要求

    Bootstrap是一款前端非常流行的框架,其中的表格更为大家经常使用.大家都知道表格的分页分为前台和后台分页,也就是表格配置中sidePagination属性,当sidePagination: &q ...

  2. EntityFramework连接SQLite

    EF很强大,可惜对于SQLite不支持CodeFirst模式(需要提前先设计好数据库表结构),不过对SQLite的数据操作还是很好用的. 先用SQLiteManager随便创建一个数据库和一张表:

  3. Window文件目录挂载(mount)到linux系统目录下

    1.先在windows下面共享需要挂载的目录. 2.确保linux与windows是在同一个局域网当中. 3.在linux下面创建一个需要挂载到的目录. 4.然后点击"添加",建立 ...

  4. linux下修改Apache配置文件

    linux下修改host文件host文件存放路径 /etc/hosts 可以用vim编辑 //Apache配置虚拟主机 /usr/local/apache/conf/extra/httpd-vhost ...

  5. 12.exception对象

    excepton对象是一个异常对象,当一个页面在运行过程中发生了异常,就产生了这个对象,如果一个jsp页面要应用此对象,就必须把isErrorPage设置为true,否则无法编译.它实际上是java. ...

  6. (转载)Oracle10g 数据泵导出命令 expdp 使用总结(三)

    原文链接:http://hi.baidu.com/edeed/item/19aa0df856da3e19a6298894 Oracle10g 数据泵导出命令 expdp 使用总结(一) 14. JOB ...

  7. (转载)Oracle10g 数据泵导出命令 expdp 使用总结(二)

    原文链接:http://hi.baidu.com/edeed/item/2c454cff5c559f773d198b94 Oracle10g 数据泵导出命令 expdp 使用总结(一) 1.1.2 e ...

  8. vijos1047题解

    总算编好了这一题,我表示200+行,亚历山大. 题目描述很简单,做起来不简单啊.(高精度的取模和除法不是一般的恶心!) 先说一下非高精度的一般做法. 求两个数a,b的最小公倍数,就是a.b的乘积与a. ...

  9. HDU 1698 Just a Hook(线段树成段更新)

    题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=1698 题目: Problem Description   In the game of DotA, P ...

  10. MongoDB数据库聚合

    前面的话 聚合操作主要用于对数据的批量处理,将记录按条件分组以后,然后再进行一系列操作,例如,求最大值.最小值.平均值,求和等操作.聚合操作还能够对记录进行复杂的操作,主要用于数理统计和数据挖掘.在 ...