客户端:

1.既然脚本是让别人用的,怎么说也得有个界面,(虽然很low)

'''
DenyManager.py
调用客户端与客户端界面
'''
from DenyClient import *
from DenyGui import *

if __name__ == '__main__':
    clientConncet = DenyHttpClient()
    clientGui = DenyHttpGui()     

2.客户端的界面很简单,签到还没写,(构思中...)其实能用的就一个比赛开始的Button

这是后台跑的数据

这个连接服务器的messageBox为了改变比赛开始Button的状态为不可点击

检查版本信息,在确定开始比赛之前检查版本信息,版本不对,更新吧(下个新版的就好了)

之后,开始比赛!

#coding=utf-8
'''
DenyGui.py
客户端的界面
1.倒计时lable
2.签到Button(未实现)
3.开始比赛Button
'''
import tkinter as tk
import random
import time
import datetime
import sys
import os
''' 用messagebox没有下面这句,报错'''
from tkinter import messagebox#专门加上
from DenyClient import *
from CountTime import *
from tkinter.constants import *
import threading

class DenyHttpGui(object):

    def __init__(self):
        '''创建一个实例对象,进行倒计时'''
        self.changetime = ChangeTime()
        '''定义窗口'''
        self.root = tk.Tk()
        '''标题'''
        self.root.title('404监考系统')
        '''大小'''
        self.curWidth = 300
        self.curHeight = 100
        '''位置'''
        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)
        '''倒计时Frame'''
        self.frameTop = tk.Frame(self.root,height=45,width=300)
        '''Button Frame'''
        self.frameBottom = tk.Frame(self.root,height=55,width=300)
        '''把Button顶上去'''
        self.frameDemo = tk.Frame(self.root,height=10)

        self.frameTop.pack(side=tk.TOP)
        self.frameBottom.pack(side=tk.TOP)
        self.frameDemo.pack(side=tk.TOP)
        '''定义倒计时属性'''
        self.decTimeLable = tk.Label(self.frameTop,text='正在连接服务器...',font=("Arial",20))
        self.decTimeLable.pack(side=tk.TOP)
        '''定义签到Button'''
        tk.Button(self.frameBottom,
               text='签到',
               height=1,width=8,padx=8,pady=8,
               font=("Arial",14),
               command=self.check).pack(side=tk.LEFT)
        '''定义比赛Button'''
        self.BEGIN = tk.Button(self.frameBottom,
                           text='比赛开始',
                           height=1,width=8,padx=8,pady=8,
                           font=("Arial",14),
                           command=self.startButton)
        self.BEGIN.pack(side=tk.RIGHT)
        self.decTimeLable.pack()
        self.root.mainloop()
    '''开始比赛,启动客户端服务'''
    def startButton(self):
        self.BEGIN.config(state='disable')
        denyhttpclinet = DenyHttpClient()
        threadQueryTime = threading.Thread(target=denyhttpclinet.queryTime)
        threadQueryTime.start()
        '''下面这句,为了刷新Button状态为不可点击状态'''
        tk.messagebox.showwarning('警告', '正在连接服务器...')
        threadQueryTime.join()
        '''进行版本更新'''
        '''线程之间用returnval传递值'''
        if denyhttpclinet.returnval == 1:
            self.decTimeLable.configure(text='正在检查版本信息...')
            threadCheckTime = threading.Thread(target=denyhttpclinet.checkVersion)
            threadCheckTime.start()
            threadCheckTime.join()

            print(denyhttpclinet.versionRight)
            if denyhttpclinet.versionRight == 1:
                self.decTimeLable.configure(text='00:00:00')
                tk.messagebox.showwarning('警告', '当前为最新版本!')
            else:
                tk.messagebox.showwarning('警告', '版本更新!\n请联系管理员')
                sys.exit()
            threadContest = threading.Thread(target=denyhttpclinet.startContest)
            threadContest.start()
        elif denyhttpclinet.returnval == 0:
            self.decTimeLable.configure(text='比赛尚未开始!')
        elif denyhttpclinet.returnval == -2:
            self.decTimeLable.configure(text='比赛已经开始!')
        else:
            self.decTimeLable.configure(text='比赛已结束!')
        if denyhttpclinet.endTime !='' and denyhttpclinet.now != '':
            self.totaltime = (denyhttpclinet.endTime - datetime.datetime.strptime(denyhttpclinet.now, "%Y-%m-%d %H:%M:%S")).seconds
            self.changetime = ChangeTime(self.totaltime)
            threadDecTime = threading.Thread(target=self.textadd())
            threadDecTime.start()
    '''改变Button状态'''
    def buttonNormal(self,sleepTime):
        while self.mark:
            if self.mark :
                self.BEGIN.config(state='normal')
            time.sleep(1)
    def check(self):
        tk.messagebox.showwarning('警告', '待更新')
    '''刷新倒计时'''
    def textadd(self):
        t = self.changetime.subTime()
        if t == '00:00:00':
            self.BEGIN.config(state='normal')
            self.decTimeLable.configure(text='比赛结束!')#这个修改lable值
            return
        self.decTimeLable.configure(text='距比赛结束: '+t)
        self.decTimeLable.after(1000, self.textadd)

