METHOD AND DEVICE FOR PROCESSING RESOURCE DESCRIPTION FILE AND FOR OBTAINING PAGE RESOURCE

Information

  • Patent Application
  • 20210397671
  • Publication Number
    20210397671
  • Date Filed
    January 17, 2019
    6 years ago
  • Date Published
    December 23, 2021
    3 years ago
Abstract
A method and a device for processing resource description file and for obtaining page resource are provided. The method for processing the resource description file includes: receiving the resource description file inserted with a monitoring script fed back by the node server; when the monitoring script is executed in the client terminal, monitoring a resource link generated by the client terminal in a process of parsing the resource description file, determining whether the resource link contains an external link, and if contains, rewriting the external link into an internal link, and replacing the corresponding external link in the resource link with the rewritten internal link; and writing the rewritten resource link into the resource description file, and according to the resource description file, obtaining page resource of the target page.
Description
FIELD OF THE DISCLOSURE

The present disclosure generally relates to the field of Internet technology and, more particularly, relates to a method and a device for processing resource description file and for obtaining page resource.


BACKGROUND

A website page often includes various resources, and these resources can include, e.g., a document, a script, a page style, and an image, etc. When a client terminal requests for loading a page, a page access request is often sent to a server, and then the server feeds back a resource description file to the client terminal in response to the page access request. The resource description file can include links to various resources in the page. In view of this, according to each link in the resource description file, the client terminal can obtain the corresponding resource.


To improve a loading speed of the page, a content delivery network (CDN) can be used to accelerate the page access request of the client terminal. However, an existing acceleration mode has a problem: only internal links in the page can be accelerated, while external links cannot be accelerated. The reasons include that the CDN often provides an acceleration service for the client terminal by redirecting a domain name system (DNS) of a domain name. Specifically, by redirecting the DNS of the page to an edge node of the CDN, the CDN can enable the client terminal to access the corresponding resource nearby. However, for the external link, the CDN cannot redirect the DNS of the external link, such that the external link cannot be accelerated through the CDN. In the process of parsing the resource description file, the client terminal is likely to introduce resource links, and such resource links are likely to include an external link. Because the external link cannot be accelerated through the CDN, the overall loading speed of the page will be substantially slow.


BRIEF SUMMARY OF THE DISCLOSURE

The purpose of the present disclosure is to provide a method and a device for processing resource description file and for obtaining page resource, which may improve a loading speed of a page.


One aspect of the present disclosure includes a method for processing resource description file. The method is applied to a client terminal, and comprises: sending an access request directed to a target page to a node server, and receiving the resource description file of the target page fed back by the node server, where the resource description file includes a monitoring script inserted by the node server; when the monitoring script is executed in the client terminal, monitoring a resource link generated by the client terminal in a process of parsing the resource description file, determining whether the resource link contains an external link, and if contains, rewriting the external link into an internal link, and replacing the corresponding external link in the resource link with the rewritten internal link; and writing the rewritten resource link into the resource description file, and according to the resource description file, obtaining page resource of the target page.


Another aspect of the present disclosure includes a client terminal. The client terminal comprises: a unit for acquiring a resource description file, configured to send an access request directed to a target page to a node server, and receive the resource description file of the target page fed back by the node server, where the resource description file includes a monitoring script inserted by the node server; a link rewriting unit, configured to when the monitoring script is executed in the client terminal, monitor a resource link generated by the client terminal in the process of parsing the resource description file, determine whether the resource link contains an external link, and if contains, rewrite the external link into an internal link, and replace the corresponding external link in the resource link with the rewritten internal link; and a writing unit, configured to write the rewritten resource link into the resource description file, and according to the resource description file, obtain page resource of the target page.


Another aspect of the present disclosure includes a client terminal. The client terminal comprises a memory and a processor, the memory is used to store a computer program, when the computer program is executed by the processor, the above method for processing resource description file is implemented.


Another aspect of the present disclosure includes a method for obtaining page resource. The method comprises: receiving a resource acquisition request directed to a target page and sent from a client terminal; determining whether the resource acquisition request contains a target link that complies with a link rewriting rule; if contains, extracting page address information from the target link, and parsing the page address information to a corresponding external link; and obtaining page resource corresponding to the external link obtained by parsing, and feeding back the page resource to the client terminal.


Another aspect of the present disclosure includes a node server. The node server comprises: a unit for receiving a resource acquisition request, configured to receive the resource acquisition request directed to a target page and sent from a client terminal; a link determining unit, configured to determine whether the resource acquisition request contains a target link that complies with a link rewriting rule; a unit for parsing page address information, configured to if contains, extract the page address information from the target link and parse the page address information to a corresponding external link; and a resource feedback unit, configured to obtain page resource corresponding to the external link obtained by parsing, and feed back the page resource to the client terminal.


Another aspect of the present disclosure includes a node server. The node server comprises a memory and a processor, the memory is used to store a computer program, when the computer program is executed by the processor, the above method for obtaining page resource is implemented.


