CN109618016A - 一种dns请求的发送处理方法、相关方法及相关装置 - Google Patents
一种dns请求的发送处理方法、相关方法及相关装置 Download PDFInfo
- Publication number
- CN109618016A CN109618016A CN201811505022.8A CN201811505022A CN109618016A CN 109618016 A CN109618016 A CN 109618016A CN 201811505022 A CN201811505022 A CN 201811505022A CN 109618016 A CN109618016 A CN 109618016A
- Authority
- CN
- China
- Prior art keywords
- request
- httpdns
- dns
- address
- dns request
- 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.)
- Granted
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L61/00—Network arrangements, protocols or services for addressing or naming
- H04L61/45—Network directories; Name-to-address mapping
- H04L61/4505—Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols
- H04L61/4511—Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols using domain name system [DNS]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/60—Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer And Data Communications (AREA)
Abstract
本发明公开了一种DNS请求的发送处理方法,方法包括:当各个应用程序发送DNS请求时,嵌入式系统对各个应用程序发送的DNS请求进行拦截,获取到DNS请求;根据Http协议对DNS请求进行转换,得到HttpDNS请求;将HttpDNS请求发送至HttpDNS服务器,以便当HttpDNS服务器中存在HttpDNS请求对应的IP地址时,HttpDNS服务器将IP地址发送至嵌入式系统。本发明还公开了一种DNS请求的处理方法、嵌入式设备、HttpDNS服务器、嵌入式系统、DNS请求处理系统以及计算机可读存储介质。本发明通过拦截DNS请求后统一进行转换,再向HttpDNS服务器进行请求。
Description
技术领域
本申请涉及计算机技术领域,尤其涉及一种DNS请求的发送处理方法、DNS请求的处理方法、嵌入式设备、HttpDNS服务器、嵌入式系统、DNS请求处理系统以及计算机可读存储介质。
背景技术
随着信息技术的不断发展,在互联网中出现了多种多样的DNS请求方式。可以应对不同的技术环境,以便在不同的环境中以最适合的方式进行DNS请求。
现有技术中,当一个组织管理了大量的域名的情况下,通过传统的DNS请求方式会出现大量的域名调度异常问题和域名劫持的问题。为了解决DNS的请求问题会应用HttpDNS服务,进行DNS请求的客户端就可以绕过DNS服务器直接向特别的HttpDNS服务器或该组织专有的HttpDNS服务器通过Http的方式进行DNS请求,解决了域名调度异常问题以及域名的劫持问题。但是,现有的HttpDNS服务技术需要每个进行DNS请求的应用程序自行向对应的HttpDNS服务器进行请求,当将该现有技术应用在arm-linux系统中时,每个应用程序单独的实现HttpDNS的DNS请求方式,会加大嵌入式系统整体的工作量,占用更多的硬件资源,降低性能利用率。
因此,如何当进行HttpDNS请求时降低占用的硬件资源,提高性能利用率是本领域技术人员关注的重点问题。
发明内容
本申请的目的是提供一种DNS请求的发送处理方法、DNS请求的处理方法、嵌入式设备、HttpDNS服务器、嵌入式系统、DNS请求处理系统以及计算机可读存储介质,旨在解决DNS请求的发送处理问题。
为实现上述目的,本发明提供一种DNS请求的发送处理方法,所述方法包括:
当各个应用程序发送DNS请求时,嵌入式系统对所述各个应用程序发送的DNS请求进行拦截,获取到所述DNS请求;
根据Http协议对所述DNS请求进行转换,得到HttpDNS请求;
将所述HttpDNS请求发送至HttpDNS服务器,以便当所述HttpDNS服务器中存在所述HttpDNS请求对应的IP地址时,所述HttpDNS服务器将所述IP地址发送至所述嵌入式系统。
可选的,在所述根据Http协议对所述DNS请求进行转换之前,还包括:
所述嵌入式系统根据所述DNS请求判断本地缓存中是否存在对应的IP地址;
若是,则向所述DNS请求对应的应用程序发送所述IP地址;
若否,则执行所述根据Http协议对所述DNS请求进行转换的步骤。
可选的,在所述根据Http协议对所述DNS请求进行转换之前,还包括:
所述嵌入式系统将所述DNS请求发送至DNS服务器,以便所述DNS服务器当对应的IP地址存在时,将所述IP地址发送至所述嵌入式系统,当对应的IP地址不存在时,将请求失败信息发送至所述嵌入式系统;
当接收到所述请求失败信息时,执行所述根据Http协议对所述DNS请求进行转换的步骤。
可选的,所述方法还包括:
当所述HttpDNS服务器中不存在所述HttpDNS对应的IP地址时,所述HttpDNS服务器将请求失败信息发送至所述嵌入式系统。
为实现上述目的,本发明进一步提供一种DNS请求的处理方法,包括:
HttpDNS服务器接收到嵌入式系统发送的HttpDNS请求,根据所述HttpDNS请求判断对应的IP地址是否存在;其中,所述HttpDNS请求为所述嵌入式系统对从各个应用程序拦截到的DNS请求进行转换得到的;
若是,则向所述嵌入式系统发送所述IP地址;
若否,则向所述嵌入式系统发送请求失败信息。
为实现上述目的,本发明进一步提供一种嵌入式设备,所述嵌入式设备包括存储器、处理器以及总线,所述存储器上存储有可在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如上所述的发送处理方法。
为实现上述目的,本发明进一步提供一种HttpDNS服务器,所述HttpDNS服务器包括存储器、处理器以及总线,所述存储器上存储有可在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如上所述的处理方法。
为实现上述目的,本发明进一步提供一种嵌入式系统,所述系统包括:
DNS请求拦截单元,用于当各个应用程序发送DNS请求时,对所述各个应用程序发送的DNS请求进行拦截,获取到所述DNS请求;
DNS请求转换单元,用于根据Http协议对所述DNS请求进行转换,得到HttpDNS请求;
HttpDNS请求单元,用于将所述HttpDNS请求发送至HttpDNS服务器,以便当所述HttpDNS服务器中存在所述HttpDNS请求对应的IP地址时,所述HttpDNS服务器将所述IP地址发送至所述嵌入式系统。
为实现上述目的,本发明进一步提供一种DNS请求处理系统,所述系统包括:
请求接收单元,用于接收到嵌入式系统发送的HttpDNS请求,根据所述HttpDNS请求判断对应的IP地址是否存在;其中,所述HttpDNS请求为所述嵌入式系统对从各个应用程序拦截到的DNS请求进行转换得到的;
IP地址返回单元,用于当对应的IP地址存在时,向所述嵌入式系统发送所述IP地址;
请求失败单元,用于当对应的IP地址不存在时,向所述嵌入式系统发送请求失败信息。
为实现上述目的,本发明进一步提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序可被一个或者多个处理器执行,以实现如上所述的发送处理方法或如上所述的处理方法。
本发明通过当每个应用程序发正常的DNS请求时,进行拦截并获取该DNS请求,然后统一对获取到的DNS请求进行Http协议的转换得到HttpDNS请求,再将该HttpDNS请求发送至HttpDNS服务器中,实现了进行HttpDNS请求,并且每个应用程序自身不需要实现HttpDNS请求,只需要按照原来的方式正常发送DNS请求即可,避免了对每个应用程序的DNS请求方式进行改动,降低了嵌入式系统整体的工作量,由于多个应用程序只需对应一个转换过程,降低了占用的硬件资源,提高了性能利用率。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
图1为本发明第一实施例的流程示意图;
图2为本发明第二实施例的流程示意图;
图3为本发明第三实施例的流程示意图;
图4为本发明第五实施例的流程示意图;
图5为本发明第一实施例揭露的嵌入式设备的内部结构示意图;
图6为本发明第五实施例揭露的HttpDNS服务器的内部结构示意图;
图7为本发明第六实施例的结构示意图;
图8为本发明第七实施例的结构示意图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅用以解释本发明,并不用于限定本发明。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本申请的说明书和权利要求书及上述附图中的术语“第一”、“第二”、“第三”、“第四”等(如果存在)是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的实施例能够以除了在这里图示或描述的内容以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
需要说明的是,在本发明中涉及“第一”、“第二”等的描述仅用于描述目的,而不能理解为指示或暗示其相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或者隐含地包括至少一个该特征。另外,各个实施例之间的技术方案可以相互结合,但是必须是以本领域普通技术人员能够实现为基础,当技术方案的结合出现相互矛盾或无法实现时应当认为这种技术方案的结合不存在,也不在本发明要求的保护范围之内。
现有技术中,当一个组织管理了大量的域名的情况下,通过传统的DNS请求方式会出现大量的域名调度异常问题和域名劫持的问题。为了解决DNS的请求问题会应用HttpDNS服务,进行DNS请求的客户端就可以绕过DNS服务器直接向特别的HttpDNS服务器或该组织专有的HttpDNS服务器通过Http的方式进行DNS请求,解决了域名调度异常问题以及域名的劫持问题。但是,现有的HttpDNS服务技术需要每个进行DNS请求的应用程序自行向对应的HttpDNS服务器进行请求,当将该现有技术应用在arm-linux系统中时,每个应用程序单独的实现HttpDNS的DNS请求方式,会加大嵌入式系统整体的工作量,占用更多的硬件资源,降低性能利用率。
因此,本发明实施例提供一种DNS请求的处理方法,通过当每个应用程序发正常的DNS请求时,进行拦截并获取该DNS请求,然后统一对获取到的DNS请求进行Http协议的转换得到HttpDNS请求,再将该HttpDNS请求发送至HttpDNS服务器中,实现了进行HttpDNS请求,并且每个应用程序自身不需要实现HttpDNS请求,只需要按照原来的方式正常发送DNS请求即可,避免了对每个应用程序的DNS请求方式进行改动,降低了嵌入式系统整体的工作量,由于多个应用程序只需对应一个转换过程,降低了占用的硬件资源,提高了性能利用率。
参照图1,图1为本发明第一实施例的流程示意图。
在第一实施例中,该方法可以包括:
S101,当各个应用程序发送DNS请求时,嵌入式系统对各个应用程序发送的DNS请求进行拦截,获取到DNS请求;
本步骤旨在将本来向DNS服务器发送的DNS请求进行拦截,也就是避免各个应用程序自身进行DNS请求处理,也就避免了每个应用程序自身进行HttpDNS服务请求。本实施例中的过程就相当于是DNS请求的统一代理,通过该统一代理,就可以实现各种各样的DNS请求服务,每个应用程序只需要在不进行任何改动的情况下发出DNS请求即可。
对于应用程序而言只需要按照正常步骤向外发送DNS请求即可,此时运行在嵌入式系统中的统一代理,也就是嵌入式系统在当各个应用程序发送DNS请求时,对每个DNS请求进行拦截获取即可,避免了应用程序自身对DNS请求进行处理,并且还获取到了该DNS请求。
其中,进行的拦截获取主要就是拦截应用程序发送的DNS请求,并获取所发送的DNS请求。由于该DNS请求容易被DNS协议所禁止而无法获取到对应的IP地址,还容易出现DNS请求被劫持而得到错误的IP地址,因此本步骤中阻断该DNS请求向外进行发送,可以避免出现上述问题。
其中,DNS(Domain Name System,域名系统),是万维网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过域名,最终得到该域名对应的IP地址的过程叫做域名解析。
S102,根据Http协议对DNS请求进行转换,得到HttpDNS请求;
在S101的基础上,本步骤旨在对DNS请求进行转换,以便该DNS请求符合HttpDNS服务的要求,即转换成HttpDNS请求。
一般的计算机设备在应用DNS服务时,是将域名发送至对应的DNS服务器,以便对应的DNS服务器向其返回对应的IP地址,该计算机设备再根据该IP地址进行网络请求。因此,DNS请求是就是以DNS协议向DNS服务器发送的网络请求,其符合DNS协议的规范,DNS服务器可以对其进行解析处理。
而HTTPDNS服务是利用Http(HyperText Transfer Protocol超文本传输协议)协议与DNS服务器交互,代替了传统的基于UDP(User Datagram Protocol用户数据报协议)协议与DNS服务器的交互形式,绕开了运营商的Local DNS(本地域名系统)服务器,有效防止了域名劫持,提高域名解析效率。
可见,当进行HttpDNS服务请求时,需要将原生的DNS请求转换为基于Http协议的HttpDNS请求。进而,本步骤中为了提高嵌入式系统进行NDS服务时的正确率和解析效率,将各个应用程序发送的DNS请求进行转换,得到对应的HttpDNS请求,以便可以向HttpDNS服务器发送合适的请求数据。
其中,Http协议是互联网上应用最为广泛的一种网络协议。其请求报文格式包括请求行、通用信息头、请求头、实体头以及报文主体。
一般的DNS请求是直接向DNS服务器发送包含域名信息的报文,例如,请求www.qq.com的IP地址时,直接向DNS服务器发送包括www.qq.com的报文。当使用HttpDNS服务进行DNS请求时,则需要将其转换为Http协议的HttpDNS请求。例如,根据Http协议可以将上述的DNS请求转换为Http://203.107.1.1/d?host=www.qq.com,将其发送至对应的HttpDNS服务器后,就可以进行相应的IP地址的查找处理,得到IP地址或请求失败信息。
S103,将HttpDNS请求发送至HttpDNS服务器,以便当HttpDNS服务器中存在HttpDNS请求对应的IP地址时,HttpDNS服务器将IP地址发送至嵌入式系统。
在S102的基础上,本步骤旨在将转换得到的HttpDNS请求发送至HttpDNS服务器中,以便HttpDNS服务器对该HttpDNS请求进行处理,并将相应的处理结果返回至嵌入式系统。
具体的,当HttpDNS服务器接收到HttpDNS请求时,会根据该HttpDNS请求进行对应的IP地址的查找,也就是判断HttpDNS服务器中是否存在对应的IP地址,当存在时,也就是查找到对应的IP地址,即将该IP地址发送至嵌入式系统,当不存在时,也就是没有查找到对应的IP地址,向该嵌入式系统发送请求失败信息。
可选的,本实施例还可以包括:
当HttpDNS服务器中不存在HttpDNS对应的IP地址时,HttpDNS服务器将请求失败信息发送至嵌入式系统。
本可选方案也就是说明当HttpDNS服务器查找不到对应的IP地址时,向嵌入式系统发送请求失败信息,以便嵌入式系统无论在什么情况下都可以知道HttpDNS请求的结果。
可见,本实施例通过当每个应用程序发正常的DNS请求时,进行拦截并获取该DNS请求,然后统一对获取到的DNS请求进行Http协议的转换得到HttpDNS请求,再将该HttpDNS请求发送至HttpDNS服务器中,实现了进行HttpDNS请求,并且每个应用程序自身不需要实现HttpDNS请求,只需要按照原来的方式正常发送DNS请求即可,避免了对每个应用程序的DNS请求方式进行改动,降低了嵌入式系统整体的工作量,由于多个应用程序只需对应一个转换过程,降低了占用的硬件资源,提高了性能利用率。
在第一实施例的基础上,本实施例主要是对第一实施例在进行DNS请求转换之前添加可选的DNS请求处理方式,可以提高本地缓存的利用率,降低DNS请求时的网络资源消耗,提高获取IP地址的效率。其他部分与第一实施例大体相同,相同部分可以参考上一实施例,在此不做赘述。
参照图2,图2为本发明第二实施例的流程示意图。
本第二实施例中,该方法可以包括:
S201,当各个应用程序发送DNS请求时,嵌入式系统对各个应用程序发送的DNS请求进行拦截,获取到DNS请求;
S202,嵌入式系统根据DNS请求判断本地缓存中是否存在对应的IP地址;若是,则执行S203;若否,则执行S204;
S203,向DNS请求对应的应用程序发送IP地址;
S204,根据Http协议对DNS请求进行转换,得到HttpDNS请求;
S205,将HttpDNS请求发送至HttpDNS服务器,以便当HttpDNS服务器中存在HttpDNS请求对应的IP地址时,HttpDNS服务器将IP地址发送至嵌入式系统。
本实施例主要是在根据Http协议对DNS请求进行转换之前,在本地缓存中查找是否已经存在对应的IP地址,如果存在就可以直接获取该IP地址进行使用,而不用再次向HttpDNS服务器发送HttpDNS请求,节约了网络资源,当本地缓存已存在IP地址的情况下提高了IP地址的获取效率。
在第一实施例的基础上,本实施例主要是对第一实施例在进行DNS请求转换之前添加可选的DNS请求处理方式,可以提高获取IP地址的准确率。其他部分与第一实施例大体相同,相同部分可以参考上一实施例,在此不做赘述。
参照图3,图3为本发明第三实施例的流程示意图。
本第三实施例中,该方法可以包括:
S301,当各个应用程序发送DNS请求时,嵌入式系统对各个应用程序发送的DNS请求进行拦截,获取到DNS请求;
S302,嵌入式系统将DNS请求发送至DNS服务器,以便DNS服务器当对应的IP地址存在时,将IP地址发送至嵌入式系统,当对应的IP地址不存在时,将请求失败信息发送至嵌入式系统;
S303,当接收到请求失败信息时,根据Http协议对DNS请求进行转换,得到HttpDNS请求;
S304,将HttpDNS请求发送至HttpDNS服务器,以便当HttpDNS服务器中存在HttpDNS请求对应的IP地址时,HttpDNS服务器将IP地址发送至嵌入式系统。
本实施例主要是在对DNS请求进行转换之前,将DNS请求发送至对应的DNS服务器以便先通过DNS服务器获取到对应的IP地址,如果出现了请求失败等问题,那么再向HttpDNS服务器进行DNS服务请求,提高了嵌入式系统进行DNS请求时的可靠性。
在以上所有实施例的基础上,本实施例还提供一种更加具体的DNS请求的发送处理方法。
本第四实施例中,该方法可以包括:
步骤1,当各个应用程序发送DNS请求时,本地DNS服务对各个应用程序发送的DNS请求进行拦截,获取到DNS请求;
步骤2,本地DNS服务根据该DNS请求查找对应域名的IP地址;
步骤3,本地DNS服务查找缓存中的域名IP地址是否存在;如果存在则返回该域名的IP地址;如果本地缓存没有该域名的IP地址,则本地DNS服务向DNS服务器请求域名的IP地址;
步骤4,DNS服务器查询域名的IP地址;如果查找到,则返回域名的IP地址;如果不存在,则返回域名的IP地址请求失败结果;
步骤5,当获取到IP地址,则本地DNS服务把该IP地址返回应用程序,完成DNS请求;如果本地DNS服务从DNS服务器获取IP地址失败,则向HttpDNS服务器请求域名IP地址;
步骤6,HttpDNS服务器查询域名IP地址;如果查找到,则返回域名的IP地址;如果不存在,则返回域名IP地址请求失败结果;
步骤7,本地DNS服务把获取IP地址或者失败结果返回给应用程序;
可见,本实施例通过当每个应用程序发正常的DNS请求时,进行拦截并获取该DNS请求,然后统一对获取到的DNS请求进行Http协议的转换得到HttpDNS请求,再将该HttpDNS请求发送至HttpDNS服务器中,实现了进行HttpDNS请求,并且每个应用程序自身不需要实现HttpDNS请求,只需要按照原来的方式正常发送DNS请求即可,避免了对每个应用程序的DNS请求方式进行改动,降低了嵌入式系统整体的工作量,由于多个应用程序只需对应一个转换过程,降低了占用的硬件资源,提高了性能利用率。
在以上所有实施例的基础上,本实施例主要是在HttpDNS服务器的角度,提供一种DNS请求的处理方法。通过该方法可以避免DNS劫持问题,提高DNS请求的准确率,提高域名解析的效率。
参考图4,图4为本发明第五实施例的流程示意图。
本第五实施例中,该方法可以包括:
S401,HttpDNS服务器接收到嵌入式系统发送的HttpDNS请求,根据HttpDNS请求判断对应的IP地址是否存在;其中,HttpDNS请求为嵌入式系统对从各个应用程序拦截到的DNS请求进行转换得到的;若是,则执行S402;若否,则执行S403;
S402,向嵌入式系统发送IP地址;
S403,向嵌入式系统发送请求失败信息。
本实施例主要是说明HttpDNS服务器对HttpDNS请求进行处理的过程,其中,HttpDNS请求是嵌入式系统对应用程序的DNS请求进行拦截后,再进行转换后得到的,使得嵌入式系统中的应用程序可以避免实现HttpDNS请求,提高了嵌入式系统获取IP地址的效率。
下面对本申请实施例提供的一种嵌入式设备进行介绍,下文描述的一种嵌入式设备与上文描述的一种DNS请求的发送处理方法可相互对应参照。
参照图5,图5为本发明第一实施例揭露的嵌入式设备的内部结构示意图。
在本实施例中,嵌入式设备1可以是PC(Personal Computer,个人电脑),也可以是智能手机、平板电脑、掌上电脑、便携计算机、智能路由器、矿机、网络存储设备终端设备。
该装置1可以是组成CDN网络或者区块链网络的节点。
该嵌入式设备1可以包括存储器11、处理器12和总线13。
其中,存储器11至少包括一种类型的可读存储介质,可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、磁性存储器、磁盘、光盘等。存储器11在一些实施例中可以是嵌入式设备1的内部存储单元,例如该嵌入式设备1的硬盘。存储器11在另一些实施例中也可以是嵌入式设备1的外部存储设备,例如嵌入式设备1上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,存储器11还可以既包括嵌入式设备1的内部存储单元也包括外部存储设备。存储器11不仅可以用于存储安装于嵌入式设备1的应用软件及各类数据,例如DNS请求的发送处理程序的代码等,还可以用于暂时地存储已经输出或者将要输出的数据。
处理器12在一些实施例中可以是一中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器或其他数据处理芯片,用于运行存储器11中存储的程序代码或处理数据,例如执行DNS请求的发送处理程序等。
该总线13可以是外设部件互连标准(peripheral component interconnect,简称PCI)总线或扩展工业标准结构(extended industry standard architecture,简称EISA)总线等。该总线可以分为地址总线、数据总线、控制总线等。为便于表示,图5中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
进一步地,嵌入式设备还可以包括网络接口,网络接口可选的可以包括有线接口和/或无线接口(如WI-FI接口、蓝牙接口等),通常用于在该装置1与其他电子设备之间建立通信连接。
可选地,该装置1还可以包括用户接口,用户接口可以包括显示器(Display)、输入单元比如键盘(Keyboard),可选的用户接口还可以包括标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是LED显示器、液晶显示器、触控式液晶显示器以及OLED(Organic Light-Emitting Diode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在嵌入式设备1中处理的信息以及用于显示可视化的用户界面。
图5仅示出了具有组件11-13以及DNS请求的发送处理程序的嵌入式设备1,本领域技术人员可以理解的是,图5示出的结构并不构成对嵌入式设备1的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。
下面对本申请实施例提供的一种HttpDNS服务器进行介绍,下文描述的一种HttpDNS服务器与上文描述的一种DNS请求的处理方法可相互对应参照。
参照图6,图6为本发明第五实施例揭露的HttpDNS服务器的内部结构示意图。
在本实施例中,HttpDNS服务器2可以是PC(Personal Computer,个人电脑),也可以是智能手机、平板电脑、掌上电脑、便携计算机、智能路由器、矿机、网络存储设备终端设备。
该装置2可以是组成CDN网络或者区块链网络的节点。
该HttpDNS服务器2可以包括存储器21、处理器22和总线23。
其中,存储器22至少包括一种类型的可读存储介质,可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、磁性存储器、磁盘、光盘等。存储器21在一些实施例中可以是HttpDNS服务器2的内部存储单元,例如该HttpDNS服务器2的硬盘。存储器21在另一些实施例中也可以是HttpDNS服务器2的外部存储设备,例如HttpDNS服务器2上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,存储器21还可以既包括HttpDNS服务器2的内部存储单元也包括外部存储设备。存储器21不仅可以用于存储安装于HttpDNS服务器2的应用软件及各类数据,例如DNS请求的处理程序的代码等,还可以用于暂时地存储已经输出或者将要输出的数据。
处理器22在一些实施例中可以是一中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器或其他数据处理芯片,用于运行存储器21中存储的程序代码或处理数据,例如执行DNS请求的处理程序等。
该总线23可以是外设部件互连标准(peripheral component interconnect,简称PCI)总线或扩展工业标准结构(extended industry standard architecture,简称EISA)总线等。该总线可以分为地址总线、数据总线、控制总线等。为便于表示,图6中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
进一步地,HttpDNS服务器还可以包括网络接口,网络接口可选的可以包括有线接口和/或无线接口(如WI-FI接口、蓝牙接口等),通常用于在该装置2与其他电子设备之间建立通信连接。
可选地,该装置2还可以包括用户接口,用户接口可以包括显示器(Display)、输入单元比如键盘(Keyboard),可选的用户接口还可以包括标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是LED显示器、液晶显示器、触控式液晶显示器以及OLED(Organic Light-Emitting Diode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在HttpDNS服务器2中处理的信息以及用于显示可视化的用户界面。
图6仅示出了具有组件21-23以及DNS请求的处理程序的HttpDNS服务器2,本领域技术人员可以理解的是,图6示出的结构并不构成对HttpDNS服务器2的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。
本发明实施例还提供一种嵌入式系统。
参照图7,图7为本发明第六实施例的结构示意图。
第六实施例中,该系统可以包括:
DNS请求拦截单元110,用于当各个应用程序发送DNS请求时,对各个应用程序发送的DNS请求进行拦截,获取到DNS请求;
DNS请求转换单元120,用于根据Http协议对DNS请求进行转换,得到HttpDNS请求;
HttpDNS请求单元130,用于将HttpDNS请求发送至HttpDNS服务器,以便当HttpDNS服务器中存在HttpDNS请求对应的IP地址时,HttpDNS服务器将IP地址发送至嵌入式系统。
本发明实施例还提供一种DNS请求处理系统。
参照图8,图8为本发明第七实施例的结构示意图。
第七实施例中,该系统可以包括:
请求接收单元210,用于接收到嵌入式系统发送的HttpDNS请求,根据HttpDNS请求判断对应的IP地址是否存在;其中,HttpDNS请求为嵌入式系统对从各个应用程序拦截到的DNS请求进行转换得到的;
IP地址返回单元220,用于当对应的IP地址存在时,向嵌入式系统发送IP地址;
请求失败单元230,用于当对应的IP地址不存在时,向嵌入式系统发送请求失败信息。
本发明实施例还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序可被一个或者多个处理器执行,以实现如以上实施例所述的发送处理方法或如以上实施例所述的处理方法。
本发明实施例还提供一种计算机程序产品,包括计算机指令,当其在计算机上运行时,使得计算机可以执行上述实施例所述的DNS请求的发送处理方法或DNS请求的处理方法。
在上述实施例中,可以全部或部分地通过软件、硬件、固件或者其任意组合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。
所述计算机程序产品包括一个或多个计算机指令。在计算机上加载和执行所述计算机程序指令时,全部或部分地产生按照本发明实施例所述的流程或功能。所述计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。所述计算机指令可以存储在计算机可读存储介质中,或者从一个计算机可读存储介质向另一计算机可读存储介质传输,例如,所述计算机指令可以从一个网站站点、计算机、服务器或数据中心通过有线(例如同轴电缆、光纤、数字用户线(DSL))或无线(例如红外、无线、微波等)方式向另一个网站站点、计算机、服务器或数据中心进行传输。所述计算机可读存储介质可以是计算机能够存储的任何可用介质或者是包含一个或多个可用介质集成的服务器、数据中心等数据存储设备。所述可用介质可以是磁性介质,(例如,软盘、硬盘、磁带)、光介质(例如,DVD)、或者半导体介质(例如固态硬盘Solid State Disk(SSD))等
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在本申请所提供的几个实施例中,应该理解到,所揭露的系统,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-OnlyMemory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
需要说明的是,上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。并且本文中的术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、装置、物品或者方法不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、装置、物品或者方法所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、装置、物品或者方法中还存在另外的相同要素。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (10)
1.一种DNS请求的发送处理方法,其特征在于,所述方法包括:
当各个应用程序发送DNS请求时,嵌入式系统对所述各个应用程序发送的DNS请求进行拦截,获取到所述DNS请求;
根据Http协议对所述DNS请求进行转换,得到HttpDNS请求;
将所述HttpDNS请求发送至HttpDNS服务器,以便当所述HttpDNS服务器中存在所述HttpDNS请求对应的IP地址时,所述HttpDNS服务器将所述IP地址发送至所述嵌入式系统。
2.如权利要求1所述的发送处理方法,其特征在于,在所述根据Http协议对所述DNS请求进行转换之前,还包括:
所述嵌入式系统根据所述DNS请求判断本地缓存中是否存在对应的IP地址;
若是,则向所述DNS请求对应的应用程序发送所述IP地址;
若否,则执行所述根据Http协议对所述DNS请求进行转换的步骤。
3.如权利要求1所述的发送处理方法,其特征在于,在所述根据Http协议对所述DNS请求进行转换之前,还包括:
所述嵌入式系统将所述DNS请求发送至DNS服务器,以便所述DNS服务器当对应的IP地址存在时,将所述IP地址发送至所述嵌入式系统,当对应的IP地址不存在时,将请求失败信息发送至所述嵌入式系统;
当接收到所述请求失败信息时,执行所述根据Http协议对所述DNS请求进行转换的步骤。
4.如权利要求1至3任一项所述的发送处理方法,其特征在于,所述方法还包括:
当所述HttpDNS服务器中不存在所述HttpDNS对应的IP地址时,所述HttpDNS服务器将请求失败信息发送至所述嵌入式系统。
5.一种DNS请求的处理方法,其特征在于,包括:
HttpDNS服务器接收到嵌入式系统发送的HttpDNS请求,根据所述HttpDNS请求判断对应的IP地址是否存在;其中,所述HttpDNS请求为所述嵌入式系统对从各个应用程序拦截到的DNS请求进行转换得到的;
若是,则向所述嵌入式系统发送所述IP地址;
若否,则向所述嵌入式系统发送请求失败信息。
6.一种嵌入式设备,其特征在于,所述嵌入式设备包括存储器、处理器以及总线,所述存储器上存储有可在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如权利要求1至4任一项所述的发送处理方法。
7.一种HttpDNS服务器,其特征在于,所述HttpDNS服务器包括存储器、处理器以及总线,所述存储器上存储有可在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如权利要求5所述的处理方法。
8.一种嵌入式系统,其特征在于,所述系统包括:
DNS请求拦截单元,用于当各个应用程序发送DNS请求时,对所述各个应用程序发送的DNS请求进行拦截,获取到所述DNS请求;
DNS请求转换单元,用于根据Http协议对所述DNS请求进行转换,得到HttpDNS请求;
HttpDNS请求单元,用于将所述HttpDNS请求发送至HttpDNS服务器,以便当所述HttpDNS服务器中存在所述HttpDNS请求对应的IP地址时,所述HttpDNS服务器将所述IP地址发送至所述嵌入式系统。
9.一种DNS请求处理系统,其特征在于,所述系统包括:
请求接收单元,用于接收到嵌入式系统发送的HttpDNS请求,根据所述HttpDNS请求判断对应的IP地址是否存在;其中,所述HttpDNS请求为所述嵌入式系统对从各个应用程序拦截到的DNS请求进行转换得到的;
IP地址返回单元,用于当对应的IP地址存在时,向所述嵌入式系统发送所述IP地址;
请求失败单元,用于当对应的IP地址不存在时,向所述嵌入式系统发送请求失败信息。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序可被一个或者多个处理器执行,以实现如权利要求1至4中任一项所述的发送处理方法或如权利要求5所述的处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811505022.8A CN109618016B (zh) | 2018-12-10 | 2018-12-10 | 一种dns请求的发送处理方法、相关方法及相关装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811505022.8A CN109618016B (zh) | 2018-12-10 | 2018-12-10 | 一种dns请求的发送处理方法、相关方法及相关装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109618016A true CN109618016A (zh) | 2019-04-12 |
CN109618016B CN109618016B (zh) | 2022-02-22 |
Family
ID=66008753
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811505022.8A Active CN109618016B (zh) | 2018-12-10 | 2018-12-10 | 一种dns请求的发送处理方法、相关方法及相关装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109618016B (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110336805A (zh) * | 2019-06-27 | 2019-10-15 | 维沃移动通信有限公司 | 网络访问管理方法和移动终端 |
Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101902508A (zh) * | 2010-08-17 | 2010-12-01 | 奇诺光瑞电子(深圳)有限公司 | 嵌入式终端取得网络地址的方法及系统 |
CN102790808A (zh) * | 2011-05-16 | 2012-11-21 | 奇智软件(北京)有限公司 | 一种域名解析方法和系统、一种客户端 |
CN103812956A (zh) * | 2012-11-14 | 2014-05-21 | 中国电信股份有限公司 | IPv4/IPv6应用转换方法、装置及智能移动终端 |
CN104168340A (zh) * | 2014-07-24 | 2014-11-26 | 深圳市腾讯计算机系统有限公司 | 域名解析的方法、服务器、终端及系统 |
CN104580192A (zh) * | 2014-12-31 | 2015-04-29 | 网宿科技股份有限公司 | 应用程序的网络访问请求的处理方法和装置 |
CN105260250A (zh) * | 2015-09-10 | 2016-01-20 | 烽火通信科技股份有限公司 | 一种Linux系统与Android系统的双系统通信装置 |
WO2016025827A1 (en) * | 2014-08-15 | 2016-02-18 | Interdigital Patent Holdings, Inc. | Edge caching of https content via certificate delegation |
CN106161669A (zh) * | 2015-04-28 | 2016-11-23 | 阿里巴巴集团控股有限公司 | 一种快速域名解析方法和系统、及其终端和服务器 |
CN106797410A (zh) * | 2016-12-23 | 2017-05-31 | 深圳前海达闼云端智能科技有限公司 | 域名解析方法和装置 |
CN107454058A (zh) * | 2017-06-29 | 2017-12-08 | 广州视源电子科技股份有限公司 | 一种数据发送方法、系统、可读存储介质及计算机设备 |
CN108063833A (zh) * | 2016-11-07 | 2018-05-22 | 中国移动通信有限公司研究院 | Http dns解析报文处理方法及装置 |
CN108881509A (zh) * | 2018-05-31 | 2018-11-23 | 网宿科技股份有限公司 | 一种基于httpdns的dns查询方法及装置 |
-
2018
- 2018-12-10 CN CN201811505022.8A patent/CN109618016B/zh active Active
Patent Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101902508A (zh) * | 2010-08-17 | 2010-12-01 | 奇诺光瑞电子(深圳)有限公司 | 嵌入式终端取得网络地址的方法及系统 |
CN102790808A (zh) * | 2011-05-16 | 2012-11-21 | 奇智软件(北京)有限公司 | 一种域名解析方法和系统、一种客户端 |
CN103812956A (zh) * | 2012-11-14 | 2014-05-21 | 中国电信股份有限公司 | IPv4/IPv6应用转换方法、装置及智能移动终端 |
CN104168340A (zh) * | 2014-07-24 | 2014-11-26 | 深圳市腾讯计算机系统有限公司 | 域名解析的方法、服务器、终端及系统 |
WO2016025827A1 (en) * | 2014-08-15 | 2016-02-18 | Interdigital Patent Holdings, Inc. | Edge caching of https content via certificate delegation |
CN104580192A (zh) * | 2014-12-31 | 2015-04-29 | 网宿科技股份有限公司 | 应用程序的网络访问请求的处理方法和装置 |
CN106161669A (zh) * | 2015-04-28 | 2016-11-23 | 阿里巴巴集团控股有限公司 | 一种快速域名解析方法和系统、及其终端和服务器 |
CN105260250A (zh) * | 2015-09-10 | 2016-01-20 | 烽火通信科技股份有限公司 | 一种Linux系统与Android系统的双系统通信装置 |
CN108063833A (zh) * | 2016-11-07 | 2018-05-22 | 中国移动通信有限公司研究院 | Http dns解析报文处理方法及装置 |
CN106797410A (zh) * | 2016-12-23 | 2017-05-31 | 深圳前海达闼云端智能科技有限公司 | 域名解析方法和装置 |
CN107454058A (zh) * | 2017-06-29 | 2017-12-08 | 广州视源电子科技股份有限公司 | 一种数据发送方法、系统、可读存储介质及计算机设备 |
CN108881509A (zh) * | 2018-05-31 | 2018-11-23 | 网宿科技股份有限公司 | 一种基于httpdns的dns查询方法及装置 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110336805A (zh) * | 2019-06-27 | 2019-10-15 | 维沃移动通信有限公司 | 网络访问管理方法和移动终端 |
Also Published As
Publication number | Publication date |
---|---|
CN109618016B (zh) | 2022-02-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111382421B (zh) | 一种业务访问控制方法、系统及电子设备和存储介质 | |
US10244058B2 (en) | Extending functionality of applications | |
CN103843004B (zh) | 装置定制白名单 | |
US8424026B1 (en) | Execution of applications distributed across a plurality of computing devices | |
US9183111B2 (en) | Methods and computer program products for collecting storage resource performance data using file system hooks | |
US8468541B2 (en) | Event driven sendfile | |
US20120204193A1 (en) | Methods and computer program products for monitoring system calls using safely removable system function table chaining | |
CN101630272B (zh) | 进程调度方法和系统 | |
CN110049059A (zh) | 一种外网设备与内网设备间通信方法及相关装置 | |
CN109062626A (zh) | Web页面组件与Native组件的交互方法、装置及设备 | |
US11575689B2 (en) | System, method, and computer program product for dynamically configuring a virtual environment for identifying unwanted data | |
CN109951562A (zh) | Nat穿透方法和系统、电子设备和存储介质 | |
CN109788051A (zh) | 基于分布式文件系统的网络资源传输方法及系统 | |
CN115668894A (zh) | 被配置为服务多个单页应用的服务工作器 | |
CN114205342A (zh) | 服务调试的路由方法、电子设备、介质及程序产品 | |
US20140052851A1 (en) | Systems and methods for discovering sources of online content | |
CN109905397A (zh) | 一种建立数据连接的方法及内网服务器 | |
CN109639801A (zh) | 数据节点分配及数据获取方法及系统 | |
CN109618016A (zh) | 一种dns请求的发送处理方法、相关方法及相关装置 | |
CN109032693A (zh) | 一种加载展示信息方法、装置、电子设备及可读存储介质 | |
CN114185592A (zh) | 多版本共存的目标项目访问方法、装置、设备及存储介质 | |
CN112910910B (zh) | Opcda协议报文处理方法、装置、设备以及存储介质 | |
CN111447282B (zh) | 用于确定传输路径的方法和装置 | |
EP3759603B1 (en) | In-line event handlers across domains | |
CN113625998A (zh) | 一种请求处理方法和装置 |
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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |