python–DenyHttp项目(2)–ACM监考客户端测试版(1等级客户端总)

产品名称:产生鱼悦动

  客户端: 

产品简介:发出鱼悦动,一个据为婚庆行业所研发的互联网+婚礼互动神器。

1.既脚论是给旁人用的,怎么说为得有只界面,(虽然大low)

当深耕婚庆行业之阳台,其中蕴藏的力量及婚礼现场贴合度极高,适用于各种主题场景。互动环节紧紧,使婚礼持续,欢笑不绝。

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

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

当您进去婚礼会场,拿起手机扫扫就可轻松签到;

2.客户端的界面很简短,签到还并未写,(构思中…)其实能因此的便一个竞开始之Button

于新人送祝福,送红包,甚至当场作红包闹婚礼,也会见在实地分外屏幕及看得到;

图片 1

婚礼现场,手机+现场很屏幕双屏互动高潮不绝,整场婚礼嗨到爆;

旋即是后台跑的数目

吃新娘在婚礼及闹体面,亲朋好友也玩得尽兴;

图片 2

这即是“有鱼悦动”利用手机+现场大屏幕,打过去之崭新婚礼现场互平台。

图片 3

对此互联网+的婚礼新宠儿—有鱼悦动,我们专门找了她们之祖师爷陈君毅来聊天,看看这样一个互动神器是哪些发生的。

本条连续服务器的messageBox为了改变比赛开始Button的状态吧不可点击

碰咖APP对话“有鱼悦动”创始人:陈君毅

图片 4

小编:“有鱼悦动”作为一如既往慢慢悠悠新产品,为何相同出场就是变成婚庆市场之初宠儿?

检查版本信息,在确定开始比赛前检查版本信息,版本不对,更新吧(下单新本子的就算哼了)

陈君毅:一方面我们“有鱼悦动”主打的是“免费、新潮、易用”,对于期望提升婚礼档次,简化婚礼流程的婚庆企业吧,具有十分强之吸引力。

图片 5

如果我们生产的祝福墙、送礼金、摇爱心、趣味投票等效果,在啊婚庆企业提供再多新奇玩法的以,又能够叫新人对婚庆企业的服务品质感到满意,从而成为婚庆企业机密的推广者,一举两得。

以后,开始比赛!

假使另一方面,“有鱼悦动”能够吧婚庆企业的万众号引入大量初的粉,方便婚庆企业挖掘潜在客户,增加品牌影响力。

图片 6

小编:为什么而见面举行“有鱼悦动”这样平等放缓婚礼互产品?

#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)
        if self.getdata == '1':
            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))
        if self.getdata == '0' 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 '0'
        return str('%02d' % self.hour) + ':' + str('%02d' % self.minute) + ':' + str('%02d' % self.sec)

当,要开如此平等缓慢高频互动的制品,光凭想是不行的。

 

哼于,我们之前对餐饮行业做了千篇一律磨蹭当场互动产品“有鱼互动”。

 

如今,“有鱼互动”这个活都覆盖全国31个省,拥有3000大多下合作商户,有诸如此类的实力同更做支撑,让咱们本着出暨运营“有鱼悦动”这产品产生足够的自信心。

小编:为什么说“有鱼悦动”是总揽为婚礼现场制作的?

陈君毅直言:产品从平开始的初衷到新兴之合计都是环婚礼之场景所开制作。

立马等同次,我们特邀了大多称为10年以上的名牌婚礼图人士与我们的阳台设计,产品功能涵盖婚礼现场的各个环节,真正深入到婚礼现场去想效果,做产品,为的尽管是做一个便受新人来体面,又被亲朋好友打得开心的良好婚礼。

小编:作为同一缓缓针对婚礼现场所研发的活,“有鱼悦动”产品功效是何等的也?

陈君毅:针对婚礼现场的各个环节,我们研发了6坏功效:

签到墙

扫码即可签到,现场点亮大屏幕爱心墙,让婚礼现场协调浪漫。

祝福墙

只需要在大哥大端输入而对新人的祝福,点击即可变身弹幕出现于婚礼之非常屏幕,让一条条滚的祝福,化成婚礼最动人之排场。

送礼物

纪念也新人送及特别之祝福,还而选取送上满屏的祝福红包,让华丽的祝福震撼全场。

抢红包

红包漫天飞,让现场气氛瞬间喂到最点,全场参与感爆棚,营造喜悦的婚礼气氛

摇爱心

手机摇一摇,点爆爱心,让全场婚礼爱意满满

意思投票

婚礼现场娱乐什么游戏,可由于新人自主设置,由在场宾客投票。既叫到场宾客有参与感,又避免游戏了火所带动的窘迫。

小编:“有鱼悦动”除了提供这些职能,在技术上是否发生保持?

陈君毅:为了保证婚礼现场的效应,我们提供了7*18小时人工售后服务及技术支持,实现一对一当场婚礼跟踪。


随着在品质以及消费水平的增高,相信有愈来愈多口起追新潮式的婚礼,传统的婚庆市场及互联网的三结合将会晤也婚礼带来什么样翻天覆地的更动,让我们等。