if __name__=='__main__':
    Demo = DenyHttpGui()
    Demo.startGui()
#coding:gbk
'''
DenyClient.py
客户端与服务器端的操作
1.连接服务器
2.监听端口
3.查询比赛时间
4.监听本地网络连接状态
5.违规报警
'''
from socket import *
import time
import datetime
from ClientOperate import *
import threading
import subprocess
import multiprocessing

class DenyHttpClient():
    def __init__(self):
        '''服务器套接字'''
        self.HOST = '10.251.234.141'
        self.PORT = 1122
        self.ADDR = (self.HOST, self.PORT)
        '''数据包大小'''
        self.BUFSIZE = 1024
        self.now = ''
        '''比赛结束时间'''
        self.endTime = ''
        '''线程之间传值'''
        self.returnval = 0
        '''版本号'''
        self.versionRight = 0
    '''检查版本'''
    def checkVersion(self):
        msg = 'V:0'
        self.listener(msg)
        ':
            self.versionRight =  1
        elif self.getdata == '-1':
            self.versionRight =  -1

    '''查询比赛时间,确认连接'''
    def queryTime(self):
        if os.system('ping ' + self.HOST):
            print('无法连接到目标主机!')
            return
        self.now = datetime.datetime.strftime(datetime.datetime.now(), "%Y-%m-%d %H:%M:%S")
        msg = 'B:' + str(self.now)
        try:
            if self.listener(msg):
                msg = 'IP:' + gethostbyname(gethostname())
                self.listener(msg)
                self.returnval = 1
                return 1
            elif self.getdata == '-1':
                print('比赛已结束')
                self.returnval = -1
                return -1
            elif self.getdata == '-2':
                self.returnval = -2
                print('比赛已经开始')
                return -2
            else:
                self.returnval = 0
                return 0
        except ConnectionRefusedError:
            self.returnval = 0
            return 0
        except TimeoutError:
            self.returnval = 0
            return 0
    '''开始检测与本地监听'''
    def startContest(self):
        self.t1 = threading.Thread(target=self.contestBegin)#参数是函数对象
        self.t2 = threading.Thread(target=self.contestEnd)
        self.t1.setDaemon(True)
        self.t2.setDaemon(True)
        self.t1.start()
        self.t2.start()
        self.t1.join()
        self.t2.join()
        return 0
    '''监听端口信息'''
    def listener(self,data):
        self.client = socket(AF_INET,SOCK_STREAM)
        self.client.connect(self.ADDR)

        self.client.send(data.encode('utf-8'))
        print('发送消息给%s: %s' % (self.HOST, data))
        self.getdata = self.client.recv(self.BUFSIZE)
        self.getdata = self.getdata.decode('utf-8')
        print('接受的消息  %s' % (self.getdata))
        ' or self.getdata == '-1':
            return False
        elif len(self.getdata) > 2:
            self.endTime = datetime.datetime.strptime(self.getdata, "%Y-%m-%d %H:%M:%S")
            return True

    '''
    在比赛过程中
    1.执行拒绝HTTP操作
    2.不断检测网络是否联通
    '''
    def contestBegin(self):
        Denyfile()
        if not detectnet():
            print('success deny http!')
        else:
            print('failed deny http!')
            return
        self.begin = 1
        while self.begin:
            if detectnet():
                print('somebody cheating!')
                self.listener('Error: ' + gethostbyname(gethostname()))
            time.sleep(5)

    '''检查是否到比赛时间,每隔 剩余时间二分之一检查一次,比赛结束后,恢复网络'''
    def contestEnd(self):
        print('检测比赛结束.......')
        while True:
            if self.endTime > datetime.datetime.now():
                sleepTime  = (self.endTime - datetime.datetime.now()).seconds // 2
                if not sleepTime > 5:
                    sleepTime = 2
                time.sleep(sleepTime)
                print('contestEnd: 比赛进行中...')
            else:
                break
        self.begin = 0
        print('contest end!')
        Recoverfile()
        if os.system('ping www.baidu.com') == 1:
            print('contest end but recover failed!!!')
        else:
            print('比赛完美举办!')

