CN112653732A - 一种实现http代理的方法、装置、设备及存储介质 - Google Patents

一种实现http代理的方法、装置、设备及存储介质 Download PDF

Info

Publication number
CN112653732A
CN112653732A CN202011440559.8A CN202011440559A CN112653732A CN 112653732 A CN112653732 A CN 112653732A CN 202011440559 A CN202011440559 A CN 202011440559A CN 112653732 A CN112653732 A CN 112653732A
Authority
CN
China
Prior art keywords
data
agent
http
server
https
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202011440559.8A
Other languages
English (en)
Inventor
赵培源
朱程
马坤
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Xi'an Clover Cyber Technology Co ltd
Original Assignee
Xi'an Clover Cyber Technology Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Xi'an Clover Cyber Technology Co ltd filed Critical Xi'an Clover Cyber Technology Co ltd
Priority to CN202011440559.8A priority Critical patent/CN112653732A/zh
Publication of CN112653732A publication Critical patent/CN112653732A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer And Data Communications (AREA)

Abstract

本公开提供一种实现HTTP代理的方法、装置、设备及存储介质,涉及计算机技术领域,能够解决现有技术中在HTTP代理时运行成本与数据传输速率不能兼顾的问题。具体技术方案为:首先接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;然后将HTTP/HTTPS数据转换为Agent调用数据,Agent调用数据为符合代理Agent脚本格式的数据;最后将Agent调用数据发送给中转服务器,以使中转服务器解析Agent调用数据后发送给目标服务器。本公开用于HTTP代理。

Description