It can be seen from the above that in the technical solution provided by the present disclosure, after sending the access request directed to the target page to the node server, the client terminal may receive the resource description file of the target page fed back by the node server. To determine whether the client terminal introduces an external link in the process of parsing the resource description file, the node server may insert a monitoring script into the fed back resource description file. When parsing the resource description file, the client terminal may execute the monitoring script. When executing the monitoring script, the resource link generated by the client terminal in the process of parsing the resource description file may be monitored, and it may be determined whether the resource link contains an external link. If the resource link contains the external link, the monitoring script may rewrite the external link into an internal link, and may use the rewritten internal link to replace the corresponding external link in the resource link. In view of this, if the client terminal introduces external links in the process of parsing the resource description file, these external links may be rewritten into internal links. Such rewritten internal links together with real internal links may be written into the resource description file.


Subsequently, the client terminal may initiate a resource acquisition request for each link in the resource description file one by one. Because the rewritten links in the resource description files are all internal links, such resource acquisition requests may be received by the node server. The node server may identify the link contained in the received resource acquisition request, and then may determine a target link carrying the specified resource path. The specified resource path may indicate that the target link is not originally an internal link, while is obtained by rewriting an external link. In view of this, for the target link, the node server may obtain the actual external link by parsing, may obtain the corresponding resource according to the external link obtained by parsing, and may feed back the resource to the client terminal. It can be seen that the technical solution provided by the present disclosure may ensure that, through a manner of rewriting the external link, in the resource acquisition request subsequently received by the node server, the links all are in the form of internal links, such that it may be ensured that the node server is capable of accelerating each link. Then, the node server may restore the rewritten internal link into an external link by identifying the specified resource path, and may obtain the resource corresponding to the external link. In view of this, both the internal link and the external link may be accelerated by the node server of the CDN, thereby improving the overall loading speed of the page.





BRIEF DESCRIPTION OF THE DRAWINGS

To more clearly illustrate the technical solutions in the disclosed embodiments of the present disclosure, drawings to be used in the description of the embodiments will be briefly described below. It is obvious that the drawings in the following description are certain embodiments of the present disclosure, and other drawings may be obtained by a person of ordinary skill in the art in view of the drawings provided without creative efforts.



FIG. 1 illustrates a step schematic diagram of a method for processing a resource description file consistent with an embodiment of the present disclosure;



FIG. 2 illustrates a flowchart of a method for processing a resource description file consistent with an embodiment of the present disclosure;



FIG. 3 illustrates a schematic diagram of a functional module of a client terminal consistent with an embodiment of the present disclosure;



FIG. 4 illustrates a schematic structural diagram of a client terminal consistent with an embodiment of the present disclosure;



FIG. 5 illustrates a step schematic diagram of a method for obtaining page resource consistent with an embodiment of the present disclosure; and



FIG. 6 illustrates an interaction schematic diagram of a method for obtaining page resource consistent with an embodiment of the present disclosure.





DETAILED DESCRIPTION

For clearer understanding of the aims, technical solutions and effects of the present disclosure, specific embodiments of the present disclosure are now described in detail with reference to the accompanying drawings.


The present disclosure provides a method for processing a resource description file. The method may be applied in a current CDN architecture. In the CDN architecture, a client terminal may be connected to an origin server through a CDN network. The client terminal may be a terminal device used by a user, or may be a software running in the terminal device. For example, the client terminal may be a browser in the terminal device. The origin server may be a service server storing various resources in a website page. The CDN network may include various node servers, and a node server may receive a page access request sent by the client terminal, and may process the page access request.


Specifically, referring to FIG. 1 and FIG. 2, an execution subject of the method for processing the resource description file may be the above-mentioned client terminal, and the method for processing the resource description file may include a plurality of following steps.


In S11: sending an access request directed to a target page to a node server, and receiving a resource description file of the target page fed back by the node server, where the resource description file may include a monitoring script inserted by the node server.


In the present embodiment, when a user wants to access the target page through the client terminal, the client terminal may initiate the access request directed to the target page. The access request may include a domain name of the target page. The access request may be received by a nearby node server, and then according to the domain name carried in the access request, the node server may forward the access request to an origin server corresponding to the domain name.


In the present embodiment, after receiving the access request, the origin server may identify the domain name contained therein, and may find a resource description file corresponding to the domain name. The resource description file may be an HTML document, and the HTML document may include resource links of various resources in the target page.


In the present embodiment, after receiving the resource description file fed back by the origin server, to determine whether the client terminal introduces a new resource link in the process of parsing the resource description file, the node server may insert a pre-edited monitoring script into the resource description file. Specifically, the monitoring script may be inserted into a head tag of the resource description file, and may be located before a first sub-element of the head tag. In view of this, when the client terminal starts to parse the resource description file, the monitoring script may be preferentially parsed, thereby ensuring that the monitoring script can be executed immediately.


In the present embodiment, after inserting the monitoring script into the resource description file, the node server may feed back the resource description file carrying the monitoring script to the client terminal.


In S13: when the monitoring script is executed in the client terminal, monitoring a resource link generated by the client terminal in the process of parsing the resource description file, and determining whether the resource link contains an external link, and if contains, rewriting the external link into an internal link, and replacing the corresponding external link in the resource link with the rewritten internal link.