if __name__ == '__main__':
    c = DenyHttpClient()
    c.checkVersion()
#     c.startContest()
'''
ClientOperate.py
对文件的复制,恢复,修改处理
'''
#coding:gbk
import os
import sys
from subprocess import *

'''复制Hosts文件,添加禁止访问网址,备份'''
def Denyfile():

    if not os.path.exists('D:\DenyHttp'):
        os.mkdir('D:\DenyHttp')
        os.mkdir(r'D:\DenyHttp\restore')    

    hostsName = 'C:\Windows\System32\drivers\etc\hosts'
    filename = r'D:\DenyHttp\hosts'
    if os.path.exists(r'D:\DenyHttp\hosts') and os.path.exists(r'D:\DenyHttp\restore\hosts'):
        print(filename + '已存在!')
    else:
        print('文件不存在,准备复制:')
        if not os.system(r'copy '+ hostsName +' D:\DenyHttp'):
            print('file remove from ' + hostsName + ' to ' + filename)
        if not os.system(r'copy '+ hostsName + r' D:\DenyHttp\restore'):
            print('file remove from ' + hostsName + ' to D:\DenyHttp\restore')

        L = []
        denyNetAddress = getHTTPList(L)
        '''添加htttp到文件'''
        for s in denyNetAddress:
            os.system('echo ' + s +'>>' + filename)

    '''修改hosts文件'''
    if not os.system(r'copy D:\DenyHttp\hosts C:\Windows\System32\drivers\etc'):
        print('file hosts has been already discovered!')
'''恢复Hosts文件'''
def Recoverfile():
    if not os.system(r'copy D:\DenyHttp\restore\hosts C:\Windows\System32\drivers\etc'):
        print('file hosts has been already recovered!')
'''覆盖Hosts文件后,检查是否成功覆盖,成功后将不能访问特定网址'''
def detectnet():
    L = []
    denyNetAddress = getNetList(L)
    mark = 1
    for s in denyNetAddress:
        p = Popen(["ping.exe" , s],
                  stdin=PIPE,stdout=PIPE,stderr=PIPE,
                  shell=True)
        out = p.stdout.read()
        if '127.0.0.1' in str(out):
            mark = 0
    '''mark为假不能访问'''
    if not mark:
        print('can\'t request http')
    else:
        print('can request http')
    return mark
'''初始化目标网址列表'''
def getHTTPList(denyNetAddress = []):
    denyNetAddress.append('127.0.0.1 www.baidu.com')
    denyNetAddress.append('127.0.0.1 www.sogou.com')
    denyNetAddress.append('127.0.0.1 sg.search.yahoo.com')
    denyNetAddress.append('127.0.0.1 cn.bing.com')
    denyNetAddress.append('127.0.0.1 www.soso.com')
    denyNetAddress.append('127.0.0.1 www.cnblogs.com')
    denyNetAddress.append('127.0.0.1 blog.csdn.net')

    return denyNetAddress
def getNetList(denyNetAddress = []):
    denyNetAddress.append('www.baidu.com')
    denyNetAddress.append('www.sogou.com')
    denyNetAddress.append('sg.search.yahoo.com')
    denyNetAddress.append('cn.bing.com')
    denyNetAddress.append('www.soso.com')
    denyNetAddress.append('www.cnblogs.com')
    denyNetAddress.append('blog.csdn.net')

    return denyNetAddress
if __name__ == '__main__':
#     Denyfile()
    Recoverfile()
