我正在用python为自己的代理服务器编写代码。从客户端和目标服务器传输数据包的代码如下:
def _read_write(self):
if self.target:
pass
else:
domain, port = self.get_target_host()
self._connect_target(domain, port)
self.target.send(self.headers)
maxtimeout = self.timeout / 3
inputs = [self.client, self.target]
count = 0
try:
while 1:
count += 1
(recv, send, err) = select.select(inputs, [], inputs)
if err:
break
if recv:
for in_ in recv:
data = in_.recv(BUFFLEN)
if in_ is self.client:
out = self.target
else:
out = self.client
if data:
out.send(data)
count = 0
if count == maxtimeout:
break
except select.error:
print >> sys.stderr, "Error : Internal queue error\n", "Reason : Unknown"
现在,由于每个数据包都是从客户机单独传输到服务器的,所以我想截取正在传输的数据,并用一些新的url替换资源(如图像、css等)的url,这些url与客户机最近的服务器是相同的。这样做对吗?我想我会陷入一个问题,如果网址是分开的数据包。你知道吗
对-在包级别上这样做是很困难的。更简单的方法是首先在代理中构建整个数据,然后进行处理,然后将数据发送到客户端。你知道吗
相关问题 更多 >
编程相关推荐