In the present embodiment, when parsing the resource description file, because the monitoring script is located before the first sub-element of the head tag, the client terminal may preferentially execute the monitoring script. After the monitoring script is executed, the resource link generated by the client terminal in the process of parsing the resource description file may be monitored. In practical applications, the client terminal may have a plurality of ways to introduce a new resource link. For example, the new resource link may be introduced through original data writing functions ‘document.write’ and ‘document.writeIn’ in the browser. For another example, in another application example, a new tag may be created through an original tag creation function ‘document.createElement’ in the browser, and a new resource link may be introduced by creating a link under the new tag. For a different manner for introducing a resource link, the monitoring script may perform monitor using a corresponding monitoring strategy.


Specifically, for an application example of a data writing function, during the process of parsing the resource description file performed by the client terminal, the client terminal may call the above-mentioned original data writing function. Parameter in the data writing function may carry a new resource link. In view of this, the monitoring script may predefine a parameter interception function ‘docwrite’, and may create a data buffer. Then, during the process of parsing the resource description file performed by the client terminal, if the client terminal can call the above-mentioned original data writing function, it may indicate that the new resource link is likely to be introduced through the parameter in the data writing function. Therefore, the monitoring script may obtain the parameter in the data writing function through the parameter interception function, and may write the obtained parameter into the data buffer. Then, the monitoring script may identify the parameter in the data buffer to obtain the resource link contained therein. Specifically, the monitoring script may identify a link attribute identifier in the parameter in the data buffer, and the link attribute identifier may be, e.g., ‘src’ or ‘href’. After identifying the link attribute identifier contained in the parameter, the monitoring script may use the link represented by the link attribute identifier as the resource link generated by the client terminal in the process of parsing the resource description file. For example, the monitoring script may identify the ‘src’ attribute identifier in the data buffer, and the link represented by the ‘src’ attribute identifier may be as follows:

    • <script src=“https://www.123.com/1.js”></script>.
    • Then, ‘https://www.123.com/1.js’ may be used as the introduced resource link.


In an application example, after identifying the introduced resource link from the parameter in the data buffer, the monitoring script may further determine whether the resource link contains an external link. Specifically, an internal link and an external link may be distinguished through domain names thereof. If a current resource link does not contain a domain name, it may indicate that the link is a link with a default domain name, and such link may often be an internal link. For example, a link like ‘script src=“/js/jquery.js”’ is an internal link. If a current resource link contains a domain name, it may be further determined whether the domain name of the resource link is consistent with a domain name of the target page. If the domain name of the resource link is consistent with the domain name of the target page, the resource link may be determined as an internal link. If the domain name of the resource link is not consistent with the domain name of the target page, the resource link may be determined as an external link.


For example, assuming that the domain name of the target page is ‘www.abc.com’, and the identified resource links are ‘https://www.123.com/1.js’ and ‘https://www.abc.com/1.js’. In view of this, through the above-mentioned determination method of the domain name, it may be determined that ‘https://www.123.com/1.js’ is an external link, and ‘https://www.abc.com/1.js’ is an internal link.


In the present embodiment, considering that the node server cannot subsequently accelerate external links directly, after the monitoring script identifies an external link, the external link may be rewritten in a form of an internal link. Specifically, because a domain name contained in the internal link needs to be consistent with the domain name of the target page, the rewritten domain name may also need to contain the domain name of the target page. In addition, to subsequently distinguish a real internal link and the rewritten internal link, a specified resource path may need to be set in the rewritten internal link. The specified resource path may indicate that the current internal link is actually obtained by rewriting an external link. In practical applications, the specified resource path may be pre-configured by the node server in the monitoring script. In view of this, after the monitoring script identifies an external link, the external link may be rewritten in the form of internal link through the specified resource path. It can be seen from the above that the rewritten internal link may need to contain the domain name of the target page, the specified resource path, and the external link.


In practical applications, the specified resource path may be represented as ‘/modify’. In addition, considering that an external link may be written in an informal form, a space or a special character may be likely to be carried in the external link, and the space and the special character may often not be allowed to be carried in the string data transmitted to the node server. Therefore, when rewriting the external link, the external link may need to be converted into corresponding string data according to a preset encoding and decoding rule, thereby eliminating the space and the special character in the external link, and enabling the converted string data to meet the specification requirements for URL (Uniform Resource Locator). In practical applications, the preset encoding and decoding rule may have a plurality of implementation manners. For example, the preset encoding and decoding rule may be ‘urlencode’ encoding and decoding rule, or may be ‘base64’ encoding and decoding rule, which is not limited by the present disclosure.


In view of this, after obtaining the domain name of the target page and converting the external link to string data according to the preset encoding and decoding rule, the domain name of the target page and the string data may be integrated according to the preset specified resource path, and the integrated result may be used as the rewritten internal link. In practical applications, in the internal link, the domain name of the target page, the specified resource path, and the string data may be sorted according to a preset rule. For example, the information of such three parts may be arranged in an order from front to back, and, thus, to form the rewritten internal link.