#     print(detectnet())
    

 

#coding:utf-8
'''
CountTime.py
将秒转化为时间格式进行倒计时
'''
class ChangeTime():

    def __init__(self,totaltime=0):
        self.sec = totaltime
        self.hour = int(self.sec / 3600)
        self.sec = self.sec % 3600
        self.minute = int(self.sec / 60)
        self.sec = int(self.sec % 60)
    def subTime(self):
        if self.sec > 0:
            self.sec -=  1
        else:
            if self.minute > 0:
                self.minute -= 1
                self.sec = 59
            else:
                if self.hour > 0:
                    self.hour -= 1
                    self.minute = 59
                    self.sec = 59
                else:
                    '
        return str('%02d' % self.hour) + ':' + str('%02d' % self.minute) + ':' + str('%02d' % self.sec)
        

 

python--DenyHttp项目(2)--ACM监考客户端测试版(1阶段客户端总结)的更多相关文章

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

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

  2. 32个Python爬虫项目让你一次吃到撑

    整理了32个Python爬虫项目.整理的原因是,爬虫入门简单快速,也非常适合新入门的小伙伴培养信心.所有链接指向GitHub,祝大家玩的愉快~O(∩_∩)O WechatSogou [1]- 微信公众 ...

  3. Github上的python开源项目

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

  4. Pycharm+django新建Python Web项目

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

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

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

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

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

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

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

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

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

  9. python【项目】:基于socket的FTP服务器

    功能要求 1. 用户加密认证 2. 服务端采用 SocketServer实现,支持多客户端连接 3. 每个用户有自己的家目录且只能访问自己的家目录 4. 对用户进行磁盘配额.不同用户配额可不同 5. ...

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

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

随机推荐

  1. windbg工具安装配置及dump抓取

    安装与配置windbg 安装与配置windbg的symbol(符号) 第一步 下载WinDBG, 第二步 双击下载的文件安装windbg.安装时注意记住安装到那里了. 第三步 windbg访问符号需要 ...

  2. Notepad++中过滤掉的正则方式

    2 => 'ashadv'3 => 'aogro'4 => 'aogs'5 => 'ashamw'6 => 'arc'8 => 'gtsatq'9 => 'b ...

  3. java执行程序的内存分析系列专栏二之static变量和方法内存分析

    昨天写了简单的聊了下java执行程序时简单的内存划分,今天我们接着往下聊,聊聊static变量和方法的内存分析. 1.static变量和方法的第一个特性内存分析 statiic变量和方法的第一个特性能 ...

  4. 【LeetCode】237. Delete Node in a Linked List

    题目: Write a function to delete a node (except the tail) in a singly linked list, given only access t ...

  5. 自己编写的 C++ 超轻量级日志类

    [自己编写的 C++ 超轻量级日志类(兼容vc++6.0.vs2010.vs2015)] 先来看效果: [测试文件:test.cpp] /* 作者:闫文山 时间:2017/07/02 介绍: 本日志类 ...

  6. 【PHP】制作日历

    本期本博主将讲述两种利用PHP制作日历的方法,由于PHP日期函数的便捷性,使得我们制作日历这一过程变得相当简单 问题描述: 1.取到当前日期,并着色显示:2.根据当前日期,判断本月有多少天,一号是周几 ...

  7. JVM总结之GC

    哪些内存需要回收 在Java堆中存放着几乎所有的对象实例,垃圾收集器在对堆进行回收前,第一件事情就是要知道哪些对象还"存活着",哪些对象已经"死去". 引用计数 ...

  8. 使用JDK自带的MessageDigest计算消息摘要

    使用JDK自带的MessageDigest计算消息摘要 上代码 /** * 使用JDK自带MessageDigest */ public class MessageDigestUtils { /** ...

  9. usaco 2002 月赛 Chores 题解

    Description Farmer John's family pitches in with the chores during milking, doing all the chores as ...

  10. Chrome浏览器扩展开发系列之十八:扩展的软件国际化chrome.i18n API

    i18n是internationalization 的简写,这里将讨论软件国际化的问题.熟悉软件国际化的朋友应该知道,软件国际化要求,页面中所有用户可见的字符串都必须置于资源属性文件中.资源属性文件中 ...