Under 35 U.S.C. § 119, this application claims the benefit and right of priority of Chinese Patent Application No. 201510648622.X, filed 9 Oct. 2015.
Field
The present invention relates to the technical field of web interface management and, in particular, relates to a method and system for efficiently managing navigation categories in a distributed web environment.
Related Art
With the rapid development of the Internet, contents of a web environment, such as an e-commerce website, are becoming richer. To facilitate quick access to the contents the users are interested in, such websites can provide a hierarchical category navigation system. Based on this system, users can quickly find the contents that they are interested in. However, the category navigation system needs to be maintained and managed. Typically, in response to the change of requirements, the navigation categories in the system are adaptively updated. For example, in an e-commerce website, the search requirements of users may change due to the change of seasons and holidays. As a result, the navigation categories are updated adaptively to match the buyer's search requirements for commodities.
With the increase of network traffic, increasing numbers of web environments are establishing local sites for load distribution. In a multi-site web environment, the users of different sites typically vary. To meet the search requirements of different users of different sites, each site maintains and employs its own set of category navigation system. When a navigation category needs to be updated, the category maintenance personnel of each site manually update their navigation category. Such manual updates can be tedious, time consuming, and error-prone. Hence, the efficiency of this approach is relatively low.
While a category navigation system brings many desirable features to a web environment, some issues remain unsolved in the management of navigation categories in a multi-site web environment.
One embodiment of the present application provides a system for efficiently managing navigation categories in a multi-site web environment. During operation, the system determines whether a category of a product is a synchronized category. A synchronized category is shared by a main site and a local site of the multi-site web environment. If the category is a synchronized category, the system copies the category from the main site to the local site.
In a variation of this embodiment, the system establishes a mapping between the category at the main site and the category at the local site, and assigns a category identifier to a respective category. The mapping is based on a first category identifier of the category at the main site and a second category identifier of the category at the local site.
In a further variation, the first category identifier is in a range of identifiers allocated for the main site, and the second category identifier is in a range of identifiers allocated for the local site.
In a variation of this embodiment, the system identifies an operation on the category at the main site. If the category is a synchronized category, the system applies the operation to the category at the local site.
In a further variation, the operation includes one of: addition, deletion, and update.
In a variation of this embodiment, if the category is a synchronized category, the system converts the category at the local site to a differentiated category by terminating a mapping between the category at the main site and the category at the local site, and setting the category to be a differentiated category.
In a variation of this embodiment, if the category is a differentiated category, the system converts the category at the local site to a synchronized category by deleting the category at the local site, copying the category from the main site to the local site, and establishing a mapping between the category at the main site and the copied category at the local site.
In a variation of this embodiment, the main site and the local site are distributed in different geographic areas.
The accompanying drawings herein, which are incorporated herein and constitute a part of the specification, illustrate several exemplary embodiments of the present application and, together with the description, serve to illustrate the present application, construing no limitation thereto. In the drawings:
In the figures, like reference numerals refer to the same figure elements.
Embodiments of the present invention solve the problem of facilitating efficient category management in a multi-site web environment by (i) identifying the categories that remain same in a respective site; and (ii) automatically synchronizing these categories across a respective site. With existing technologies, even when a category is the same in each site, the administrator of each site manually manages (e.g., adds, deletes, or updates) that category. As a result, even when a category that can be managed without differentiation across the sites, the same operations are repeated for that category at all sites, which leads to significant resource usage. For example, when a new cell phone model comes to the market, the cell phone model should be added to the cell phone category. With existing technologies, the same operation needs to be repeated at each site. If the category structures of the sites are different, this operation can become tedious and error-prone.
To solve these problems, embodiments of the present invention allow a category navigation system to determine whether a category at a site is a differentiated category. If a category is presented differently at two different sites (e.g., has different sub-categories or has a different name), that category can be referred to as a differentiated category. If a category is not a differentiated category, the category is the same in each site. If the category is modified at a site, the system automatically synchronizes that category with a respective site. This category can be referred to as a synchronized category. Since operations on a synchronized category can be managed at a single location, the automatic synchronization avoids the issues incurred by the repeated operations for the category at each site.
To facilitate the navigation categories to users 101 and 105, a category operation administrator can modify navigation category data, which can be stored in a database 132 in server 110. In some embodiments, the category navigation system of web environment 100 identifies the products associated with a category and establishes a relationship (e.g., a relationship in a relational database) between the category and the identified products. The search service of web environment 100 can use this relationship information to create an index for the product. This index can be an identifier of a category to which the product belongs. When user 101 or 105 searches for a keyword, the category navigation system returns the navigation categories associated with the matched products for the user to choose from.
During operation, if a user 101 wishes to purchase a product 134 from the corresponding local site 162, a client device 102 of user 101 can access local site 162 using a web interface 142 (e.g., a browser) and searches for product 134. Web interface 142 issues a request 122 (e.g., an HTTP request) to server 110, which stores the information associated with product 134 in database 132. Upon receiving request 122, server 110 obtains the information associated with product 134 (e.g., a navigation category) and sends a response 124 comprising the information back to web interface 142. Based on one or more such requests and responses, web interface 142 displays a web page corresponding to local site 162 to user 101. Based on the navigation categories of local site 162, server 110 presents a category of product 134 to user 101.
On the other hand, if user 105 searches for the same product 134, server 110 can present a different local site 164 with a different outline to user 105. For example, a client device 106 of user 105 can access local site 164 using a web interface 144. Web interface 144 issues a request 126 to server 110, which sends a response 128 back to web interface 144. Based on one or more such requests and responses, web interface 144 displays a web page corresponding to local site 164 to user 105. Since user 105 is at a different location, server 110 may present a different category for product 134 at local site 164. It should be noted that the web services associated with different sites of the e-commerce services can be hosted at the same server or at different locations. As a result, requests 122 and 126 can be served from the same server or from different servers at different locations.
With existing technologies, even when the category of product 134 is the same at sites 162 and 164, the category is manually established for each site. As a result, the same operations are repeated for that category at server 110 (or any other server that may host a local site) for each site. This can lead to significant resource usage. In particular, if the category structures of sites 162 and 164 are different, this operation can become tedious and error-prone. Embodiments of the present invention solve this problem by determining whether the category of product 134 is the same at both sites 162 and 164, and automatically synchronizing the category across sites 162 and 164 (e.g., with the main site).
Requests 122 and 126, and responses 124 and 128 can be data frames. In this disclosure, the term “frame” refers to a group of bits that can be transported together across a network. “Frame” should not be interpreted as limiting embodiments of the present invention to layer-2 networks. “Frame” can be replaced by other terminologies referring to a group of bits, such as “packet,” “cell,” “message,” or “datagram.”
If category 170 is a differentiated category, the category navigation system copies the category tree of category 170 to local sites 162 and 164. Each of the local sites is then updated based on the categorization criteria of the local site. For example, at local site 162, sub-category 172 can have more sub-categories than main site 160; and at local site 164, category 170 can have an additional sub-category 176, which may not be present in sites 160 and 162. In this way, a category tree of the main site can be used to generate the initial category tree at a local site. Then the copy the category tree of the main site is further updated for the local site to represent the categorization of that local site to provide the differentiation.
If category 180 is a synchronized category, the category navigation system copies the category tree of category 180 to local sites 162 and 164. Furthermore, the category navigation system establishes a mapping relationship between category 180 at main site 160 and category 180 at respective local sites 162 and 164. Based on the mapping, any modification to the category tree of category 180 at main site 160 is automatically synchronized with the category tree of category 180 at respective local sites 162 and 164. For example, if sub-category 182 is updated at main site 160, that update is automatically synchronized with sub-category 182 at local sites 162 and 164. In this way, category 180 is shared among main site 160, and local sites 162 and 164. This allows operations on synchronized category 180 to be managed at main site 160, thereby avoiding the repeated operations for category 180 at local sites 162 and 164.
On the other hand, if category 210 is a synchronized category for a local site, category navigation system 200 copies category 210 to the local site and establishes a mapping relationship between category 210 at the main site and at the local site. This mapping relationship can be referred to as a category mapping. This category mapping allows synchronous updates to the local sites. For example, if category 210 is updated at the main site, category navigation system 200 identifies the categories mapped to category 210 in a respective local site and automatically synchronizes the update (i.e., performs the same update) with that category 210 at a respective local site.
To uniquely identify a category (or any sub-category in a category tree), a category navigation system allocates a category identifier to that category. In some embodiments, a category tree (i.e., a category and any sub-category thereof) can be identified by the category identifier of the root category of the category tree. To make sure that the same category at different sites is disguisable from each other, the category navigation system allocates different ranges of identifiers to each site.
Here, the category navigation system allocates non-overlapping ranges of identifiers (or identifier ranges) 250, 252, and 254 to sites 160, 162, and 164, respectively. Such an identifier can be referred to as a category identifier. When a particular category is assigned an identifier, the system can determine the site based on the identifier. Suppose that ranges of identifiers 250, 252, and 254 are (1˜201000000), (201000001˜202000000), and (202000001˜203000000), respectively. In the example in
Furthermore, at each site, the system maintains a mapping between a product and one or more categories associated with the product based on the identifiers. In the example in
The category navigation system further maintains a category mapping table for synchronized categories. This table maps a category at a main site to the same category at a respective local site.
Suppose that, identifiers 260, 262, and 264 have values 1000, 1001, and 1002 in range 250. Identifiers 270, 272, and 274 have values 201001000, 201001001, and 201001002 in range 252. Since category 180 is a synchronized category, the system maps identifier 260 to identifier 270 for category 180 in category mapping table 244. In the same way, the system maps identifier 262 to identifier 272 for category 182 and identifier 264 to identifier 274 for category 184 in category mapping table 244. As a result, if category 180 is updated at main site 160, the system determines that identifier 260 is mapped to identifier 270. The system determines that identifier 270 is in range 252 and therefore, is associated with local site 162. The system then identifies and synchronizes the updates with (i.e., applies the same updates to) category 180 at local site 162.
When a new synchronized category is added, or an existing synchronized category is deleted or updated, the category navigation system synchronously updates the category at a respective site.
The system then checks whether the new category is a synchronized category (operation S303). The instruction can specify whether the category is a synchronized category. The system can also maintain a set of generic product classes and if the category is associated with one or more of the product classes, the system determines that the new category is a synchronized category. If the new category is not a synchronized category, the system copies the new category to a respective local site and allocates a category identifier from the identifier range associated with the corresponding local site (operation S304). The system then applies a differentiation to the copy of the new category at a respective local site (operation S305). In some embodiments, an administrator provides the differentiation to the system.
If the new category is a synchronized category, the system synchronously establishes the new category for a respective local site and allocates a category identifier from the identifier range associated with the corresponding local site (operation S306). The system then maps the allocated category identifier associated with the main site to the allocated category identifier associated with a respective local site (operation S307), as described in conjunction with
If the category does not have a mapping with a local site, the category is a differentiated category. The system then prevents synchronization with the local sites (i.e., does not propagate the delete operation to the local sites) (operation S338). On the other hand, if the category has a mapping with a local site, the category is a synchronous category. The system then checks whether the local site has a sub-category (operation S334). If the local site has a sub-category, the system prompts to query whether to convert a category to a differentiated category (operation S336). Otherwise, the system synchronously deletes the category from a respective local site (operation S335).
If the category is in the main site, the system deletes the category and the corresponding sub-categories (operation S454) and copies the category and the corresponding sub-categories from the main site to a respective local site (operation S455). The system then establishes a mapping between the category (and its respective sub-categories) at the main site and the copied category (and its respective copied sub-categories) at a respective local site (operation S456). In some embodiments, the system allocates category identifiers to the copied category and its sub-categories. The system maps the category identifier of the category at the main site to the category identifier of the category at a respective local site, as described in conjunction with
Exemplary Apparatus
In some embodiments, modules 532, 534, 536, and 538 can be partially or entirely implemented in hardware and can be part of processor 510. Further, in some embodiments, data processing system 500 may not include a separate processor and memory. Instead, in addition to performing their specific tasks, modules 532, 534, 536, and 538, either separately or in concert, may be part of special-purpose computation engines.
Storage device 530 stores programs to be executed by processor 510. Specifically, storage device 530 stores a program that implements an e-commerce server and/or a web server. During operation, an application program can be loaded from storage device 530 into memory 520 and executed by processor 510. As a result, category navigation system 500 can perform the functions described above. Category navigation system 500 can be further coupled to an optional display device 580 (e.g., a monitor, a display pad, a projector, etc.), a keyboard 560, and a pointing device 570, and can be coupled via one or more network interfaces to a network 590.
During operation, system 500 can run as a web server, which receives a search request for a product (e.g., via a port of system 500) from a user and can send one or more categories of the product. Category module 532 adds, deletes, and updates a category. Category module 532 can also maintain a range of category identifiers for a site and allocates a category identifier to a category. Classification module 534 determines whether a category is a differentiated category or a synchronization category. Mapping module 536 establishes a mapping between a category in the main site and the corresponding category in a local site. In some embodiments, this mapping is based on category identifiers. Synchronization module 538 synchronizes operations performed on a synchronized category at the main site with a corresponding category at a respective local site.
Embodiments of the present invention may be implemented on various universal or dedicated computer system environments or configurations. For example, such computer systems may include personal computers, server computers, handheld or portable devices, tablet-type devices, multiprocessor systems, microprocessor-based systems, set-top boxes, programmable electronic consumption devices, network PCs, minicomputers, mainframe computers, distributed computing environments including any of the above systems or devices, and the like.
Embodiments of the present invention may be described within the general context of computer-executable instructions executed by a computer, such as a program module. Generally, the program module includes a routine, a program, an object, an assembly, a data structure and the like for implementing particular tasks or achieving particular abstract data types. Embodiments of the present invention may also be implemented in distributed computing environments, in which tasks are performed by remote processing devices connected via a communication network. In the distributed computing environments, program modules may be located in local and remote computer storage media that may include a storage device.
The data structures and computer instructions described in this detailed description are typically stored on a computer-readable storage medium, which may be any device or medium that can store code and/or data for use by a computer system. The computer-readable storage medium includes, but is not limited to, volatile memory, non-volatile memory, magnetic and optical storage devices such as disk drives, magnetic tape, CDs (compact discs), DVDs (digital versatile discs or digital video discs), or other media capable of storing computer-readable media now known or later developed.
The methods and processes described in the detailed description section can be embodied as code and/or data, which can be stored in a computer-readable storage medium as described above. When a computer system reads and executes the code and/or data stored on the computer-readable storage medium, the computer system performs the methods and processes embodied as data structures and code and stored within the computer-readable storage medium.
Furthermore, methods and processes described herein can be included in hardware modules or apparatus. These modules or apparatus may include, but are not limited to, an application-specific integrated circuit (ASIC) chip, a field-programmable gate array (FPGA), a dedicated or shared processor that executes a particular software module or a piece of code at a particular time, and/or other programmable-logic devices now known or later developed. When the hardware modules or apparatus are activated, they perform the methods and processes included within them.
The above description is presented to enable any person skilled in the art to make and use the embodiments, and is provided in the context of a particular application and its requirements. Various modifications to the disclosed embodiments will be readily apparent to those skilled in the art, and the general principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the present disclosure. Thus, the present invention is not limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features disclosed herein.
Number | Date | Country | Kind |
---|---|---|---|
2015 1 0648622 | Oct 2015 | CN | national |
Number | Name | Date | Kind |
---|---|---|---|
4281391 | Huang | Jul 1981 | A |
6526166 | Gorman | Feb 2003 | B1 |
6697947 | Matyas, Jr. | Feb 2004 | B1 |
6726094 | Rantze | Apr 2004 | B1 |
7044741 | Leem | May 2006 | B2 |
7149720 | Shepherd | Dec 2006 | B2 |
7321874 | Dilip | Jan 2008 | B2 |
7734527 | Uzo | Jun 2010 | B2 |
7809636 | Jou | Oct 2010 | B1 |
7809762 | Parker | Oct 2010 | B1 |
7941760 | Kocienda | May 2011 | B2 |
7946474 | Agrawal | May 2011 | B1 |
7978900 | Nepomniachtchi | Jul 2011 | B2 |
8090642 | Van Doren | Jan 2012 | B1 |
8176324 | Krishnamurthy | May 2012 | B1 |
8280782 | Talreja | Oct 2012 | B1 |
8423392 | Moxley | Apr 2013 | B2 |
8423467 | Johansson | Apr 2013 | B1 |
8645295 | Dillard | Feb 2014 | B1 |
9111073 | Jiang | Aug 2015 | B1 |
9239722 | Calahan | Jan 2016 | B1 |
9621348 | Bahjat | Apr 2017 | B2 |
20020046131 | Boone | Apr 2002 | A1 |
20020111916 | Coronna | Aug 2002 | A1 |
20020161466 | Heching | Oct 2002 | A1 |
20030042301 | Rajasekaran | Mar 2003 | A1 |
20030046150 | Ader | Mar 2003 | A1 |
20030061172 | Robinson | Mar 2003 | A1 |
20030200190 | Adar | Oct 2003 | A1 |
20040139008 | Mascavage | Jul 2004 | A1 |
20040153407 | Clubb | Aug 2004 | A1 |
20050038707 | Roever | Feb 2005 | A1 |
20050071637 | Shirakawa | Mar 2005 | A1 |
20050075954 | Matsumoto | Apr 2005 | A1 |
20050113123 | Torvinen | May 2005 | A1 |
20050144406 | Chong, Jr. | Jun 2005 | A1 |
20050170856 | Keyani | Aug 2005 | A1 |
20050240935 | Ramanathan | Oct 2005 | A1 |
20060010190 | Shimbo | Jan 2006 | A1 |
20060056626 | Keohane | Mar 2006 | A1 |
20060069635 | Ram | Mar 2006 | A1 |
20060089897 | Maas | Apr 2006 | A1 |
20060176847 | Chen | Aug 2006 | A1 |
20060220842 | Breed | Oct 2006 | A1 |
20060271783 | Wong | Nov 2006 | A1 |
20070035617 | Ko | Feb 2007 | A1 |
20070043651 | Xiao | Feb 2007 | A1 |
20070276730 | Lee | Nov 2007 | A1 |
20080004981 | Gopalpur | Jan 2008 | A1 |
20080077542 | McElhiney | Mar 2008 | A1 |
20080097805 | Wells | Apr 2008 | A1 |
20080119160 | Andriantsiferana | May 2008 | A1 |
20080120160 | Woo | May 2008 | A1 |
20080182586 | Aaron | Jul 2008 | A1 |
20080228595 | Hill | Sep 2008 | A1 |
20080306839 | Starrs | Dec 2008 | A1 |
20090076926 | Zinberg | Mar 2009 | A1 |
20090090772 | Lee | Apr 2009 | A1 |
20090106825 | Cerruti | Apr 2009 | A1 |
20090144451 | Cabezas | Jun 2009 | A1 |
20090157522 | Srinivasan | Jun 2009 | A1 |
20090195506 | Geidl | Aug 2009 | A1 |
20100060585 | Chiu | Mar 2010 | A1 |
20100073302 | Ritzau | Mar 2010 | A1 |
20100088026 | Manolescu | Apr 2010 | A1 |
20100162036 | Linden | Jun 2010 | A1 |
20100191648 | Smith | Jul 2010 | A1 |
20100210240 | Mahaffey | Aug 2010 | A1 |
20100223543 | Marston | Sep 2010 | A1 |
20100235283 | Gerson | Sep 2010 | A1 |
20100241575 | Cotton | Sep 2010 | A1 |
20100250436 | Loevenguth | Sep 2010 | A1 |
20110016520 | Cohen | Jan 2011 | A1 |
20110093493 | Nair | Apr 2011 | A1 |
20110125616 | Ni | May 2011 | A1 |
20110184840 | Godard | Jul 2011 | A1 |
20110231465 | Phatak | Sep 2011 | A1 |
20110258027 | Lee | Oct 2011 | A1 |
20110264598 | Fuxman | Oct 2011 | A1 |
20120016799 | Killian | Jan 2012 | A1 |
20120076283 | Ajmera | Mar 2012 | A1 |
20120101942 | Park | Apr 2012 | A1 |
20120117271 | Kennedy | May 2012 | A1 |
20120143924 | Sethi | Jun 2012 | A1 |
20120158467 | Hammad | Jun 2012 | A1 |
20120204256 | Craine | Aug 2012 | A1 |
20120259774 | Marti | Oct 2012 | A1 |
20120259783 | Kemper | Oct 2012 | A1 |
20120299831 | Lioy | Nov 2012 | A1 |
20120323846 | Bai | Dec 2012 | A1 |
20130066889 | Rodriguez | Mar 2013 | A1 |
20130094751 | Nepomniachtchi | Apr 2013 | A1 |
20130110670 | Webber | May 2013 | A1 |
20130232071 | Dilip | Sep 2013 | A1 |
20130246172 | Moissinac | Sep 2013 | A1 |
20130311532 | Olsen | Nov 2013 | A1 |
20130317895 | Turner | Nov 2013 | A1 |
20130331130 | Lee | Dec 2013 | A1 |
20140037184 | Gorski | Feb 2014 | A1 |
20140052636 | Mattes | Feb 2014 | A1 |
20140156512 | Rahman | Jun 2014 | A1 |
20140162698 | Han | Jun 2014 | A1 |
20140164109 | Chow | Jun 2014 | A1 |
20140236801 | Hansen | Aug 2014 | A1 |
20140279525 | Mohsenzadeh | Sep 2014 | A1 |
20140280910 | Swig | Sep 2014 | A1 |
20140306896 | Sosby | Oct 2014 | A1 |
20140310171 | Grossman | Oct 2014 | A1 |
20150066679 | Mack | Mar 2015 | A1 |
20150186989 | Kneen | Jul 2015 | A1 |
20150220876 | Sethi | Aug 2015 | A1 |
20150235477 | Simkin | Aug 2015 | A1 |
20150356288 | Guo | Dec 2015 | A1 |
20150379460 | Zamer | Dec 2015 | A1 |
20160012503 | Fu | Jan 2016 | A1 |
20160055490 | Keren | Feb 2016 | A1 |
20160077734 | Buxton | Mar 2016 | A1 |
20170270598 | Ram | Sep 2017 | A1 |
Number | Date | Country |
---|---|---|
201498035 | Jun 2010 | CN |
102004047258 | Apr 2006 | DE |
0992949 | Apr 2000 | EP |
1067471 | Jan 2001 | EP |
10240690 | Sep 1998 | JP |
2000082101 | Mar 2000 | JP |
2001297283 | Oct 2001 | JP |
2003271851 | Sep 2003 | JP |
2006259854 | Sep 2006 | JP |
2008532112 | Aug 2008 | JP |
2009020676 | Jan 2009 | JP |
2014515149 | Jun 2014 | JP |
1020020057906 | Jul 2002 | KR |
2012045128 | Apr 2012 | WO |
2013003372 | Jan 2013 | WO |
2013149883 | Oct 2013 | WO |
2017080768 | May 2017 | WO |
Number | Date | Country | |
---|---|---|---|
20170103118 A1 | Apr 2017 | US |