In the present embodiment, to distinguish the above-mentioned string data from data of any other part, the rewritten internal link may further include a locator identifier. The locator identifier may be located after the specified resource path, and assignment of the locator identifier may be the string data. For example, the locator identifier may be “? Url”, and the “? Url” may be assigned in a form of “? Url=XXXX”, where XXXX may be the string data assigned to “? Url”. In view of this, in an application example, through the above manner, an external link such as ‘https://www.123.com/1.js’ may be rewritten into an internal link:


‘https://www.abc.com/modify?url=https%3A%2F%2Fwww.123.com%2F1.js’.


In the above internal link, ‘https://www.abc.com’ may be the domain name of the target page, ‘/modify’ may be the specified resource path, ‘?Url’ may be the locator identifier, and ‘https%3A%2F%2Fwww.123.com%2F1.js’ may be the string data obtained through the ‘urlencode’ encoding manner.


In the present embodiment, according to the above-mentioned manner, the identified external links may be sequentially rewritten, such that each external link introduced by the client terminal may be represented in a form of an internal link. For an internal link introduced by the client terminal, the above-mentioned rewriting process may not be performed.


In the present embodiment, after rewriting an external link into an internal link, in the data buffer, the corresponding external link in the parameter may be replaced with the rewritten internal link to obtain the rewritten parameter in the data buffer. Therefore, it may be ensured that in the rewritten parameter, the manifestations of the resource links are all in the form of internal links.


For an application example of the tag creation function, the original ‘document.createElement’ function of the browser may create a new element (tag), and a new resource link may be introduced through an ‘element.src’ instruction. In view of this, a different tag may introduce a different resource link. For example, a script tag ‘HTMLScriptElement’ may introduce a script link, an image tag ‘HTMLImageElement’ may introduce an image link, and a style tag ‘HTMLLinkElement’ may introduce a style link. Therefore, in the present embodiment, tags with different types may need to be monitored to determine whether these tags with different types subsequently introduce new resource links. In view of this, the monitoring script may determine a to-be-monitored tag with a specified type and a to-be-monitored attribute identifier under the tag with the specified type. The tag with the specified type may be each tag exemplified above. In practical applications, tags with substantially few or many types may be contained, which are not limited by the present disclosure. In addition, there may be many attribute identifiers under these tags with specified types. The monitoring script may not need to monitor each attribute identifier, while may merely need to monitor an attribute identifier that is likely to introduce a resource link. Therefore, the above-mentioned to-be-monitored attribute identifier may include ‘src’ attribute and/or ‘href’ attribute, and the client terminal may introduce a new resource link through ‘element.src’ or ‘element.href’. In the present embodiment, the monitoring script may further define a data acquisition mode ‘setter’. The data acquisition mode may intercept an attribute value of the to-be-monitored attribute identifier, such that the monitoring script may identify whether the intercepted attribute value contains an external link.


In the present embodiment, during the process of parsing the resource description file performed by the client terminal, if the monitoring script monitors a set event of the attribute identifier under the tag with the specified type, it may indicate that currently the client terminal may introduce a new resource link. At this time, the attribute value of the set event may be obtained through the data acquisition mode ‘setter’, and then a link represented by the attribute value may be used as the resource link generated by the client terminal in the process of parsing the resource description file.


Similarly, after obtaining the resource link introduced by the client terminal, according to the above-mentioned manner, whether the resource link contains an external link may be determined, and the external link may be rewritten in the form of the internal link according to the above-mentioned manner. For the internal link, the above rewriting process may not be performed. After the external link is rewritten in the form of the internal link, in the attribute value obtained through the data acquisition mode, the monitoring script may use the rewritten internal link to replace the corresponding external link, to obtain the rewritten attribute value. Then, through the data acquisition mode, the rewritten attribute value may be returned to the set event, such that new resource links introduced through ‘element.src’ or ‘element.href’ manner may be all in the form of internal links.


In S15: writing the rewritten resource link into the resource description file, and according to the resource description file, obtaining the page resource of the target page.


In the present embodiment, after rewriting an external link into an internal link and replacing the corresponding external link with the rewritten internal link, the rewritten resource link may be obtained. In the rewritten resource link, each link may be in the form of an internal link. In view of this, the rewritten resource link may be written into the resource description file, and then the client terminal may subsequently construct a resource acquisition request for the link in the resource description file, thereby obtaining the corresponding page resource.


In practical applications, for an application example of the above-mentioned data writing function, after obtaining the rewritten parameter, the monitoring script may call the original data writing function, and through the original data writing function, the rewritten parameter in the data buffer may be written into the resource description file. For an application example of the above-mentioned tag creation function, after returning the rewritten attribute value to the set event through the data acquisition mode, the rewritten attribute value may be written into the resource description file through the set event. Specifically, the rewritten attribute value may be written into the resource description file through an ‘appendChild’ manner.


In practical applications, the above-mentioned functions of identifying and rewriting the external link may be set whether to be enabled or not by configuring a function switch in the node server. Referring to FIG. 2, if the node server does not enable the functions of identifying and rewriting the external link, after receiving the resource description file fed back from the origin server, the monitoring script may not be inserted, while the resource description file may be directly provided to the client terminal. If the node server has enabled the functions of identifying and rewriting the external link, the monitoring script may be inserted into the resource description file.


