Приведенный ниже код представляет собой HTTP-прокси для фильтрации содержимого. Он использует GET для отправки URL-адреса текущего сайта на сервер, где он обрабатывает его и отвечает. Он работает ОЧЕНЬ , ОЧЕНЬ , ОЧЕНЬ медленно. Есть идеи, как сделать это быстрее?
Вот код:
from twisted.internet import reactor
from twisted.web import http
from twisted.web.proxy import Proxy, ProxyRequest
from Tkinter import *
#import win32api
import urllib2
import urllib
import os
import webbrowser
cwd = os.path.abspath(sys.argv[0])[0]
proxies = {}
user = "zachb"
class BlockingProxyRequest(ProxyRequest):
def process(self):
params = {}
params['Location']= self.uri
params['User'] = user
params = urllib.urlencode(params)
req = urllib.urlopen("http://weblock.zbrowntechnology.info/ProgFiles/stats.php?%s" % params, proxies=proxies)
resp = req.read()
req.close()
if resp == "allow":
pass
else:
self.transport.write('''BLOCKED BY ADMIN!''')
self.transport.loseConnection()
ProxyRequest.process(self)
class BlockingProxy(Proxy):
requestFactory = BlockingProxyRequest
factory = http.HTTPFactory()
factory.protocol = BlockingProxy
reactor.listenTCP(8000, factory)
reactor.run()
У кого-нибудь есть идеи, как сделать это быстрее? Или даже лучший способ написать это?