一种实现HTTP代理的方法、装置、设备及存储介质
技术领域
本公开涉及计算机技术领域,尤其涉及一种实现HTTP代理的方法、装置、设备及存储介质。
背景技术
HTTP代理服务器的作用是转发浏览器发出的HTTP数据给Web服务器,并将Web服务器返回的数据再返回给浏览器。其使用场景为浏览器无法与Web服务器直接通信,但浏览器可与HTTP代理服务器通信,HTTP代理服务器可与Web服务器通信,此时浏览器即可通过HTTP代理访问Web服务器。
目前,一般使用如nginx等Web服务器软件等配置为HTTP代理软件。但是这种方式需要部署服务器、开放独立端口、以及修改防火墙配置以满足其运行环境,运行成本较高。
另外,现有技术中还使用reGeorg软件(https://github.com/sensepost/reGeorg),利用已有支持动态脚本的Web服务器,在HTTP/HTTPS协议上中构建Socks5协议。其实现的动态脚本Agnet提供了用于转发TCP的4个API接口CONNECT、DISCONNECT、READ、FORWADR分别用于TCP的连接、关闭、读取数据、发送数据功能。reGeorg软件实现了Socks5服务端,当接收到对应Socks5指令时则通过调用Agent对应接口来转发TCP指令和数据。但是这种在方式下,当需要访问HTTPS网站时,需要调用八次Agent接口才能完成一次HTTPS请求和返回。分别是请求连接一次,SSL/TLS握手四次、发送HTTP数据一次、接收HTTP数据一次、关闭连接一次。即使对用HTTP网站也需要调用四次API,分别为请求连接一次,发送HTTP数据一次、接收HTTP数据一次、关闭连接一次。由于其对原始流量数据量有放大数倍,连接次数也至少四倍于原始连接次数,所以其速率慢、延迟高。
发明内容
本公开实施例提供一种实现HTTP代理的方法、装置、设备及存储介质,能够解决现有技术中在HTTP代理时运行成本与数据传输速率不能兼顾的问题。所述技术方案如下:
根据本公开实施例的第一方面,提供一种实现HTTP代理的方法,应用于HTTP代理服务器,所述方法包括:
接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;
将所述HTTP/HTTPS数据转换为Agent调用数据,所述Agent调用数据为符合代理Agent脚本格式的数据;
将所述Agent调用数据发送给中转服务器,以使所述中转服务器解析所述Agent调用数据后发送给目标服务器。
本公开实施例提供的实现HTTP代理的方法,首先接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;然后将HTTP/HTTPS数据转换为Agent调用数据,Agent调用数据为符合代理Agent脚本格式的数据;最后将Agent调用数据发送给中转服务器,以使中转服务器解析Agent调用数据后发送给目标服务器。本公开仅需要在Web服务器上传一个动态脚本文件即可实现HTTP代理服务,免去了复杂部署步骤和环境要求,相比于现有技术而言,运行成本低,且速率快,延迟低。
在一个实施例中,上述方法还包括:
接收所述中转服务器发送的Agent调用返回数据;
将所述Agent调用返回数据转换为HTTP/HTTPS返回数据,并将所述HTTP/HTTPS返回数据发送给所述浏览器。
本公开实施例通过上述方法,通过HTTP服务器接收中转服务器返回的Agent调用返回数据,再发送给浏览器,实现浏览器访问目标服务器。
在一个实施例中,接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据包括:
接收所述浏览器发送的HTTP数据;或
接收所述浏览器发出的连接CONNECT指令;
根据所述连接CONNECT指令,与所述浏览器建立传输层安全协议TLS或安全套接字层SSL;
根据所述TLS/SSL,接收所述浏览器发送的HTTPS数据。
本公开实施例通过以上方法,浏览器可以通过HTTP代理服务器访问HTTP或者HTTPS网站。
在一个实施例中,所述Agent调用数据包括:
所述Agent调用数据至少包括host、port、https、data参数,所述host参数用于指示要转发的服务器域名或者互联网协议IP地址、所述port参数用于指示要转发的服务器端口、所述https参数用于指示是否为超文本传输安全协议https、所述data参数用于指示原始的http数据。
根据本公开实施例的第二方面,提供一种实现HTTP代理的方法,应用于中转服务器,所述方法包括:
接收HTTP代理服务器发送的Agent调用数据,所述Agent调用数据为符合Agent脚本格式的数据;
将所述Agent调用数据解析后发送给目标服务器;
接收所述目标服务器发送的返回数据;
将所述返回数据转换为Agent调用返回数据,发送给所述HTTP代理服务器,以使所述HTTP代理服务器转换为HTTP/HTTPS返回数据发送给浏览器。
本公开实施例提供的实现HTTP代理的方法,首先接收HTTP代理服务器发送的Agent调用数据,Agent调用数据为符合Agent脚本格式的数据;然后将Agent调用数据解析后发送给目标服务器;接收目标服务器发送的返回数据;最后将返回数据转换为Agent调用返回数据,发送给HTTP代理服务器,以使HTTP代理服务器转换为HTTP/HTTPS返回数据发送给浏览器。本公开仅需要在Web服务器上传一个动态脚本文件即可实现HTTP代理服务,免去了复杂部署步骤和环境要求,相比于现有技术而言,运行成本低,且速率快,延迟低。
在一个实施例中,在接收HTTP代理服务器发送的Agent调用数据之前,所述方法还包括:
上传所述Agent脚本到所述中转服务器,获得所述中转服务器对应的统一资源定位符URL地址,并发送给所述HTTP代理服务器,以使所述HTTP代理服务器设置启动参数为所述统一资源定位符。
本公开实施例通过以上方法,可以实现HTTP代理服务器与中转服务器中Agent脚本的连接。
在一个实施例中,将所述Agent调用数据解析后发送给目标服务器包括:
判断所述Agent调用数据是否为HTTPS数据;
若是,则与所述目标服务器建立传输层安全协议TLS或安全套接字层SSL;
若否,则与所述目标服务器建立传输控制协议TCP;
根据所述TLS、SSL或TCP发送原始的HTTP数据给所述目标服务器,并接收所述目标服务器发送的返回数据。
本公开实施例通过上述方法,根据Agent调用数据是否是HTTPS数据,建立不同的协议,实现中转服务器和目标服务器之间的数据传输。
根据本公开实施例的第三方面,提供一种实现HTTP代理的装置,包括接收模块、转换模块和发送模块;
所述接收模块,用于接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;
所述转换模块,用于将所述HTTP/HTTPS数据转换为Agent调用数据,所述Agent调用数据为符合代理Agent脚本格式的数据;
所述发送模块,用于将所述Agent调用数据发送给中转服务器,以使所述中转服务器解析所述Agent调用数据后发送给目标服务器。
本公开实施例提供的实现HTTP代理的装置,包括接收模块、转换模块和发送模块;接收模块接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;转换模块将HTTP/HTTPS数据转换为Agent调用数据,Agent调用数据为符合代理Agent脚本格式的数据;发送模块将Agent调用数据发送给中转服务器,以使中转服务器解析Agent调用数据后发送给目标服务器。本公开仅需要在Web服务器上传一个动态脚本文件即可实现HTTP代理服务,免去了复杂部署步骤和环境要求,相比于现有技术而言,运行成本低,且速率快,延迟低。
根据本公开实施例的第四方面,提供一种实现HTTP代理的设备,所述实现HTTP代理的设备包括处理器和存储器,所述存储器中存储有至少一条计算机指令,所述指令由所述处理器加载并执行以实现上述任一项所述的实现HTTP代理的方法中所执行的步骤。
根据本公开实施例的第五方面,提供一种计算机可读存储介质,所述存储介质中存储有至少一条计算机指令,所述指令由处理器加载并执行以实现上述任一项所述的实现HTTP代理的方法中所执行的步骤。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
图1是本公开实施例提供的一种实现HTTP代理的方法的流程图;
图2是本公开实施例提供的一种实现HTTP代理的方法的流程图;
图3是本公开实施例提供的一种实现HTTP代理的系统的框架结构图;
图4是本公开实施例提供的一种实现HTTP代理的方法的流程图;
图5是本公开实施例提供的中转服务器和目标服务器数据传输的流程图;
图6是本公开实施例提供的一种实现HTTP代理的方法的流程图;
图7是本公开实施例提供的一种实现HTTP代理的装置的结构图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的系统和方法的例子。
本公开实施例提供一种实现HTTP代理的方法,应用于HTTP代理服务器,如图1所示,该实现HTTP代理的方法包括以下步骤:
步骤101、接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;
在一个实施例中,接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据包括:
接收浏览器发送的HTTP数据;或
接收浏览器发出的连接CONNECT指令;
根据连接CONNECT指令,与浏览器建立传输层安全协议TLS或安全套接字层SSL;
根据TLS/SSL,接收浏览器发送的HTTPS数据。
具体的,CONNECT指令为RFC2616(https://tools.ietf.org/html/rfc2616#section-9.9)中定义的指令。实际使用时,在HTTP代理运行后,当浏览器请求时判断指令是否CONNECT,如果是则浏览器将要访问HTTPS网站,向浏览器返回已连接并进一步与浏览器完成TLS/SSL握手。然后接收浏览器实际要请求的HTTP明文数据,然后构造host、port、https、data数据调用Agnet脚本,等待Agent脚本返回数据后,返回给浏览器。如果否,则直接接收浏览器要请求的HTTP明文数据,然后继续进行数据构造。
本公开实施例通过以上方法,浏览器可以通过HTTP代理服务器访问HTTP或者HTTPS网站。
步骤102、将HTTP/HTTPS数据转换为Agent调用数据,Agent调用数据为符合代理Agent脚本格式的数据;
在一个实施例中,Agent调用数据包括:
Agent调用数据至少包括host、port、https、data参数,host参数用于指示要转发的服务器域名或者互联网协议IP地址、port参数用于指示要转发的服务器端口、https参数用于指示是否为超文本传输安全协议https、data参数用于指示原始的http数据。
步骤103、将Agent调用数据发送给中转服务器,以使中转服务器解析Agent调用数据后发送给目标服务器。
在一个实施例中,上述方法还包括:
接收中转服务器发送的Agent调用返回数据;
将Agent调用返回数据转换为HTTP/HTTPS返回数据,并将HTTP/HTTPS返回数据发送给浏览器。
本公开实施例通过上述方法,通过HTTP服务器接收中转服务器返回的Agent调用返回数据,再发送给浏览器,实现浏览器访问目标服务器。
简单来说,当浏览器访问目标网站服务器时,其发送的HTTP/HTTPS数据会发送给HTTP代理,HTTP代理转换为调用Agent的HTTP/HTTPS数据发送给中转Web服务器,中转Web服务器中的Agent脚本解析数据,最终将数据发送给目标网站服务器,返回数据按照来路依次返回。
在整个过程中,HTTP代理与Agent脚本建立一次连接,发送一次数据,这个过程在客户计算机和中转服务器进行,数据量仅比原始HTTP请求多出HTTP请求头和host porthttps信息。
本公开实施例提供的实现HTTP代理的方法,首先接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;然后将HTTP/HTTPS数据转换为Agent调用数据,Agent调用数据为符合代理Agent脚本格式的数据;最后将Agent调用数据发送给中转服务器,以使中转服务器解析Agent调用数据后发送给目标服务器。本公开仅需要在Web服务器上传一个动态脚本文件即可实现HTTP代理服务,免去了复杂部署步骤和环境要求,相比于现有技术而言,运行成本低,且速率快,延迟低。
本公开另一实施例提供一种实现HTTP代理的方法,应用于中转服务器,如图2所示,该实现HTTP代理的方法包括以下步骤:
步骤201、接收HTTP代理服务器发送的Agent调用数据,Agent调用数据为符合Agent脚本格式的数据;
在一个实施例中,在接收HTTP代理服务器发送的Agent调用数据之前,上述方法还包括:
上传Agent脚本到中转服务器,获得中转服务器对应的统一资源定位符URL地址,并发送给HTTP代理服务器,以使HTTP代理服务器设置启动参数为统一资源定位符。
具体的,首先上传Agent脚本到中转Web服务器获得对应的URL地址,然后启动HTTP代理并设置启动参数为Agent脚本的URL地址,最后配置浏览器等软件的代理服务器。本实施例中,配置浏览器的代理服务器可以为http://127.0.0.1:8080。
本公开实施例通过以上方法,可以实现HTTP代理服务器与中转服务器的连接。
步骤202、将Agent调用数据解析后发送给目标服务器;
在一个实施例中,将Agent调用数据解析后发送给目标服务器包括:
判断Agent调用数据是否为HTTPS数据;
若是,则与目标服务器建立传输层安全协议TLS或安全套接字层SSL;
若否,则与目标服务器建立传输控制协议TCP;
根据TLS、SSL或TCP发送原始的HTTP数据给目标服务器,并接收目标服务器发送的返回数据。
实际使用时,首先判断调用者,也就是HTTP代理是否HTTPS,如果不是则建立TCP连接,如果是则建立TLS/SSL连接,然后发送data数据,从刚才创建的连接接收数据并将数据返回给HTTP代理。
本公开实施例通过上述方法,根据Agent调用数据是否是HTTPS数据,建立不同的连接,实现中转服务器和目标服务器之间的数据传输。
步骤203、接收目标服务器发送的返回数据;
步骤204、将返回数据转换为Agent调用返回数据,发送给HTTP代理服务器,以使HTTP代理服务器转换为HTTP/HTTPS返回数据发送给浏览器。
本公开实施例提供的实现HTTP代理的方法,首先接收HTTP代理服务器发送的Agent调用数据,Agent调用数据为符合Agent脚本格式的数据;然后将Agent调用数据解析后发送给目标服务器;接收目标服务器发送的返回数据;最后将返回数据转换为Agent调用返回数据,发送给HTTP代理服务器,以使HTTP代理服务器转换为HTTP/HTTPS返回数据发送给浏览器。本公开仅需要在Web服务器上传一个动态脚本文件即可实现HTTP代理服务,免去了复杂部署步骤和环境要求,相比于现有技术而言,运行成本低,且速率快,延迟低。
参考图3,图3为本公开提出的实现HTTP代理的系统的结构示意图。如图3所示,实现HTTP代理的系统包括客户计算机中的浏览器和HTTP代理,支持动态脚本的中转Web服务器,其中包括Agent脚本,以及任意目标Web服务器。
基于图3所示的实现HTTP代理的系统,图1和图2对应的实施例提供的实现HTTP代理的方法,本公开另一实施例提供一种实现HTTP代理的方法,如图4所示,该实现HTTP代理的方法包括以下步骤:
步骤301、上传Agent脚本到中转Web服务器获得对应的URL地址,在客户计算机上启动HTTP代理并设置启动参数为Agent的URL地址,配置浏览器等软件的代理服务器为http://127.0.0.1:8080;
步骤302、当浏览器访问网站服务器A时,其发送的HTTP/HTTPS数据会发送给HTTP代理,HTTP代理转换为调用Agent的HTTP/HTTPS数据发送给中转Web服务器;
Agent脚本接收4个参数分别是host、port、https、data。host指将要转发的服务器域名或者IP,port指将要转发的服务器端口,https表示是否为https,data指原始的http数据。
步骤303、中转Web服务器中的Agent脚本解析数据,将数据发送给指定的网站服务器A;
具体的,将调用Agent的HTTP/HTTPS数据解析后发送给网站服务器A的流程如图5所示,首先判断调用者HTTP代理是否HTTPS,如果不是则建立TCP连接,如果是则建立SSL连接,然后发送data数据,从刚才创建的连接接收数据并将数据返回给HTTP代理。具体的,在实际使用中,当判断调用者HTTP代理是HTTPS时,还可以建立TLS连接,然后发送data数据,从刚才创建的连接接收数据并将数据返回给HTTP代理。
如图6所示,HTTP代理运行后,当浏览器请求时判断指令是否CONNECT,如果是则浏览器将要访问HTTPS网站,向浏览器返回已连接并进一步与浏览器完成TLS/SSL握手。
接收浏览器实际要请求的HTTP明文数据,然后构造host、port、https、data数据调用Agnet脚本,等待Agent脚本返回数据后,返回给浏览器。
步骤304、返回数据按照来路依次返回。
本公开实施例在整个过程中,HTTP代理与Agent脚本建立一次连接,发送一次数据,这个过程在客户计算机和中转Web服务器进行,数据量仅比原始HTTP请求多出HTTP请求头和host port https信息。
基于上述图1、图2和图4对应的实施例中所描述的实现HTTP代理的方法,下述为本公开系统实施例,可以用于执行本公开方法实施例。
本公开实施例提供一种实现HTTP代理的装置,如图7所示,该装置40包括接收模块401、转换模块402和发送模块403;
接收模块401,用于接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;
转换模块402,用于将HTTP/HTTPS数据转换为Agent调用数据,Agent调用数据为符合代理Agent脚本格式的数据;
发送模块403,用于将Agent调用数据发送给中转服务器,以使中转服务器解析Agent调用数据后发送给目标服务器。
本公开实施例提供的实现HTTP代理的装置40,包括接收模块401、转换模块402和发送模块403;接收模块401接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;转换模块402将HTTP/HTTPS数据转换为Agent调用数据,Agent调用数据为符合代理Agent脚本格式的数据;发送模块403将Agent调用数据发送给中转服务器,以使中转服务器解析Agent调用数据后发送给目标服务器。本公开仅需要在Web服务器上传一个动态脚本文件即可实现HTTP代理服务,免去了复杂部署步骤和环境要求,相比于现有技术而言,运行成本低,且速率快,延迟低。
基于上述图1、图2和图4对应的实施例中描述的实现HTTP代理的方法,本公开另一实施例还提供一种实现HTTP代理的设备,该实现HTTP代理的设备包括处理器和存储器,存储器中存储有至少一条计算机指令,该指令由处理器加载并执行以实现上述图1、图2和图4对应的实施例中所描述的实现HTTP代理的方法。
基于上述图1、图2和图4对应的实施例中所描述的实现HTTP代理的方法,本公开实施例还提供一种计算机可读存储介质,例如,非临时性计算机可读存储介质可以是只读存储器(英文:Read Only Memory,ROM)、随机存取存储器(英文:Random Access Memory,RAM)、CD-ROM、磁带、软盘和光数据存储装置等。该存储介质上存储有至少一条计算机指令,用于执行上述图1、图2和图4对应的实施例中所描述的实现HTTP代理的方法,此处不再赘述。
本领域技术人员在考虑说明书及实践这里公开的公开后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。

Claims (10)

1.一种实现HTTP代理的方法,其特征在于,应用于HTTP代理服务器,所述方法包括:
接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;
将所述HTTP/HTTPS数据转换为Agent调用数据,所述Agent调用数据为符合代理Agent脚本格式的数据;
将所述Agent调用数据发送给中转服务器,以使所述中转服务器解析所述Agent调用数据后发送给目标服务器。
2.根据权利要求1所述的实现HTTP代理的方法,其特征在于,所述方法还包括:
接收所述中转服务器发送的Agent调用返回数据;
将所述Agent调用返回数据转换为HTTP/HTTPS返回数据,并将所述HTTP/HTTPS返回数据发送给所述浏览器。
3.根据权利要求1所述的实现HTTP代理的方法,其特征在于,所述接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据包括:
接收所述浏览器发送的HTTP数据;或
接收所述浏览器发出的连接CONNECT指令;
根据所述连接CONNECT指令,与所述浏览器建立传输层安全协议TLS或安全套接字层SSL;
根据所述TLS/SSL,接收所述浏览器发送的HTTPS数据。
4.根据权利要求1所述的实现HTTP代理的方法,其特征在于,所述Agent调用数据包括:
所述Agent调用数据至少包括host、port、https、data参数,所述host参数用于指示要转发的服务器域名或者互联网协议IP地址、所述port参数用于指示要转发的服务器端口、所述https参数用于指示是否为超文本传输安全协议https、所述data参数用于指示原始的http数据。
5.一种实现HTTP代理的方法,其特征在于,应用于中转服务器,所述方法包括:
接收HTTP代理服务器发送的Agent调用数据,所述Agent调用数据为符合Agent脚本格式的数据;
将所述Agent调用数据解析后发送给目标服务器;
接收所述目标服务器发送的返回数据;
将所述返回数据转换为Agent调用返回数据,发送给所述HTTP代理服务器,以使所述HTTP代理服务器转换为HTTP/HTTPS返回数据发送给浏览器。
6.根据权利要求5所述的实现HTTP代理的方法,其特征在于,在接收HTTP代理服务器发送的Agent调用数据之前,所述方法还包括:
上传所述Agent脚本到所述中转服务器,获得所述中转服务器对应的统一资源定位符URL地址,并发送给所述HTTP代理服务器,以使所述HTTP代理服务器设置启动参数为所述统一资源定位符。
7.根据权利要求5所述的实现HTTP代理的方法,其特征在于,所述将所述Agent调用数据解析后发送给目标服务器包括:
判断所述Agent调用数据是否为HTTPS数据;
若是,则与所述目标服务器建立传输层安全协议TLS或安全套接字层SSL;
若否,则与所述目标服务器建立传输控制协议TCP;
根据所述TLS、SSL或TCP发送原始的HTTP数据给所述目标服务器,并接收所述目标服务器发送的返回数据。
8.一种实现HTTP代理的装置,其特征在于,包括接收模块、转换模块和发送模块;
所述接收模块,用于接收浏览器发送的超文本传输协议HTTP/超文本传输安全协议HTTPS数据;
所述转换模块,用于将所述HTTP/HTTPS数据转换为Agent调用数据,所述Agent调用数据为符合代理Agent脚本格式的数据;
所述发送模块,用于将所述Agent调用数据发送给中转服务器,以使所述中转服务器解析所述Agent调用数据后发送给目标服务器。
9.一种实现HTTP代理的设备,其特征在于,所述实现HTTP代理的设备包括处理器和存储器,所述存储器中存储有至少一条计算机指令,所述指令由所述处理器加载并执行以实现权利要求1至权利要求7任一项所述的实现HTTP代理的方法中所执行的步骤。
10.一种计算机可读存储介质,其特征在于,所述存储介质中存储有至少一条计算机指令,所述指令由处理器加载并执行以实现权利要求1至权利要求7任一项所述的实现HTTP代理的方法中所执行的步骤。
CN202011440559.8A 2020-12-07 2020-12-07 一种实现http代理的方法、装置、设备及存储介质 Pending CN112653732A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202011440559.8A CN112653732A (zh) 2020-12-07 2020-12-07 一种实现http代理的方法、装置、设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202011440559.8A CN112653732A (zh) 2020-12-07 2020-12-07 一种实现http代理的方法、装置、设备及存储介质

Publications (1)

Publication Number Publication Date
CN112653732A true CN112653732A (zh) 2021-04-13

Family

ID=75350768

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202011440559.8A Pending CN112653732A (zh) 2020-12-07 2020-12-07 一种实现http代理的方法、装置、设备及存储介质

Country Status (1)

Country Link
CN (1) CN112653732A (zh)

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5673322A (en) * 1996-03-22 1997-09-30 Bell Communications Research, Inc. System and method for providing protocol translation and filtering to access the world wide web from wireless or low-bandwidth networks
EP0935193A2 (en) * 1998-02-06 1999-08-11 Hewlett-Packard Company World wide web agent
US20110202589A1 (en) * 2010-02-15 2011-08-18 Openwave Systems Inc. Scripting/proxy systems, methods and circuit arrangements
US8543726B1 (en) * 2005-04-08 2013-09-24 Citrix Systems, Inc. Web relay
CN103944992A (zh) * 2014-04-25 2014-07-23 厦门享游网络科技有限公司 一种在ios上加速http的方法
CN108243143A (zh) * 2016-12-23 2018-07-03 北京明朝万达科技股份有限公司 一种基于web代理的网闸穿透方法及系统

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5673322A (en) * 1996-03-22 1997-09-30 Bell Communications Research, Inc. System and method for providing protocol translation and filtering to access the world wide web from wireless or low-bandwidth networks
EP0935193A2 (en) * 1998-02-06 1999-08-11 Hewlett-Packard Company World wide web agent
US8543726B1 (en) * 2005-04-08 2013-09-24 Citrix Systems, Inc. Web relay
US20110202589A1 (en) * 2010-02-15 2011-08-18 Openwave Systems Inc. Scripting/proxy systems, methods and circuit arrangements
CN103944992A (zh) * 2014-04-25 2014-07-23 厦门享游网络科技有限公司 一种在ios上加速http的方法
CN108243143A (zh) * 2016-12-23 2018-07-03 北京明朝万达科技股份有限公司 一种基于web代理的网闸穿透方法及系统

Similar Documents

Publication Publication Date Title
CN109067914B (zh) Web服务的代理方法、装置、设备及存储介质
CN108200165B (zh) 请求传输系统、方法、装置及存储介质
JP3777302B2 (ja) 通信振り分け制御装置、および通信振り分けプログラムを記憶した記憶媒体
KR102036662B1 (ko) 네트워크 시스템에서 웹 접속 장치 및 방법
US20150295785A1 (en) Resource Subscription Method and Device
US8078684B2 (en) Accessing web services
US10382521B2 (en) Gateway that enables a browser-based application to communicate with a server-side application using a non-browser-compatible protocol
US10367894B2 (en) Information processing apparatus, method for controlling the same, non-transitory computer-readable storage medium, and information processing system
CN112104744B (zh) 流量代理方法、服务器及存储介质
JP2023542398A (ja) データ処理方法、装置、関連機器及び記憶媒体
US10158587B2 (en) Communication between a web application instance connected to a connection server and a calling entity other than said connection server
US20140379932A1 (en) Setting up communication between a web application and a terminal
EP3226483A1 (en) Remote service for standard to native messages translation in a lan
US20070130312A1 (en) Web service provision apparatus and method and web service request apparatus and method
US20140068001A1 (en) Intermediate proxy server, communication method, and communication system based on http multi-level proxy
CN115174562B (zh) 一种远程协助的通信方法及系统
CN112653732A (zh) 一种实现http代理的方法、装置、设备及存储介质
CN114205149B (zh) 网络通信方法及装置
CN113285920B (zh) 业务访问方法、装置、设备及存储介质
CN111611052B (zh) 在网页中与桌面应用交互的方法
CN114124935A (zh) Ftp服务的实现方法、系统、设备及存储介质
CN114390095A (zh) 远端设备控制方法以及物联网设备管理平台、系统
EP1726145B1 (en) Method and apparatus for efficiently transferring data within a telecommunications network
AU2018373682A1 (en) Method for remote management of a device connected to a residential gateway
CN117938819A (zh) 基于网关媒体代理的WebRTC通信方法及相关设备

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20210413