The present disclosure further provides a client terminal. Referring to FIG. 3, the client terminal may include:

    • a unit for acquiring a resource description file, configured to send an access request directed to a target page to a node server, and receive the resource description file of the target page fed back by the node server, where the resource description file may include a monitoring script inserted by the node server;
    • a link rewriting unit, configured to when the monitoring script is executed in the client terminal, monitor a resource link generated by the client terminal in the process of parsing the resource description file, and determine whether the resource link contains an external link, if the resource link contains an external link, rewrite the external link into an internal link, and replace the corresponding external link in the resource link with the rewritten internal link; and
    • a writing unit, configured to write the rewritten resource link into the resource description file, and according to the resource description file, obtain page resource of the target page.


In one embodiment, the link rewriting unit may include:

    • an initialization module, configured to define a parameter interception function and create a data buffer;
    • a parameter interception module, configured to during the process of parsing the resource description file performed by the client terminal, if the client terminal calls an original data writing function, obtain a parameter in the data writing function through the parameter interception function, and write the obtained parameter into the data buffer; and
    • an identifier identification module, configured to identify a link attribute identifier from the parameter in the data buffer, and use the link represented by the link attribute identifier as the resource link generated by the client terminal in the process of parsing the resource description file.


In one embodiment, the link rewriting unit may include:

    • a monitoring information setting module, configured to determine a to-be-monitored tag with a specified type and a to-be-monitored attribute identifier under the tag with the specified type, and define a data acquisition mode;
    • an event monitoring module, configured to during the process of parsing the resource description file performed by the client terminal, when a set event of the attribute identifier under the tag with the specified type is monitored, obtain an attribute value of the set event through the data acquisition mode; and
    • a link determining module, configured to use the link represented by the obtained attribute value as the resource link generated by the client terminal in the process of parsing the resource description file.


In one embodiment, the link rewriting unit may further include:

    • an attribute value returning module, configured to obtain a rewritten attribute value, by replacing the corresponding external link with the rewritten internal link, in the attribute value obtained through the data acquisition mode; and return the rewritten attribute value to the set event through the data acquisition mode.


Correspondingly, the writing unit may be further configured to write the rewritten attribute value into the resource description file through the set event.


The present disclosure further provides a client terminal. Referring to FIG. 4, the client terminal may include a memory and a processor. The memory may be used to store a computer program. When the computer program is executed by the processor, the foregoing method for processing the resource description file may be implemented. Specifically, referring to FIG. 4, at the hardware level, the client terminal may include the processor, an internal bus, and the memory. The memory may include a memory and a non-volatile memory. The processor may read the corresponding computer program from the non-volatile memory into the memory, and then may execute the computer program. Persons of ordinary skill in the art can understand that the structure shown in FIG. 4 is merely schematic, which may not limit the structure of the above identification device. For example, the client terminal may further include more or fewer components than those shown in FIG. 4. For example, the client terminal may further include any other processing hardware, e.g., a GPU (graphics processing unit), or may have a configuration different from that shown in FIG. 4. In addition to software implementation manner, the present disclosure may not exclude any other implementation manner, e.g., a logic device or a combination of software and hardware.


In the present embodiment, the processor may include a central processing unit (CPU) or a graphics processing unit (GPU), and may also include any other single-chip computer with logic processing capabilities, logic gate circuit, and integrated circuit, etc., or a suitable combination thereof. The memory in the present embodiment may be a memory device for storing information. In a digital system, a device capable of storing binary data may be a memory. In an integrated circuit, a circuit that has a storage function and does not have a physical form may be a memory, e.g., random-access memory (RAM), first-in-first-out (FIFO), etc. In a system, a storage device having a physical form may also be called a memory. When being implemented, the memory may also be implemented in a cloud storage manner. The specific implementation manner is not limited by the present disclosure.


It should be noted that, the specific implementation manner of the client terminal in the present embodiment may refer to the description of the foregoing implementation method for processing the resource description file, which is not repeated herein.


The present disclosure further provides a method for obtaining page resource. Referring to FIG. 5 and FIG. 6, the method may be applied to the foregoing node server, and the method may include following steps.


In S21: receiving a resource acquisition request directed to a target page and sent from a client terminal.


In the present embodiment, the client terminal may identify each resource link contained in the resource description file, and then may initiate a resource acquisition request for each resource link one by one. In practical applications, to reduce the number of initiated requests, sometimes multiple resource links may be carried in a same resource acquisition request, which is not limited in the present disclosure.


In S23: determining whether the resource acquisition request contains a target link that complies with a link rewriting rule.


In the present embodiment, the resource link in the resource description file may contain a real internal link, and may also contain an internal link rewritten according to the manner described in steps S11-S15. In view of this, the resource acquisition request initiated by the client terminal may carry the real internal link, and may carry an internal link obtained by rewriting an external link. A link with a different type may need to be processed in a different manner. Specifically, for the real internal link, the node server may directly obtain the page resource corresponding to the real internal link, and feed back the obtained page resource to the client terminal. For the internal link obtained by rewriting the external link, the actual external link may be extracted to obtain the resource corresponding to the external link.


Therefore, in the present embodiment, it is necessary to first determine what kind of internal link is contained in the resource acquisition request sent by the client terminal. Specifically, it may be determined whether the resource acquisition request contains a target link that complies with the link rewriting rule. The link rewriting rule may be represented by the above-mentioned specified resource path. Specifically, it may be determined whether the resource acquisition request contains a link carrying the specified resource path. If the resource acquisition request contains the link carrying the specified resource path, the link carrying the specified resource path may be used as the target link that complies with the link rewriting rule. If the resource acquisition request does not contain the link carrying the specified resource path, it may be determined that the resource acquisition request does not contain the target link that complies with the link rewriting rule. According to the rewriting rule described in step S13, after rewriting the external link, the obtained internal link may include the specified resource path. If the node server identifies the specified resource path from the resource acquisition request, it may indicate that the link carrying the specified resource path may be an internal link obtained by rewriting the external link. If the resource acquisition request does not contain the specified resource path, it may indicate that the link contained in the resource acquisition request is a real internal link.


In S25: if the resource acquisition request contains the target link that complies with the link rewriting rule, extracting page address information from the target link, and parsing the page address information to a corresponding external link.


In the present embodiment, if the resource acquisition request contains a target link carrying the specified resource path, the target link may need to be restored into an external link. Specifically, a locator identifier may be first identified in the target link, and string data represented by the locator identifier may be identified. Therefore, the string data may be extracted into page address information contained in the target link. For example, a target link carrying the specified resource path may be:


‘https://www.abc.com/modify?url=https%3A%2F%2Fwww.123.com%2F1.js’.


The locator identifier “? Url” in the target link may be identified, and, thus, the assignment ‘https%3A%2F% 2Fwww.123.com%2F1.js’ after “? Url” may be used as the extracted page address information.


In the present embodiment, when rewriting the external link, the page address information may be obtained by encoding the external link through a preset encoding and decoding rule. Then, after extracting the page address information, the page address information may still be decoded into the corresponding external link according to the preset encoding and decoding rule. For example, according to the ‘urlencode’ manner, the above page address information may be decoded into an external link ‘https://www.123.com/1.js’.


In S27: obtaining the page resource corresponding to the external link obtained by parsing, and feeding back the page resource to the client terminal.


In the present embodiment, after obtaining the external link by parsing, the page resource corresponding to the external link obtained by parsing may be obtained, and then the page resource may be fed back to the client terminal.


In addition, if the resource acquisition request does not contain a target link that complies with the link rewriting rule, it may indicate that the internal links contained in the resource acquisition request all are real internal links. At this time, the page resource corresponding to the link contained in the resource acquisition request may be directly obtained, and the obtained page resource may be fed back to the client terminal.


It should be noted that the node server may have a resource cache function. After obtaining various page resources, these page resources may be stored in association with their respective resource links, and at the same time, each page resource in the target page may be stored in association with the domain name of the target page. In view of this, when an access request directed to the target page is subsequently sent by the client terminal, it may first check whether the cache contains corresponding cached data. If the cache contains the corresponding cached data, the cached data may be directly fed back to the client terminal. Similarly, after receiving the resource acquisition request sent by the client terminal, it may first check whether the cache already contains cached data corresponding to the resource acquisition request. If the cache already contains cached data corresponding to the resource acquisition request, the cached data may be directly fed back to the client terminal. If the cache does not contain cached data corresponding to the resource acquisition request, the corresponding page resource may be obtained according to the above-mentioned manner.


The present disclosure further provides a node server. The node server may include:

    • a unit for receiving a resource acquisition request, configured to receive the resource acquisition request directed to a target page and sent from a client terminal;
    • a link determining unit, configured to determine whether the resource acquisition request contains a target link that complies with a link rewriting rule;
    • a unit for parsing page address information, configured to if the resource acquisition request contains the target link that complies with the link rewriting rule, extract page address information from the target link and parse the page address information to a corresponding external link; and
    • a resource feedback unit, configured to obtain page resource corresponding to the external link obtained by parsing and feed back the page resource to the client terminal.


In one embodiment, the link determining unit may include:

    • a module for determining a specified resource path, configured to determine whether the resource acquisition request contains a link carrying the specified resource path, and if the resource acquisition request contains the link carrying the specified resource path, use the link carrying the specified resource path as the target link that complies with the link rewriting rule, or if the resource acquisition request does not contain the link carrying the specified resource path, determine that the resource acquisition request does not contain the target link that complies with the link rewriting rule.


In one embodiment, the page address information may be obtained by encoding the external link through a preset encoding and decoding rule. Correspondingly, the unit for parsing the page address information may be further configured to according to the preset encoding and decoding rule, decode the page address information to a corresponding external link.


The present disclosure further provides a node server. The node server may include a memory and a processor. The memory may be used to store a computer program. When the computer program is executed by the processor, the foregoing method for obtaining the page resource may be implemented.


It can be seen from the above that in the technical solution provided by the present disclosure, after sending the access request directed to the target page to the node server, the client terminal may receive the resource description file of the target page fed back by the node server. To determine whether the client terminal introduces an external link in the process of parsing the resource description file, the node server may insert the monitoring script into the fed back resource description file. When parsing the resource description file, the client terminal may execute the monitoring script. When executing the monitoring script, the resource link generated by the client terminal in the process of parsing the resource description file may be monitored, and it may be determined whether the resource link contains an external link. If the resource link contains the external link, the monitoring script may rewrite the external link into an internal link, and may use the rewritten internal link to replace the corresponding external link in the resource link. In view of this, if the client terminal introduces external links in the process of parsing the resource description file, these external links may be rewritten into internal links. Such rewritten internal links together with the real internal links may be written into the resource description file.


Subsequently, the client terminal may initiate a resource acquisition request for each link in the resource description file one by one. Because the rewritten links in the resource description files are all internal links, such resource acquisition requests may be received by the node server. The node server may identify the link contained in the received resource acquisition request, and then may determine a target link carrying the specified resource path. The specified resource path may indicate that the target link is not originally an internal link, while is obtained by rewriting an external link. In view of this, for the target link, the node server may obtain the actual external link by parsing, may obtain the corresponding resource according to the external link obtained by parsing, and may feed back the resource to the client terminal. It can be seen that the technical solution provided by the present disclosure may ensure that, in the resource acquisition request subsequently received by the node server, by rewriting external links, the links all are in the form of internal links, such that it may be ensured that the node server is capable of accelerating each link. Then, the node server may restore the rewritten internal link into an external link by identifying the specified resource path, and may obtain the resource corresponding to the external link. In view of this, both the internal link and the external link may be accelerated by the node server of the CDN, thereby improving the overall loading speed of the page.


Through the description of the above embodiments, those skilled in the art can clearly understand that each embodiment may be implemented by means of software and a necessary universal hardware platform, and may also be implemented by hardware. Based on such understanding, the above-mentioned essential technical solution or part that contributes to the existing technology may be embodied in the form of a software product. The computer software product may be stored in a computer-readable storage medium, e.g., read-only memory (ROM)/RAM, a magnetic disc, an optical disc, etc., and may include a plurality of instructions for enabling a computer device (e.g., a personal computer, a server, or a network device, etc.) to execute the method described in various embodiments or certain parts of the embodiments.


The above descriptions are merely the preferred embodiments of the present disclosure, and are not intended to limit the present disclosure. Any modifications, equivalents, improvements, etc., which are within the spirit and scope of the present disclosure, should be included in the protection of the present disclosure.

Claims
  • 1. A method for processing a resource description file, wherein the method is applied to a client terminal, and comprises: sending an access request directed to a target page to a node server, and receiving the resource description file of the target page fed back by the node server, wherein the resource description file includes a monitoring script inserted by the node server;when the monitoring script is executed in the client terminal, monitoring a resource link generated by the client terminal in a process of parsing the resource description file, determining whether the resource link contains an external link, and if the resource link contains the external link, rewriting the external link into an internal link, and replacing the corresponding external link in the resource link with the rewritten internal link; andwriting the rewritten resource link into the resource description file, and according to the resource description file, obtaining page resource of the target page.
  • 2. The method according to claim 1, wherein monitoring the resource link generated by the client terminal in the process of parsing the resource description file includes: defining a parameter interception function, and creating a data buffer;during the process of parsing the resource description file performed by the client terminal, if the client terminal calls an original data writing function, obtaining a parameter in the data writing function through the parameter interception function, and writing the obtained parameter into the data buffer; andidentifying a link attribute identifier from the parameter in the data buffer, and using a link represented by the link attribute identifier as the resource link generated by the client terminal in the process of parsing the resource description file.
  • 3. The method according to claim 2, wherein replacing the corresponding external link in the resource link with the rewritten internal link includes: obtaining a rewritten parameter in the data buffer by replacing the external link corresponding to the parameter with the rewritten internal link; andcorrespondingly, writing the rewritten resource link into the resource description file includes:calling the original data writing function, and through the original data writing function, writing the rewritten parameter in the data buffer into the resource description file.
  • 4. The method according to claim 1, wherein monitoring the resource link generated by the client terminal in the process of parsing the resource description file includes: determining a to-be-monitored tag with a specified type and a to-be-monitored attribute identifier under the tag with the specified type, and defining a data acquisition mode;during the process of parsing the resource description file performed by the client terminal, when a set event of the attribute identifier under the tag with the specified type is monitored, obtaining an attribute value of the set event through the data acquisition mode; andusing a link represented by the obtained attribute value as the resource link generated by the client terminal in the process of parsing the resource description file.
  • 5. The method according to claim 4, wherein replacing the corresponding external link in the resource link with the rewritten internal link includes: obtaining, by replacing the corresponding external link with the rewritten internal link, a rewritten attribute value in the attribute value obtained through the data acquisition mode, and returning the rewritten attribute value to the set event through the data acquisition mode, wherein:correspondingly, writing the rewritten resource link into the resource description file includes:through the set event, writing the rewritten attribute value into the resource description file.
  • 6. The method according to claim 1, wherein determining whether the resource link contains an external link includes: determining whether a current resource link contains a domain name, if the current resource link contains the domain name, determining whether the domain name in the current resource link is consistent with a domain name of the target page, and if the domain name in the current resource link is consistent with the domain name of the target page, determining that the current resource link is an internal link, or if the domain name in the current resource link is not consistent with the domain name of the target page, determining that the current resource link is an external link; orif the current resource link does not contain the domain name, determining that the current resource link is an internal link.
  • 7. The method according to claim 1, wherein rewriting the external link into the internal link includes: obtaining a domain name of the target page, and according to a preset encoding and decoding rule, converting the external link to string data; andthrough a specified resource path preset by the node server, integrating the domain name of the target page and the string data, and using an integrated result as the rewritten internal link, wherein in the internal link, the domain name of the target page, the specified resource path, and the string data are sorted according to a preset rule.
  • 8. The method according to claim 7, wherein the rewritten internal link further includes a locator identifier, wherein the locator identifier is located after the specified resource path, and assignment of the locator identifier is the string data.
  • 9. A client terminal, wherein the client terminal comprises: a unit for acquiring a resource description file, configured to send an access request directed to a target page to a node server, and receive the resource description file of the target page fed back by the node server, wherein the resource description file includes a monitoring script inserted by the node server;a link rewriting unit, configured to when the monitoring script is executed in the client terminal, monitor a resource link generated by the client terminal in the process of parsing the resource description file, determine whether the resource link contains an external link, and if the resource link contains the external link, rewrite the external link into an internal link, and replace the corresponding external link in the resource link with the rewritten internal link; anda writing unit, configured to write the rewritten resource link into the resource description file, and according to the resource description file, obtain page resource of the target page.
  • 10. The client terminal according to claim 9, wherein the link rewriting unit includes: an initialization module, configured to define a parameter interception function, and create a data buffer;a parameter interception module, configured to during the process of parsing the resource description file performed by the client terminal, if the client terminal calls an original data writing function, obtain a parameter in the data writing function through the parameter interception function, and write the obtained parameter into the data buffer; andan identifier identification module, configured to identify a link attribute identifier from the parameter in the data buffer, and use a link represented by the link attribute identifier as the resource link generated by the client terminal in the process of parsing the resource description file.
  • 11. The client terminal according to claim 9, wherein the link rewriting unit includes: a monitoring information setting module, configured to determine a to-be-monitored tag with a specified type and a to-be-monitored attribute identifier under the tag with the specified type, and define a data acquisition mode;an event monitoring module, configured to during the process of parsing the resource description file performed by the client terminal, when a set event of the attribute identifier under the tag with the specified type is monitored, obtain an attribute value of the set event through the data acquisition mode; anda link determining module, configured to use a link represented by the obtained attribute value as the resource link generated by the client terminal in the process of parsing the resource description file.
  • 12. The client terminal according to claim 11, wherein the link rewriting unit further includes: an attribute value returning module, configured to obtain, by replacing the corresponding external link with the rewritten internal link, a rewritten attribute value in the attribute value obtained through the data acquisition mode, and return the rewritten attribute value to the set event through the data acquisition mode, wherein:correspondingly, the writing unit is further configured to write the rewritten attribute value into the resource description file through the set event.
  • 13. (canceled)
  • 14. A method for obtaining page resource, wherein the method comprises: receiving a resource acquisition request directed to a target page and sent from a client terminal;determining whether the resource acquisition request contains a target link that complies with a link rewriting rule;if the resource acquisition request contains the target link that complies with the link rewriting rule, extracting page address information from the target link, and parsing the page address information to a corresponding external link; andobtaining page resource corresponding to the external link obtained by parsing, and feeding back the page resource to the client terminal.
  • 15. The method according to claim 14, wherein determining whether the resource acquisition request contains the target link that complies with the link rewriting rule includes: determining whether the resource acquisition request contains a link carrying a specified resource path; and if the resource acquisition request contains the link carrying the specified resource path, using the link carrying the specified resource path as the target link that complies with the link rewriting rule; or if the resource acquisition request does not contain the link carrying the specified resource path, determining that the resource acquisition request does not contain the target link that complies with the link rewriting rule.
  • 16. The method according to claim 14, wherein extracting the page address information from the target link includes: identifying a locator identifier in the target link, and using string data represented by the locator identifier as the extracted page address information.
  • 17. The method according to claim 14, wherein the page address information is obtained by encoding the external link through a preset encoding and decoding rule; and correspondingly, parsing the page address information to the corresponding external link includes: according to the preset encoding and decoding rule, decoding the page address information to the corresponding external link.
  • 18. The method according to claim 14, further including: if the resource acquisition request does not contain the target link that complies with the link rewriting rule, obtaining the page resource corresponding to a link contained in the resource acquisition request, and feeding back the obtained page resource to the client terminal.
  • 19. (canceled)
  • 20. (canceled)
  • 21. (canceled)
  • 22. (canceled)
Priority Claims (1)
Number Date Country Kind
201811550196.6 Dec 2018 CN national
PCT Information
Filing Document Filing Date Country Kind
PCT/CN2019/072179 1/17/2019 WO 00