WO2011119676A1 - Cloud-based web content filtering - Google Patents

Cloud-based web content filtering Download PDF

Info

Publication number
WO2011119676A1
WO2011119676A1 PCT/US2011/029534 US2011029534W WO2011119676A1 WO 2011119676 A1 WO2011119676 A1 WO 2011119676A1 US 2011029534 W US2011029534 W US 2011029534W WO 2011119676 A1 WO2011119676 A1 WO 2011119676A1
Authority
WO
WIPO (PCT)
Prior art keywords
web content
filtering rules
content filtering
client
rules
Prior art date
Application number
PCT/US2011/029534
Other languages
French (fr)
Inventor
Mario Vuksan
Vedran Novoselac
Mario Matijasevic
Original Assignee
Securityheroes, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Securityheroes, Inc. filed Critical Securityheroes, Inc.
Priority to CA2793960A priority Critical patent/CA2793960C/en
Priority to ES11714614T priority patent/ES2786030T3/en
Priority to EP11714614.2A priority patent/EP2550607B1/en
Publication of WO2011119676A1 publication Critical patent/WO2011119676A1/en
Priority to HRP20200730TT priority patent/HRP20200730T1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/30Information retrieval; Database structures therefor; File system structures therefor of unstructured textual data
    • G06F16/33Querying
    • G06F16/335Filtering based on additional data, e.g. user or group profiles
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/953Querying, e.g. by the use of web search engines
    • G06F16/9535Search customisation based on user profiles and personalisation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/567Integrating service provisioning from a plurality of service providers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/63Routing a service request depending on the request content or context

Definitions

  • the present disclosure generally relates to web content filtering, and more particularly relates to cloud-based web content filtering.
  • Web content filtering is commonly utilized to optimize system performance during consumption of web content, to provide improved security while consuming web content, as well as to improve the web content consumption experience.
  • Often features such as advertisements, explicit material, trackers, and the like may be blocked to achieve the above aims.
  • Such content may be blocked based upon rules that may be locally stored on the computing device through which the web content is accessed. As such, the available storage for content blocking rules may be limited, and the rules may require updating to provide acceptable levels of content blocking.
  • a method includes maintaining, by a computing device, a data store including a plurality of web content filtering rules.
  • a filtering rules query is received from a client device, via a network, in response to the client device requesting web content.
  • One or more web content filtering rules are transmitted to the client device via the network.
  • the network may include one or more of a local area network, a wide area network, and an Internet.
  • the method may further include receiving, from the client device, a web content filter rule submission.
  • the plurality of web content filtering rules may be updated based upon, at least in part, the web content filter rule submission.
  • a validity of the web content filter rule submission may be determined.
  • the one or more web content filtering rules may be based upon, at least in part, an external source.
  • the method may also include associating at least one category identifier with at least a portion of the plurality of web content filtering rules.
  • the category identifier may be indicative of one or more of a content type, and a content function.
  • Transmitting one or more web content filtering rules to the client device may include transmitting one or more web content filtering rules based upon, at least in part, a user defined category identifier.
  • the method may also include transmitting one or more filtered content rendering rules to the client device.
  • the one or more filtered content rendering rules including instructions for rendering the requested web content.
  • the method may also include defining a client group. At least a portion of the web content filtering rules may be associated with the client group. Web content filtering rules may be transmitted to the client device based upon, at least in part, participation of the client device in the client group.
  • the client group may include one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
  • a computer program product resides on a computer readable medium having a plurality of instructions stored on it. When executed by a processor, the instructions cause the processor to perform operations including maintaining a data store including a plurality of web content filtering rules. Instructions are also included for receiving a filtering rules query from a client device, via a network, in response to the client device requesting web content. One or more web content filtering rules are transmitted to the client device via the network.
  • the network may include one or more of a local area network, a wide area network, and an Internet. Instructions may be included for receiving, from the client device, a web content filter rule submission. The plurality of web content filtering rules may be updated based upon, at least in part, the web content filter rule submission. Instructions may be included for determining a validity of the web content filter rule submission. The one or more web content filtering rules may be based upon, at least in part, an external source.
  • Instructions may be included for associating at least one category identifier with at least a portion of the plurality of web content filtering rules.
  • the category identifier may be indicative of one or more of a content type, and a content function.
  • the instructions for transmitting one or more web content filtering rules to the client device may include instructions for transmitting one or more web content filtering rules based upon, at least in part, a user defined category identifier.
  • Instructions may also be included for transmitting one or more filtered content rendering rules to the client device.
  • the one or more filtered content rendering rules may include instructions for rendering the requested web content.
  • Instructions may be included for defining a client group. At least a portion of the web content filtering rules may be associated with the client group. Web content filtering rules may be transmitted to the client device based upon, at least in part, participation of the client device in the client group.
  • the client group may include one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
  • a method includes receiving, by a computing device, an indication of a request for web content.
  • a query for web content filtering rules is generated based upon, at least in part, the request for web content.
  • the query for web content filtering rules is transmitted to a data store including a plurality of web content filtering via a network.
  • One or more web content filtering rules are received from the data store.
  • the web content is filtered based upon, at least in part, the received on or more web content filtering rules.
  • the network may include one or more of a local area network, a wide area network, and an Internet.
  • the method may include generating a web content filter rule submission.
  • the web content filter rule submission may be transmitted to the data store.
  • At least one category identifier may be associated with at least a portion of the plurality of web content filtering rules.
  • the category identifier may be indicative of one or more of a content type, and a content function.
  • Transmitting the query for web content filtering rules to the client device may include transmitting the query for web content filtering rules based upon, at least in part, a user defined category identifier.
  • One or more filtered content rendering rules may be received from the data store.
  • the one or more filtered content rendering rules may include instructions for rendering the requested web content.
  • the method may include defining a client group. At least a portion of the web content filtering rules may be associated with the client group. Web content filtering rules may be received by the client device based upon, at least in part, participation of the client device in the client group.
  • the client group may include one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
  • a computer program product resides on a computer readable medium having a plurality of instructions stored on it.
  • the instructions When executed by a processor, the instructions cause the processor to perform operations including receiving an indication of a request for web content.
  • a query for web content filtering rules is generated based upon, at least in part, the request for web content.
  • the query for web content filtering rules is transmitted to a data store including a plurality of web content filtering via a network.
  • One or more web content filtering rules are received from the data store.
  • the web content is filtered based upon, at least in part, the received one or more web content filtering rules.
  • the network may include one or more of a local area network, a wide area network, and an Internet. Instructions may be included for generating a web content filter rule submission.
  • the web content filter rule submission may be transmitted to the data store.
  • At least one category identifier may be associated with at least a portion of the plurality of web content filtering rules.
  • the category identifier may be indicative of one or more of a content type, and a content function.
  • the instructions for transmitting the query for web content filtering rules to the client device may include instructions for transmitting the query for web content filtering rules based upon, at least in part, a user defined category identifier.
  • Instructions may be included for receiving one or more filtered content rendering rules from the data store.
  • the one or more filtered content rendering rules may include instructions for rendering the requested web content.
  • Instructions may also be included for defining a client group. At least a portion of the web content filtering rules may be associated with the client group. Web content filtering rules may be received by the client device based upon, at least in part, participation of the client device in the client group.
  • the client group may include one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
  • FIG. 1 diagrammatically depicts a filter process coupled to a distributed computing network.
  • FIG. 2 is a flow chart of a process executed by the server-side filter process of FIG. 1.
  • FIG. 3 is a flow chart of a process executed by the client-side filter process of FIG. 1.
  • FIG. 4 diagrammatically depicts web content rendered by a web browser of FIG. 1.
  • FIG. 5 diagrammatically depicts web content rendered by a web browser of FIG. 1.
  • FIG. 6 diagrammatically depicts web content rendered by a web browser of FIG. 1.
  • the present invention may be embodied as a method, system, or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a "circuit,” "module” or “system.” Furthermore, the present invention may take the form of a computer program product on a computer-usable storage medium having computer-usable program code embodied in the medium.
  • the computer readable medium may be a computer readable signal medium or a computer readable storage medium.
  • a computer-usable, or computer-readable, storage medium (including a storage device associated with a computing device or client electronic device) may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing.
  • a computer-usable, or computer-readable, storage medium may be any tangible medium that can contain, or store a program for use by or in connection with the instruction execution system, apparatus, or device.
  • a computer readable signal medium may include a propagated data signal with computer readable program coded embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof.
  • a computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
  • Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
  • Computer program code for carrying out operations of the present invention may be written in an object oriented programming language such as Java, Smalltalk, C++ or the like.
  • the computer program code for carrying out operations of the present invention may also be written in conventional procedural programming languages, such as the "C" programming language or similar programming languages.
  • the program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server.
  • the remote computer may be connected to the user's computer through a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
  • LAN local area network
  • WAN wide area network
  • Internet Service Provider for example, AT&T, MCI, Sprint, EarthLink, MSN, GTE, etc.
  • These computer program instructions may also be stored in a computer- readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
  • the computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
  • filter process 10 may reside on and may be executed by server computer 12, which may be connected to network 14 (e.g., the Internet or a local area network).
  • server computer 12 may include, but are not limited to: a personal computer, a server computer, a series of server computers, a mini computer, and a mainframe computer.
  • Server computer 12 may be a web server (or a series of servers) running a network operating system, examples of which may include but are not limited to: Microsoft® Windows® Server; Novell® NetWare®; or Red Hat® Linux®, for example.
  • the filter process may reside on and be executed, in whole or in part, by a client electronic device, such as a personal computer, notebook computer, personal digital assistant, or the like.
  • filter process 10 may maintain a data store including a plurality of web content filtering rules.
  • Filter process 10 may also receive a filtering rules query from a client device, via a network, in response to the client device requesting web content.
  • Filter process 10 may further transmit one or more web content filtering rules to the client device via the network.
  • the instruction sets and subroutines of filter process 10 may include one or more software modules, and which may be stored on storage device 16 coupled to server computer 12, may be executed by one or more processors (not shown) and one or more memory modules (not shown) incorporated into server computer 12.
  • Storage device 16 may include but is not limited to: a hard disk drive; a solid state drive, a tape drive; an optical drive; a RAID array; a random access memory (RAM); and a read-only memory (ROM).
  • Server computer 12 may execute a web server application, examples of which may include but are not limited to: Microsoft IIS , Novell WebserverTM, or Apache® Webserver, that allows for HTTP (i.e., HyperText Transfer Protocol) access to server computer 12 via network 14
  • Webserver is a trademark of Novell Corporation in the United States, other countries, or both
  • Apache is a registered trademark of Apache Software Foundation in the United States, other countries, or both
  • Network 14 may be connected to one or more secondary networks (e.g., network 18), examples of which may include but are not limited to: a local area network; a wide area network; or an intranet, for example.
  • Server computer 12 may execute a data store application (e.g., data store application 20), examples of which may include, but is not limited to e.g., a database.
  • Data store application 20 may include / maintain a plurality of web content filtering rules that may be utilized by a client web browser application (e.g., web browsers 22, 24, 26, 28) for filtering web content.
  • client web browser application e.g., web browsers 22, 24, 26, 28
  • Examples of web browsers 22, 24, 26, 28 may include, but are not limited to, e.g., Microsoft Internet Explorer®, Apple® Safari®, etc.
  • Internet Explorer is a registered trademark of Microsoft Corporation in the United States, other countries, or both
  • Apple and Safari are registered trademarks of Apple Inc. in the United States, other countries, or both).
  • Filter process 10 may be a stand alone application, or may be an applet / application / script that may interact with and/or be executed within data store application 20.
  • the filter process may include a client-side process (described below) that may reside on a client electronic device (described below) and may interact with a web browser (e.g., one or more of web browsers 22, 24, 26, 28).
  • the filter process may be a hybrid server-side / client-side process that may interact with data store application 20 and a web browser (e.g., one or more of web browsers 22, 24, 26, 28).
  • the filter process may reside, in whole, or in part, on server computer 12 and/or one or more client electronic devices.
  • the instruction sets and subroutines of data store application 20, which may be stored on storage device 16 coupled to server computer 12 may be executed by one or more processors (not shown) and one or more memory modules (not shown) incorporated into server computer 12.
  • Storage devices 30, 32, 34, 36 may include but are not limited to: hard disk drives; solid state drives, tape drives; optical drives; RAID arrays; random access memories (RAM); read-only memories (ROM), compact flash (CF) storage devices, secure digital (SD) storage devices, and a memory stick storage devices.
  • client electronic devices 38, 40, 42, 44 may include, but are not limited to, personal computer 38, laptop computer 40, mobile computing device 42 (such as a smart phone, net book, or the like), notebook computer 44, for example.
  • web browsers 22, 24, 26, 28, users 46, 48, 50, 52 may access web content (e.g., web pages, web applications, and the like) via one or more of networks 14, 18. Additionally, using web browsers 22, 24, 26, 28, users 46, 48, 50, 52 may access web content filtering rules included in / maintained by data store application 20 to thereby filter accessed web content.
  • the filter process may reside, in whole or in part, on a client electronic device (e.g., client electronic device 38, 40, 42, 44).
  • client electronic devices 38, 40, 42, 44 may respectively execute a client-side filter process (e.g., filter processes 54, 56, 58, 60).
  • Filter processes 54, 56, 58, 60 may each include a stand alone application, or may be an applet / application / script that may interact with and/or be executed within web browsers 22, 24, 26, 28.
  • the instruction sets and subroutines of filter processes 54, 56, 58, 60 which may be stored on storage devices 30, 32, 34, 36 (respectively) coupled to client electronic devices 38, 40, 42, 44 (respectively), may be executed by one or more processors (not shown) and one or more memory modules (not shown) incorporated into client electronic devices 38, 40, 42, 44 (respectively).
  • the client-side filter process may receive an indication of a request for web content.
  • a query for web content filtering rules may be generated based upon, at least in part, the request for web content.
  • the query for web content filtering rules may be transmitted to a data store (e.g., data store 20) including a plurality of web content filtering via a network.
  • One or more web content filtering rules may be received from the data store.
  • the web content may be filtered based upon, at least in part, the received on or more web content filtering rules.
  • Users 46, 48, 50, 52 may access data store application 20 directly through the device on which the web browser (e.g., web browsers 22, 24, 26, 28) is executed, namely client electronic devices 38, 40, 42, 44, for example. Users 46, 48, 50, 52 may access data store application 20 directly through network 14 or through secondary network 18. Further, server computer 12 (i.e., the computer that executes scheduling application 20) may be connected to network 14 through secondary network 18, as illustrated with phantom link line 62.
  • server computer 12 i.e., the computer that executes scheduling application 20
  • the various client electronic devices may be directly or indirectly coupled to network 14 (or network 18).
  • personal computer 38 is shown directly coupled to network 14 via a hardwired network connection.
  • notebook computer 44 is shown directly coupled to network 18 via a hardwired network connection.
  • Laptop computer 40 is shown wirelessly coupled to network 14 via wireless communication channel 64 established between laptop computer 40 and wireless access point (i.e., WAP) 66, which is shown directly coupled to network 14.
  • WAP 66 may be, for example, an IEEE 802.11a, 802.1 1b, 802. l lg, Wi-Fi, EDGE, 3G, Wi-MAX and/or Bluetooth device that is capable of establishing wireless communication channel 64 between laptop computer 40 and WAP 66.
  • Mobile computing device 42 is shown wirelessly coupled to network 14 via wireless communication channel 68 established between mobile computing device 42 and cellular network / bridge 70, which is shown directly coupled to network 14.
  • IEEE 802. l lx specifications may use Ethernet protocol and carrier sense multiple access with collision avoidance (i.e., CSMA/CA) for path sharing.
  • the various 802.1 lx specifications may use phase-shift keying (i.e., PSK) modulation or complementary code keying (i.e., CCK) modulation, for example.
  • PSK phase-shift keying
  • CCK complementary code keying
  • Bluetooth is a telecommunications industry specification that allows e.g., mobile phones, computers, and personal digital assistants to be interconnected using a short-range wireless connection.
  • Client electronic devices 38, 40, 42, 44 may each execute an operating system, examples of which may include but are not limited to Microsoft Windows, Microsoft Windows CE®, Red Hat Linux, or other suitable operating system.
  • Microsoft Windows is a registered trademark of Microsoft Corporation in the United States, other countries, or both.
  • Windows CE is a registered trademark of Microsoft Corporation in the United States, other countries, or both.
  • web browser 22 and filter application 54 may be discussed. However, this is for illustrative purposes only and should not be construed as a limitation of the present disclosure, as other web browsers (e.g., web browsers 24, 26, 28) and other filter processes (e.g., filter processes 56, 58, 60) may be equally utilized.
  • web browsers e.g., web browsers 24, 26, 28
  • filter processes e.g., filter processes 56, 58, 60
  • GUIS. 2 and 3 assume that user 45 is accessing web content using web browser 22.
  • User 46 may input a request for web content into browser 22 (e.g., by entering a universal resource locator, "URL", into web browser 22 using an input device, such as a keyboard, associated with computing device 36).
  • the web content may include, but is not limited to, a web page, a web application, or the like.
  • filter process 54 e.g., which may be integrated into or otherwise interact with web browser 22
  • filter process 54 may generate 152 a query for web content filtering rules based upon, at least in part, the received 150 request for web content.
  • the generated 152 query for web content filtering rules may include, for example, an identifier of the requested web content, such as the requested URL, or other identifier of the requested web content.
  • Filter process 54 may further transmit 154 the query for web content filtering rules to a data store (e.g., data store 20, alone and/or in conjunction with filter process 10) including a plurality of web content filtering rules.
  • the query may be transmitted 154 via a network, such as network 14, or 18.
  • networks 14, 18 may include, for example, local area networks, wide area networks, the internet, or other such computing network.
  • Filter process 10 may maintain 100 data store 20, which may include a plurality of web content filtering rules.
  • Filter process 10 may receive 102 the filtering rules query transmitted 154 in response to the requested web content by client device 38 (e.g., transmitted by filter process 54 and/or web browser 22).
  • Filter process 10 may execute the received 102 filtering rules query over data store 20, which may return a results set of web content filtering rules applicable to the web content requested by client device 38 (e.g., via web browser 22).
  • Filter process 10 may transmit 104 one or more web content filtering rules to client device 38 via networks 14, 18.
  • the one or more web content filtering rules may, for example, identify portions, components, features, or the like, of the requested web content that may be blocked, disabled, or removed from the requested web content prior to, and/or during, rendering of the web content by a web browser (such as, for example, web browser 22).
  • filter process 10 may optionally also transmit general web content filtering rules.
  • filter process 10 may, for example, transmit a list of known ad-servers, URL's associated with malicious content, pornographic content, etc., as may be generally known.
  • the optional transmission of general web content filtering rules may be configured according to system and/or user preferences, which may be defined in a conventional manner (e.g., via preference configuration settings and graphical user interfaces).
  • Filter process 54 may receive 156 the one or more web content filtering rules transmitted 104 by filter process 10. Further, filter process 54 (alone and/or in conjunction with web browser 22) may filter 158 the web content (e.g., which may be received by web browser 22 based upon the request for the web content) based upon, at least in part, the received 156 one or more web content filtering rules. For example, filtering 158 the received web content may include blocking, disabling, and/or removing portions of the requested web content, and/or features or components within the requested web content as, or before, the requested web content is rendered by web browser 22.
  • filtering 158 the received web content may include blocking advertisements included within the web content, disabling and/or blocking selected java script or flash items, or otherwise blocking, removing, disabling, or the like, selected portions of the requested web content or features or components of the requested web content.
  • the requested web content may be displayed having portions, features, or components blocked, removed, or disabled, based upon, at least in part, the one or more web content filtering rules.
  • data store 20 may include large sets of web content filtering rules, for example which may consume large amounts of memory and storage to the point of being impractical or inconvenient to store on a client electronic device. This may be especially true for constrained devices, such as tablets, net books, smart phones, and the like, which may have relatively small amounts of available storage. Additionally, as the web content filtering rules may be stored in a central data store (e.g., data store 20), any updates or changes to the web content filtering rules may be immediately implemented and available to all users, without the need to update a local repository of filtering rules.
  • a central data store e.g., data store 20
  • At least a portion of the received 156 web content filtering rules may be locally cached (e.g., by filter process 55 and/or web browser 22). As such, the locally cached web content filtering rules may be available without subsequent requests to filter process 10. Such locally cached rules may be applicable to other web content associated with a common domain, or the like.
  • filter process(s) 10, 55 may utilize a network caching infrastructure and/or utilize a content delivery network arrangement.
  • at least a portion of the web content filtering rules (and/or a copy of at least a portion of the web content filtering rules) may additionally be stored on a network accessible storage device accessible by client device 38 (in the foregoing example).
  • filter process 55 may access at least a portion of the web content filtering rules from either data store 20 or the network accessible storage device (e.g., depending upon available bandwidth, or other networking considerations).
  • filter process 10 may leverage a user community to aid in building a robust catalog of web content filtering rules.
  • filter process 10 may provide a mechanism for receiving user submissions of suggested web content filtering rules.
  • the available web content filtering rules may similarly expand.
  • requested web content (e.g., web page) 200 may be rendered via web browser 22.
  • Web page 200 may include first web content 202, such as an article or other content.
  • web page 200 may include feature 204 that user 46 believes should be filtered.
  • feature 204 may include an advertisement, flash content, pornographic content, a tracker, a widget, unrelated content panel, or any other content that user 46 may consider worthy of blocking.
  • User 46 may mark feature 204 as content to be filtered.
  • user 46 may select, via onscreen pointer 206 (which may be controlled by a pointing device, such as a mouse or gestural touch-screen interface; not shown) feature 204 by right clicking feature 204.
  • filter process 54 (alone or in conjunction with web browser 22) may generate popup 208. While popup 208 is shown including a single option (namely "mark content for filtering") other options (e.g., an identifier of the category of the content, etc.) may be included within popup 208 depending upon design criteria and user need.
  • User 46 may select, via onscreen pointer 206, the option "mark content for filtering" from within popup 208.
  • filter process 54 may transmit 162 the web content filter rule submission to data store 20. Transmitting 162 the web content filter rule submission may include transmitting an identifier of web page 200 (e.g., may transmit the URL or other identifier of the web page or web application), and/or may transmit an identifier of feature 204 (e.g., may transmit a link associated with feature 204, html code or java script, etc., associated with feature 204, or the like).
  • Filter process 10 may receive 106 the web content filter rule submission from filter process 54.
  • filter process 10 may update 108 the plurality of web content filtering rules (included within data store 20) based upon, at least in part, the web content filter rule submission.
  • filter process 10 may create a new web content filtering rule (and/or update an existing web content filtering rule) based upon, at least in part, the received 106 web content filter rule submission.
  • a new web content filter rule may include an identifier of the URL associated with web page 200 (e.g., the URL of the web page) as well as an identifier associated with feature 204.
  • Filter process 10 may, in some embodiments, determine 1 10 the validity of the web content filter rule submission. According to one aspect, it may be possible for filter process 10 to automatically determine 1 10 the validity of the web content filter rule submission. For example, a like associated with feature 204 may be correlated to a known ad-server, or other automatically identifiable source of content that may desirably be filtered. Additionally / alternatively, the received 106 web content filter rule submission may be manually examined by a support representative. In such an embodiment, filter process 10 may determine 1 10 the validity of the web content filter rule submission based upon an indication input by the support representative.
  • filter process 10 may update 108 the plurality of web content filtering rules based upon, at least in part, the web content filtering rule submission.
  • the updated rules may be immediately accessible by users of the system. Consistent with this aspect, as the number or user submissions increases, the web content filtering rules included within date store 20 may increase, and may provide enriched filtering capacity.
  • web content filtering rules may be based upon, at least in part, external sources. Such external sources may arise, for example, from third party feeds or information.
  • the web content filtering rules based upon, at least in part, external sources may, for example, allow potentially malicious content to be filtered out of requested web content (e.g., web page 200).
  • Various examples of web content filtering rules may relate to filtering content such as advertisements, malicious features, objectionable content, items (content, features, components, or the like) that may give rise to privacy concerns (e.g., trackers) or performance concerns.
  • web content filtering rules may relate to filtering any web content (e.g., content included within a web page or web application, portions of content within a web page or web application, features or components included within the web page or web application, such as java script items, flash items, etc.) that may be unwanted by a user, an administrator, a vendor, or the like, regardless of the nature of the web content.
  • the content to be filtered need not be functional, or even visible to a consumer of the requested web content (e.g., the web page or web application).
  • content may be filtered (e.g., based upon, at least in part, a web content filtering rule) based upon, at least in part, a corporate policy (e.g., no hate speech or content unrelated to the business of the corporation), law (e.g., no access to gambling web applications or fragments), to trust (e.g., parental control and non-work related web sites and applications) or the like.
  • a corporate policy e.g., no hate speech or content unrelated to the business of the corporation
  • law e.g., no access to gambling web applications or fragments
  • to trust e.g., parental control and non-work related web sites and applications
  • filter process 10 may associate 112 at least one category identifier with at least a portion of the plurality of web content filtering rules included within data store 20.
  • category identifiers may indicate that a given rule is directed at filtering advertising material, trackers, widgets, unrelated content panes such as market places or blogs, or any other category of content that may be filtered based upon, at least in part, the given web content filtering rule.
  • the category identifier may be indicative of one or more of a content type, and a content function.
  • the associated 112 category identifier may include a tag, a relational feature, or the like, associated with a given web content filtering rule, or collection of web content filtering rules.
  • one or more of filter processes 10, 54 may allow a category identifier to also be associated 1 12 with the feature.
  • transmitting 154 the query for web content filtering rules by the client device may include transmitting 164 the query for web content filtering rules based upon, at least in part, a user defined category identifier.
  • filter process 54 may allow user 46 to specify preferences of categories of web content to be filtered.
  • user 46 may specify preferences to filter advertisements and trackers, but not to filter widgets.
  • transmitting 154 the query for web content filtering rules may include transmitting 164 the query for web content filtering rules only for advertisements and trackers, but not for widgets.
  • various additional / alternative preferences of web content categories may be specified.
  • Transmitting 104 one or more web content filtering rules to the client device may include transmitting one or more web content filtering rules based upon, at least in part, a user defined category identifier.
  • filter process 54 may transmit 164 the query for web content based upon, at least in part, a user defined category identifier
  • filter process 10 may execute a query over data store 20 relative to the web content requested by web browser 22 and the user defined category identifiers.
  • a user profile may be maintained by filter process 10. Accordingly, all queries for web content filtering rules by user 46 may be based upon, at least in part, the user defined category identifiers.
  • Filter process 104 may transmit one or more web content filtering rules based upon, at least in part, a user defined category identifier to client device 38.
  • filtering processes 10, 54 may provide options for rendering filtered web content. That is, the manner in which the region of the requested web content (e.g., web page 200) corresponding to the filtered web content (e.g., feature 204 in the foregoing examples) may be rendered according to various preferences or rules.
  • filter process 10 may transmit 114 a content rendering rule to the client device (e.g., client device 38).
  • the content rendering rule may include instructions (e.g., which may be utilized by filter process 54 and / web browser 22) for rendering the requested web content (e.g., web page 200).
  • filter process 54 may receive 166 the one or more filtered content rendering rules from data store. Filter process 54 may render the requested web content (e.g., web page 200) according to the instructions of the filtered content rendering rules.
  • the content rending rule may include instructions for omitting the filtered web content (e.g., feature 204).
  • web page 200 may include a blank region corresponding to the location of feature 204.
  • the rendering instructions may include instructions to close up the text, thereby providing an uninterrupted paragraph of text.
  • other features may be placed in the region of web page corresponding to filtered web content (e.g., feature 204). For example, as shown in FIG.
  • the feature 204 may be replaced by a phantom box, thereby providing a visual indicator that web content has been filtered from web page 204.
  • Various additional / alternative images, animations, etc. may similarly be displayed in the region corresponding to the filtered web content.
  • an image such as a corporate logo, or other image, may be place in the region corresponding to feature 204, which has been filtered from web page 200.
  • the content rendering rules may allow the filtered web content (e.g., feature 204 within web page 200) may be replaced by content from a dynamic source.
  • dynamic sources may include, for example, content from another ad server, social network site or page, a web feed, or an external database.
  • Various additional / alternative implementations may be equally utilized.
  • filter process 54 may provide for user preferences for rendering filtered web content. For example, user 46 may specify (e.g., via one or more of filter process 54 and web browser 22) how filtered web content should be rendered. As such, user 46 may customize the appearance of rendered web content having filtered features.
  • the filtering process herein may allow web content filtering across multiple client devices or users.
  • such an aspect may be implemented in an enterprise environment, a social network, or other group-level environment.
  • a central administrator may establish web content filtering rules that may be implemented across more than one client electronic device or user.
  • the filter process herein may provide filtering of individual items of web content within, e.g., a web page, web application, or the like.
  • group-level filtering profiles may be defined and implemented across multiple client devices and/or user profiles (e.g., based upon, at least in part, user provided login credentials, licensing keys or the like).
  • one or more of filter processes 10, 54 may define 1 16, 168 a client group.
  • user 46 may be an administrative user. User 46 may, accordingly, input a user group (e.g., including one or more identified client electronic devices, such as 40, 42, 44; or one or more users, such as user 48, 50, 52 based upon user profiles, user credentials, or the like).
  • One or more of filter processes 10, 54 may define 1 16, 186 the client group based upon, at least in part, the input from user 46. At least a portion of the web content filtering rules may be associated 1 18, 170 with the client group. For example, web content filtering rules based upon categories of web content to be filtered may be associated 118, 170 with the client group.
  • the web content filtering rules associated 1 18, 170 with the client group may specify that advertisements and trackers should be filtered. Other variations may equally be utilized.
  • Web content filtering rules may be transmitted 104 by filter process 10 and received 156 by one or more of filter processes 56, 58, 60 based upon, at least in part participation of the client device (e.g., devices 40, 42, 44) in the client group.
  • the respective client devices 40, 42, 44 may participate in the client group by virtue of having been specifically identified as participating the client group, by virtue of residing on a commonly controlled and specified network, by virtue of a specified user being logged onto one of the client devices, or the like.
  • the client group may include one or more of a defined plurality of users, a plurality of client devices associated with a group network, or other similar association.
  • each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s).
  • the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved.

Abstract

A method of filtering web content including maintaining a data store including a plurality of web content filtering rules. A filtering rules query is received from a client device via a network in response to the client device requesting web content. One or more web content filtering rules are transmitted to the client device via the network.

Description

CLOUD-BASED WEB CONTENT FILTERING
CROSS-REFERENCE TO RELATED APPLICATION
[0001] This application claims the benefit of U.S. provisional patent application Serial No. 61/316,609, filed on 23 March 2010, the entire disclosure of which is incorporated herein by reference.
TECHNICAL FIELD
[0002] The present disclosure generally relates to web content filtering, and more particularly relates to cloud-based web content filtering.
BACKGROUND OF THE DISCLOSURE
[0003] Web content filtering is commonly utilized to optimize system performance during consumption of web content, to provide improved security while consuming web content, as well as to improve the web content consumption experience. Often features such as advertisements, explicit material, trackers, and the like may be blocked to achieve the above aims. Such content may be blocked based upon rules that may be locally stored on the computing device through which the web content is accessed. As such, the available storage for content blocking rules may be limited, and the rules may require updating to provide acceptable levels of content blocking.
SUMMARY OF THE DISCLOSURE
[0004] According to a first implementation a method includes maintaining, by a computing device, a data store including a plurality of web content filtering rules. A filtering rules query is received from a client device, via a network, in response to the client device requesting web content. One or more web content filtering rules are transmitted to the client device via the network.
[0005] One or more of the following features may be included. The network may include one or more of a local area network, a wide area network, and an Internet. The method may further include receiving, from the client device, a web content filter rule submission. The plurality of web content filtering rules may be updated based upon, at least in part, the web content filter rule submission. A validity of the web content filter rule submission may be determined. The one or more web content filtering rules may be based upon, at least in part, an external source.
[0006] The method may also include associating at least one category identifier with at least a portion of the plurality of web content filtering rules. The category identifier may be indicative of one or more of a content type, and a content function. Transmitting one or more web content filtering rules to the client device may include transmitting one or more web content filtering rules based upon, at least in part, a user defined category identifier. The method may also include transmitting one or more filtered content rendering rules to the client device. The one or more filtered content rendering rules including instructions for rendering the requested web content.
[0007] The method may also include defining a client group. At least a portion of the web content filtering rules may be associated with the client group. Web content filtering rules may be transmitted to the client device based upon, at least in part, participation of the client device in the client group. The client group may include one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
[0008] According to another implementation, a computer program product resides on a computer readable medium having a plurality of instructions stored on it. When executed by a processor, the instructions cause the processor to perform operations including maintaining a data store including a plurality of web content filtering rules. Instructions are also included for receiving a filtering rules query from a client device, via a network, in response to the client device requesting web content. One or more web content filtering rules are transmitted to the client device via the network.
[0009] One or more of the following features may be included. The network may include one or more of a local area network, a wide area network, and an Internet. Instructions may be included for receiving, from the client device, a web content filter rule submission. The plurality of web content filtering rules may be updated based upon, at least in part, the web content filter rule submission. Instructions may be included for determining a validity of the web content filter rule submission. The one or more web content filtering rules may be based upon, at least in part, an external source.
[0010] Instructions may be included for associating at least one category identifier with at least a portion of the plurality of web content filtering rules. The category identifier may be indicative of one or more of a content type, and a content function. The instructions for transmitting one or more web content filtering rules to the client device may include instructions for transmitting one or more web content filtering rules based upon, at least in part, a user defined category identifier. Instructions may also be included for transmitting one or more filtered content rendering rules to the client device. The one or more filtered content rendering rules may include instructions for rendering the requested web content.
[0011] Instructions may be included for defining a client group. At least a portion of the web content filtering rules may be associated with the client group. Web content filtering rules may be transmitted to the client device based upon, at least in part, participation of the client device in the client group. The client group may include one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
[0012] According to another implementation, a method includes receiving, by a computing device, an indication of a request for web content. A query for web content filtering rules is generated based upon, at least in part, the request for web content. The query for web content filtering rules is transmitted to a data store including a plurality of web content filtering via a network. One or more web content filtering rules are received from the data store. The web content is filtered based upon, at least in part, the received on or more web content filtering rules.
[0013] One or more of the following features may be included. The network may include one or more of a local area network, a wide area network, and an Internet. The method may include generating a web content filter rule submission. The web content filter rule submission may be transmitted to the data store. At least one category identifier may be associated with at least a portion of the plurality of web content filtering rules. The category identifier may be indicative of one or more of a content type, and a content function.
[0014] Transmitting the query for web content filtering rules to the client device may include transmitting the query for web content filtering rules based upon, at least in part, a user defined category identifier. One or more filtered content rendering rules may be received from the data store. The one or more filtered content rendering rules may include instructions for rendering the requested web content. [0015] The method may include defining a client group. At least a portion of the web content filtering rules may be associated with the client group. Web content filtering rules may be received by the client device based upon, at least in part, participation of the client device in the client group. The client group may include one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
[0016] According to another implementation, a computer program product resides on a computer readable medium having a plurality of instructions stored on it. When executed by a processor, the instructions cause the processor to perform operations including receiving an indication of a request for web content. A query for web content filtering rules is generated based upon, at least in part, the request for web content. The query for web content filtering rules is transmitted to a data store including a plurality of web content filtering via a network. One or more web content filtering rules are received from the data store. The web content is filtered based upon, at least in part, the received one or more web content filtering rules.
[0017] One or more of the following features may be included. The network may include one or more of a local area network, a wide area network, and an Internet. Instructions may be included for generating a web content filter rule submission. The web content filter rule submission may be transmitted to the data store. At least one category identifier may be associated with at least a portion of the plurality of web content filtering rules. The category identifier may be indicative of one or more of a content type, and a content function. The instructions for transmitting the query for web content filtering rules to the client device may include instructions for transmitting the query for web content filtering rules based upon, at least in part, a user defined category identifier. Instructions may be included for receiving one or more filtered content rendering rules from the data store. The one or more filtered content rendering rules may include instructions for rendering the requested web content.
[0018] Instructions may also be included for defining a client group. At least a portion of the web content filtering rules may be associated with the client group. Web content filtering rules may be received by the client device based upon, at least in part, participation of the client device in the client group. The client group may include one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
[0019] The details of one or more implementations are set forth in the accompanying drawings and the description below. Other features will become apparent from the description, the drawings, and the claims.
BRIEF DESCRIPTION OF THE DRAWINGS
[0020] FIG. 1 diagrammatically depicts a filter process coupled to a distributed computing network.
[0021] FIG. 2 is a flow chart of a process executed by the server-side filter process of FIG. 1.
[0022] FIG. 3 is a flow chart of a process executed by the client-side filter process of FIG. 1.
[0023] FIG. 4 diagrammatically depicts web content rendered by a web browser of FIG. 1.
[0024] FIG. 5 diagrammatically depicts web content rendered by a web browser of FIG. 1.
[0025] FIG. 6 diagrammatically depicts web content rendered by a web browser of FIG. 1.
DETAILED DESCRIPTION OF EXEMPLARY EMBODIMENTS
[0026] As will be appreciated by one skilled in the art, the present invention may be embodied as a method, system, or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a "circuit," "module" or "system." Furthermore, the present invention may take the form of a computer program product on a computer-usable storage medium having computer-usable program code embodied in the medium.
[0027] Any suitable computer usable or computer readable medium may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer-usable, or computer-readable, storage medium (including a storage device associated with a computing device or client electronic device) may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non- exhaustive list) of the computer-readable medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device. In the context of this document, a computer-usable, or computer-readable, storage medium may be any tangible medium that can contain, or store a program for use by or in connection with the instruction execution system, apparatus, or device.
[0028] A computer readable signal medium may include a propagated data signal with computer readable program coded embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
[0029] Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
[0030] Computer program code for carrying out operations of the present invention may be written in an object oriented programming language such as Java, Smalltalk, C++ or the like. However, the computer program code for carrying out operations of the present invention may also be written in conventional procedural programming languages, such as the "C" programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
[0031] The present invention is described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
[0032] These computer program instructions may also be stored in a computer- readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
[0033] The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
[0034] Referring to FIG. 1, there is shown filter process 10 that may reside on and may be executed by server computer 12, which may be connected to network 14 (e.g., the Internet or a local area network). Examples of server computer 12 may include, but are not limited to: a personal computer, a server computer, a series of server computers, a mini computer, and a mainframe computer. Server computer 12 may be a web server (or a series of servers) running a network operating system, examples of which may include but are not limited to: Microsoft® Windows® Server; Novell® NetWare®; or Red Hat® Linux®, for example. (Microsoft and Windows are registered trademarks of Microsoft Corporation in the United States, other countries or both; Novell and NetWare are registered trademarks of Novell Corporation in the United States, other countries or both; Red Hat is a registered trademark of Red Hat Corporation in the United States, other countries or both; and Linux is a registered trademark of Linus Torvalds in the United States, other countries or both.) Additionally / alternatively, the filter process may reside on and be executed, in whole or in part, by a client electronic device, such as a personal computer, notebook computer, personal digital assistant, or the like.
[0035] As will be discussed below in greater detail, filter process 10 may maintain a data store including a plurality of web content filtering rules. Filter process 10 may also receive a filtering rules query from a client device, via a network, in response to the client device requesting web content. Filter process 10 may further transmit one or more web content filtering rules to the client device via the network.
[0036] The instruction sets and subroutines of filter process 10, which may include one or more software modules, and which may be stored on storage device 16 coupled to server computer 12, may be executed by one or more processors (not shown) and one or more memory modules (not shown) incorporated into server computer 12. Storage device 16 may include but is not limited to: a hard disk drive; a solid state drive, a tape drive; an optical drive; a RAID array; a random access memory (RAM); and a read-only memory (ROM).
[0037] Server computer 12 may execute a web server application, examples of which may include but are not limited to: Microsoft IIS , Novell WebserverTM, or Apache® Webserver, that allows for HTTP (i.e., HyperText Transfer Protocol) access to server computer 12 via network 14 (Webserver is a trademark of Novell Corporation in the United States, other countries, or both; and Apache is a registered trademark of Apache Software Foundation in the United States, other countries, or both). Network 14 may be connected to one or more secondary networks (e.g., network 18), examples of which may include but are not limited to: a local area network; a wide area network; or an intranet, for example.
[0038] Server computer 12 may execute a data store application (e.g., data store application 20), examples of which may include, but is not limited to e.g., a database. Data store application 20 may include / maintain a plurality of web content filtering rules that may be utilized by a client web browser application (e.g., web browsers 22, 24, 26, 28) for filtering web content. Examples of web browsers 22, 24, 26, 28 may include, but are not limited to, e.g., Microsoft Internet Explorer®, Apple® Safari®, etc. (Internet Explorer is a registered trademark of Microsoft Corporation in the United States, other countries, or both, and Apple and Safari are registered trademarks of Apple Inc. in the United States, other countries, or both).
[0039] Filter process 10 may be a stand alone application, or may be an applet / application / script that may interact with and/or be executed within data store application 20. In addition / as an alternative to being a server-side process, the filter process may include a client-side process (described below) that may reside on a client electronic device (described below) and may interact with a web browser (e.g., one or more of web browsers 22, 24, 26, 28). Further, the filter process may be a hybrid server-side / client-side process that may interact with data store application 20 and a web browser (e.g., one or more of web browsers 22, 24, 26, 28). As such, the filter process may reside, in whole, or in part, on server computer 12 and/or one or more client electronic devices.
[0040] The instruction sets and subroutines of data store application 20, which may be stored on storage device 16 coupled to server computer 12 may be executed by one or more processors (not shown) and one or more memory modules (not shown) incorporated into server computer 12.
[0041] The instruction sets and subroutines of web browsers 22, 24, 26, 28, which may be stored on storage devices 30, 32, 34, 36 (respectively) coupled to client electronic devices 38, 40, 42, 44 (respectively), may be executed by one or more processors (not shown) and one or more memory modules (not shown) incorporated into client electronic devices 38, 40, 42, 44 (respectively). Storage devices 30, 32, 34, 36 may include but are not limited to: hard disk drives; solid state drives, tape drives; optical drives; RAID arrays; random access memories (RAM); read-only memories (ROM), compact flash (CF) storage devices, secure digital (SD) storage devices, and a memory stick storage devices. Examples of client electronic devices 38, 40, 42, 44 may include, but are not limited to, personal computer 38, laptop computer 40, mobile computing device 42 (such as a smart phone, net book, or the like), notebook computer 44, for example. Using web browsers 22, 24, 26, 28, users 46, 48, 50, 52 may access web content (e.g., web pages, web applications, and the like) via one or more of networks 14, 18. Additionally, using web browsers 22, 24, 26, 28, users 46, 48, 50, 52 may access web content filtering rules included in / maintained by data store application 20 to thereby filter accessed web content.
[0042] As mentioned above, the filter process may reside, in whole or in part, on a client electronic device (e.g., client electronic device 38, 40, 42, 44). For example, client electronic devices 38, 40, 42, 44 may respectively execute a client-side filter process (e.g., filter processes 54, 56, 58, 60). Filter processes 54, 56, 58, 60 may each include a stand alone application, or may be an applet / application / script that may interact with and/or be executed within web browsers 22, 24, 26, 28. The instruction sets and subroutines of filter processes 54, 56, 58, 60, which may be stored on storage devices 30, 32, 34, 36 (respectively) coupled to client electronic devices 38, 40, 42, 44 (respectively), may be executed by one or more processors (not shown) and one or more memory modules (not shown) incorporated into client electronic devices 38, 40, 42, 44 (respectively).
[0043] As will be discussed in greater detail below, the client-side filter process (e.g., filter processes 54, 56, 58, 60), alone or in conjunction with a web browser, may receive an indication of a request for web content. A query for web content filtering rules may be generated based upon, at least in part, the request for web content. The query for web content filtering rules may be transmitted to a data store (e.g., data store 20) including a plurality of web content filtering via a network. One or more web content filtering rules may be received from the data store. The web content may be filtered based upon, at least in part, the received on or more web content filtering rules.
[0044] Users 46, 48, 50, 52 may access data store application 20 directly through the device on which the web browser (e.g., web browsers 22, 24, 26, 28) is executed, namely client electronic devices 38, 40, 42, 44, for example. Users 46, 48, 50, 52 may access data store application 20 directly through network 14 or through secondary network 18. Further, server computer 12 (i.e., the computer that executes scheduling application 20) may be connected to network 14 through secondary network 18, as illustrated with phantom link line 62.
[0045] The various client electronic devices may be directly or indirectly coupled to network 14 (or network 18). For example, personal computer 38 is shown directly coupled to network 14 via a hardwired network connection. Further, notebook computer 44 is shown directly coupled to network 18 via a hardwired network connection. Laptop computer 40 is shown wirelessly coupled to network 14 via wireless communication channel 64 established between laptop computer 40 and wireless access point (i.e., WAP) 66, which is shown directly coupled to network 14. WAP 66 may be, for example, an IEEE 802.11a, 802.1 1b, 802. l lg, Wi-Fi, EDGE, 3G, Wi-MAX and/or Bluetooth device that is capable of establishing wireless communication channel 64 between laptop computer 40 and WAP 66. Mobile computing device 42 is shown wirelessly coupled to network 14 via wireless communication channel 68 established between mobile computing device 42 and cellular network / bridge 70, which is shown directly coupled to network 14.
[0046] As is known in the art, all of the IEEE 802. l lx specifications may use Ethernet protocol and carrier sense multiple access with collision avoidance (i.e., CSMA/CA) for path sharing. The various 802.1 lx specifications may use phase-shift keying (i.e., PSK) modulation or complementary code keying (i.e., CCK) modulation, for example. As is known in the art, Bluetooth is a telecommunications industry specification that allows e.g., mobile phones, computers, and personal digital assistants to be interconnected using a short-range wireless connection.
[0047] Client electronic devices 38, 40, 42, 44 may each execute an operating system, examples of which may include but are not limited to Microsoft Windows, Microsoft Windows CE®, Red Hat Linux, or other suitable operating system. (Windows CE is a registered trademark of Microsoft Corporation in the United States, other countries, or both.)
[0048] For the purpose of the following description, web browser 22 and filter application 54 may be discussed. However, this is for illustrative purposes only and should not be construed as a limitation of the present disclosure, as other web browsers (e.g., web browsers 24, 26, 28) and other filter processes (e.g., filter processes 56, 58, 60) may be equally utilized.
[0049] With reference to FIGS. 2 and 3, assume that user 45 is accessing web content using web browser 22. User 46 may input a request for web content into browser 22 (e.g., by entering a universal resource locator, "URL", into web browser 22 using an input device, such as a keyboard, associated with computing device 36). The web content may include, but is not limited to, a web page, a web application, or the like. Upon user 46 entering the request for web content, filter process 54 (e.g., which may be integrated into or otherwise interact with web browser 22) may receive 150 an indication of the request for web content. In response to receiving 150 the indication of the request for web content, filter process 54 may generate 152 a query for web content filtering rules based upon, at least in part, the received 150 request for web content. The generated 152 query for web content filtering rules may include, for example, an identifier of the requested web content, such as the requested URL, or other identifier of the requested web content. Filter process 54 may further transmit 154 the query for web content filtering rules to a data store (e.g., data store 20, alone and/or in conjunction with filter process 10) including a plurality of web content filtering rules. The query may be transmitted 154 via a network, such as network 14, or 18. As discussed above, networks 14, 18 may include, for example, local area networks, wide area networks, the internet, or other such computing network.
[0050] Filter process 10 may maintain 100 data store 20, which may include a plurality of web content filtering rules. Filter process 10 may receive 102 the filtering rules query transmitted 154 in response to the requested web content by client device 38 (e.g., transmitted by filter process 54 and/or web browser 22). Filter process 10 may execute the received 102 filtering rules query over data store 20, which may return a results set of web content filtering rules applicable to the web content requested by client device 38 (e.g., via web browser 22). Filter process 10 may transmit 104 one or more web content filtering rules to client device 38 via networks 14, 18. The one or more web content filtering rules may, for example, identify portions, components, features, or the like, of the requested web content that may be blocked, disabled, or removed from the requested web content prior to, and/or during, rendering of the web content by a web browser (such as, for example, web browser 22). In addition to any rules specific to the requested web content, filter process 10 may optionally also transmit general web content filtering rules. In terms of general web content filtering rules, filter process 10 may, for example, transmit a list of known ad-servers, URL's associated with malicious content, pornographic content, etc., as may be generally known. The optional transmission of general web content filtering rules may be configured according to system and/or user preferences, which may be defined in a conventional manner (e.g., via preference configuration settings and graphical user interfaces).
[0051] Filter process 54 may receive 156 the one or more web content filtering rules transmitted 104 by filter process 10. Further, filter process 54 (alone and/or in conjunction with web browser 22) may filter 158 the web content (e.g., which may be received by web browser 22 based upon the request for the web content) based upon, at least in part, the received 156 one or more web content filtering rules. For example, filtering 158 the received web content may include blocking, disabling, and/or removing portions of the requested web content, and/or features or components within the requested web content as, or before, the requested web content is rendered by web browser 22. For example, filtering 158 the received web content may include blocking advertisements included within the web content, disabling and/or blocking selected java script or flash items, or otherwise blocking, removing, disabling, or the like, selected portions of the requested web content or features or components of the requested web content. As such, the requested web content may be displayed having portions, features, or components blocked, removed, or disabled, based upon, at least in part, the one or more web content filtering rules.
[0052] Consistent with this aspect of the present disclosure, data store 20 may include large sets of web content filtering rules, for example which may consume large amounts of memory and storage to the point of being impractical or inconvenient to store on a client electronic device. This may be especially true for constrained devices, such as tablets, net books, smart phones, and the like, which may have relatively small amounts of available storage. Additionally, as the web content filtering rules may be stored in a central data store (e.g., data store 20), any updates or changes to the web content filtering rules may be immediately implemented and available to all users, without the need to update a local repository of filtering rules. According to one aspect, at least a portion of the received 156 web content filtering rules may be locally cached (e.g., by filter process 55 and/or web browser 22). As such, the locally cached web content filtering rules may be available without subsequent requests to filter process 10. Such locally cached rules may be applicable to other web content associated with a common domain, or the like. In a similar manner, filter process(s) 10, 55 may utilize a network caching infrastructure and/or utilize a content delivery network arrangement. In such an embodiment, at least a portion of the web content filtering rules (and/or a copy of at least a portion of the web content filtering rules) may additionally be stored on a network accessible storage device accessible by client device 38 (in the foregoing example). As such, filter process 55 may access at least a portion of the web content filtering rules from either data store 20 or the network accessible storage device (e.g., depending upon available bandwidth, or other networking considerations).
[0053] According to one aspect, filter process 10 may leverage a user community to aid in building a robust catalog of web content filtering rules. For example, filter process 10 may provide a mechanism for receiving user submissions of suggested web content filtering rules. In this regard, as the usership of filter process 10 grows, and the life cycle of filter process 10 advances, the available web content filtering rules may similarly expand.
[0054] Continuing with the foregoing concept, and with additional reference to FIG. 4, assume that requested web content (e.g., web page) 200 may be rendered via web browser 22. Web page 200 may include first web content 202, such as an article or other content. Additionally, web page 200 may include feature 204 that user 46 believes should be filtered. For example, feature 204 may include an advertisement, flash content, pornographic content, a tracker, a widget, unrelated content panel, or any other content that user 46 may consider worthy of blocking. User 46 may mark feature 204 as content to be filtered. For example, user 46 may select, via onscreen pointer 206 (which may be controlled by a pointing device, such as a mouse or gestural touch-screen interface; not shown) feature 204 by right clicking feature 204. In response to user 46 right clicking feature 204 filter process 54 (alone or in conjunction with web browser 22) may generate popup 208. While popup 208 is shown including a single option (namely "mark content for filtering") other options (e.g., an identifier of the category of the content, etc.) may be included within popup 208 depending upon design criteria and user need. User 46 may select, via onscreen pointer 206, the option "mark content for filtering" from within popup 208. Selecting the option "mark content for filtering" may result in filter process 54 (alone or in conjunction with web browser 22) generating 160 a web content filter rule submission. Further, filter process 54 may transmit 162 the web content filter rule submission to data store 20. Transmitting 162 the web content filter rule submission may include transmitting an identifier of web page 200 (e.g., may transmit the URL or other identifier of the web page or web application), and/or may transmit an identifier of feature 204 (e.g., may transmit a link associated with feature 204, html code or java script, etc., associated with feature 204, or the like). [0055] Filter process 10 may receive 106 the web content filter rule submission from filter process 54. Further, filter process 10 may update 108 the plurality of web content filtering rules (included within data store 20) based upon, at least in part, the web content filter rule submission. For example, filter process 10 may create a new web content filtering rule (and/or update an existing web content filtering rule) based upon, at least in part, the received 106 web content filter rule submission. For example, a new web content filter rule may include an identifier of the URL associated with web page 200 (e.g., the URL of the web page) as well as an identifier associated with feature 204.
[0056] Filter process 10 may, in some embodiments, determine 1 10 the validity of the web content filter rule submission. According to one aspect, it may be possible for filter process 10 to automatically determine 1 10 the validity of the web content filter rule submission. For example, a like associated with feature 204 may be correlated to a known ad-server, or other automatically identifiable source of content that may desirably be filtered. Additionally / alternatively, the received 106 web content filter rule submission may be manually examined by a support representative. In such an embodiment, filter process 10 may determine 1 10 the validity of the web content filter rule submission based upon an indication input by the support representative. If the validity is confirmed, filter process 10 may update 108 the plurality of web content filtering rules based upon, at least in part, the web content filtering rule submission. Upon updating 108 the plurality of web content filtering rules, the updated rules may be immediately accessible by users of the system. Consistent with this aspect, as the number or user submissions increases, the web content filtering rules included within date store 20 may increase, and may provide enriched filtering capacity.
[0057] In addition to web content filter rule submissions from users, web content filtering rules may be based upon, at least in part, external sources. Such external sources may arise, for example, from third party feeds or information. The web content filtering rules based upon, at least in part, external sources may, for example, allow potentially malicious content to be filtered out of requested web content (e.g., web page 200). Various examples of web content filtering rules (included within data store 20, resulting from web content filtering rule submissions, and web content filtering rules based upon, at least in part, external sources) may relate to filtering content such as advertisements, malicious features, objectionable content, items (content, features, components, or the like) that may give rise to privacy concerns (e.g., trackers) or performance concerns. Such examples should not be construed as limiting however. For example, web content filtering rules may relate to filtering any web content (e.g., content included within a web page or web application, portions of content within a web page or web application, features or components included within the web page or web application, such as java script items, flash items, etc.) that may be unwanted by a user, an administrator, a vendor, or the like, regardless of the nature of the web content. As such, the content to be filtered need not be functional, or even visible to a consumer of the requested web content (e.g., the web page or web application). Further, content may be filtered (e.g., based upon, at least in part, a web content filtering rule) based upon, at least in part, a corporate policy (e.g., no hate speech or content unrelated to the business of the corporation), law (e.g., no access to gambling web applications or fragments), to trust (e.g., parental control and non-work related web sites and applications) or the like.
[0058] According to another aspect, filter process 10 may associate 112 at least one category identifier with at least a portion of the plurality of web content filtering rules included within data store 20. For example, category identifiers may indicate that a given rule is directed at filtering advertising material, trackers, widgets, unrelated content panes such as market places or blogs, or any other category of content that may be filtered based upon, at least in part, the given web content filtering rule. In this manner, the category identifier may be indicative of one or more of a content type, and a content function. The associated 112 category identifier may include a tag, a relational feature, or the like, associated with a given web content filtering rule, or collection of web content filtering rules. Referring back to the previous aspect of the present disclosure, in addition to simply allowing a feature (e.g., feature 204) of a piece of web content (e.g., web page 200) to be marked for filtering, one or more of filter processes 10, 54 may allow a category identifier to also be associated 1 12 with the feature.
[0059] Continuing with this aspect of the present disclosure, transmitting 154 the query for web content filtering rules by the client device may include transmitting 164 the query for web content filtering rules based upon, at least in part, a user defined category identifier. For example, filter process 54 may allow user 46 to specify preferences of categories of web content to be filtered. For example, user 46 may specify preferences to filter advertisements and trackers, but not to filter widgets. As such, transmitting 154 the query for web content filtering rules may include transmitting 164 the query for web content filtering rules only for advertisements and trackers, but not for widgets. Of course, various additional / alternative preferences of web content categories may be specified.
[0060] Transmitting 104 one or more web content filtering rules to the client device may include transmitting one or more web content filtering rules based upon, at least in part, a user defined category identifier. For example, in an embodiment in which filter process 54 may transmit 164 the query for web content based upon, at least in part, a user defined category identifier, filter process 10 may execute a query over data store 20 relative to the web content requested by web browser 22 and the user defined category identifiers. In a related embodiment, a user profile may be maintained by filter process 10. Accordingly, all queries for web content filtering rules by user 46 may be based upon, at least in part, the user defined category identifiers. Filter process 104 may transmit one or more web content filtering rules based upon, at least in part, a user defined category identifier to client device 38.
[0061] According to a further aspect, filtering processes 10, 54 may provide options for rendering filtered web content. That is, the manner in which the region of the requested web content (e.g., web page 200) corresponding to the filtered web content (e.g., feature 204 in the foregoing examples) may be rendered according to various preferences or rules. In one embodiment, to implement this aspect filter process 10 may transmit 114 a content rendering rule to the client device (e.g., client device 38). The content rendering rule may include instructions (e.g., which may be utilized by filter process 54 and / web browser 22) for rendering the requested web content (e.g., web page 200). Correspondingly, filter process 54 may receive 166 the one or more filtered content rendering rules from data store. Filter process 54 may render the requested web content (e.g., web page 200) according to the instructions of the filtered content rendering rules.
[0062] For example, the content rending rule may include instructions for omitting the filtered web content (e.g., feature 204). As such, web page 200 may include a blank region corresponding to the location of feature 204. In the event that the filtered web content resides in other content (e.g., the filtered web content is, for example, and advertisement located in a paragraph of text) the rendering instructions may include instructions to close up the text, thereby providing an uninterrupted paragraph of text. Additionally / alternatively other features may be placed in the region of web page corresponding to filtered web content (e.g., feature 204). For example, as shown in FIG. 5, the feature 204 may be replaced by a phantom box, thereby providing a visual indicator that web content has been filtered from web page 204. Various additional / alternative images, animations, etc., may similarly be displayed in the region corresponding to the filtered web content. For example, as shown in FIG. 6, an image, such as a corporate logo, or other image, may be place in the region corresponding to feature 204, which has been filtered from web page 200.
[0063] In addition / as an alternative to the foregoing example of the removal of the content, placement of phantom box, image, or the like, the content rendering rules may allow the filtered web content (e.g., feature 204 within web page 200) may be replaced by content from a dynamic source. Examples of dynamic sources may include, for example, content from another ad server, social network site or page, a web feed, or an external database. Various additional / alternative implementations may be equally utilized.
[0064] In addition / as an alternative to receiving web content rendering rules from filter process 10, filter process 54 may provide for user preferences for rendering filtered web content. For example, user 46 may specify (e.g., via one or more of filter process 54 and web browser 22) how filtered web content should be rendered. As such, user 46 may customize the appearance of rendered web content having filtered features.
[0065] In addition / as an alternative to providing web content filtering for individual users, the filtering process herein may allow web content filtering across multiple client devices or users. For example, such an aspect may be implemented in an enterprise environment, a social network, or other group-level environment. In such a manner, for example, a central administrator may establish web content filtering rules that may be implemented across more than one client electronic device or user.
[0066] Consistent with the foregoing description, rather than providing URL level filtering (e.g., in which entire web sites may be blocked), the filter process herein may provide filtering of individual items of web content within, e.g., a web page, web application, or the like. According to the instant aspect, group-level filtering profiles may be defined and implemented across multiple client devices and/or user profiles (e.g., based upon, at least in part, user provided login credentials, licensing keys or the like).
[0067] In one example, one or more of filter processes 10, 54 may define 1 16, 168 a client group. For example, user 46 may be an administrative user. User 46 may, accordingly, input a user group (e.g., including one or more identified client electronic devices, such as 40, 42, 44; or one or more users, such as user 48, 50, 52 based upon user profiles, user credentials, or the like). One or more of filter processes 10, 54 may define 1 16, 186 the client group based upon, at least in part, the input from user 46. At least a portion of the web content filtering rules may be associated 1 18, 170 with the client group. For example, web content filtering rules based upon categories of web content to be filtered may be associated 118, 170 with the client group. In one example, the web content filtering rules associated 1 18, 170 with the client group may specify that advertisements and trackers should be filtered. Other variations may equally be utilized. Web content filtering rules may be transmitted 104 by filter process 10 and received 156 by one or more of filter processes 56, 58, 60 based upon, at least in part participation of the client device (e.g., devices 40, 42, 44) in the client group. The respective client devices 40, 42, 44 may participate in the client group by virtue of having been specifically identified as participating the client group, by virtue of residing on a commonly controlled and specified network, by virtue of a specified user being logged onto one of the client devices, or the like. As indicated above, the client group may include one or more of a defined plurality of users, a plurality of client devices associated with a group network, or other similar association.
[0068] The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
[0069] The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms "a", "an" and "the" are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms "comprises" and/or "comprising," when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
[0070] The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
[0071] Having thus described the invention of the present application in detail and by reference to embodiments thereof, it will be apparent that modifications and variations are possible without departing from the scope of the invention defined in the appended claims.

Claims

WHAT IS CLAIMED IS:
1. A computer implemented method comprising:
maintaining, by a computing device, a data store including a plurality of web content filtering rules;
receiving, by the computing device, a filtering rules query from a client device, via a network, in response to the client device requesting web content;
transmitting, by the computing device, one or more web content filtering rules to the client device via the network.
2. The computer implemented method according to claim 1, wherein the network includes one or more of a local area network, a wide area network, and an Internet.
3. The computer implemented method according to claim 1, further including: receiving, from the client device, a web content filter rule submission; and updating the plurality of web content filtering rules based upon, at least in part, the web content filter rule submission.
4. The computer implemented method according to claim 3, further including determining a validity of the web content filter rule submission.
5. The computer implemented method according to claim 1, further including associating at least one category identifier with at least a portion of the plurality of web content filtering rules, the category identifier being indicative of one or more of a content type, and a content function.
6. The computer implemented method according to claim 5, wherein transmitting one or more web content filtering rules to the client device includes transmitting one or more web content filtering rules based upon, at least in part, a user defined category identifier.
7. The computer implemented method according to claim 1, further including transmitting one or more filtered content rendering rules to the client device, the one or more filtered content rendering rules including instructions for rendering the requested web content.
8. The computer implemented method according to claim 1, further including: defining a client group;
associating at least a portion of the web content filtering rules with the client group; and
transmitting web content filtering rules to the client device based upon, at least in part, participation of the client device in the client group.
9. The computer implemented method according to claim 8, wherein the client group includes one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
10. The computer implemented method according to claim 1, wherein the one or more web content filtering rules are based upon, at least in part, an external source.
1 1. A computer program product residing on a computer readable medium having a plurality of instructions stored thereon, which, when executed by a processor, cause the processor to perform operations comprising:
maintaining a data store including a plurality of web content filtering rules; receiving a filtering rules query from a client device, via a network, in response to the client device requesting web content;
transmitting one or more web content filtering rules to the client device via the network.
12. The computer program product according to claim 11, wherein the network includes one or more of a local area network, a wide area network, and an Internet.
13. The computer program product according to claim 11, further including instructions for:
receiving, from the client device, a web content filter rule submission; and updating the plurality of web content filtering rules based upon, at least in part, the web content filter rule submission.
14. The computer program product according to claim 13, further including instructions for determining a validity of the web content filter rule submission.
15. The computer program product according to claim 11, further including instructions for associating at least one category identifier with at least a portion of the plurality of web content filtering rules, the category identifier being indicative of one or more of a content type, and a content function.
16. The computer program product according to claim 15, wherein the instructions for transmitting one or more web content filtering rules to the client device include instructions for transmitting one or more web content filtering rules based upon, at least in part, a user defined category identifier.
17. The computer program product according to claim 11, further including instructions for transmitting one or more filtered content rendering rules to the client device, the one or more filtered content rendering rules including instructions for rendering the requested web content.
18. The computer program product according to claim 11, further including instructions for:
defining a client group;
associating at least a portion of the web content filtering rules with the client group; and
transmitting web content filtering rules to the client device based upon, at least in part, participation of the client device in the client group.
19. The computer program product according to claim 18, wherein the client group includes one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
20. The computer program product according to claim 11, wherein the one or more web content filtering rules are based upon, at least in part, an external source.
21. A computer implemented method comprising:
receiving, by a computing device, an indication of a request for web content; generating, by the computing device, a query for web content filtering rules based upon, at least in part, the request for web content;
transmitting, by the computing device, the query for web content filtering rules to a data store including a plurality of web content filtering via a network;
receiving, by the computing device, one or more web content filtering rules from the data store; and
filtering, by the computing device, the web content based upon, at least in part, the received on or more web content filtering rules.
22. The computer implemented method according to claim 21, wherein the network includes one or more of a local area network, a wide area network, and an Internet.
23. The computer implemented method according to claim 21, further including: generating a web content filter rule submission; and
transmitting the web content filter rule submission to the data store.
24. The computer implemented method according to claim 21, wherein at least one category identifier is associated with at least a portion of the plurality of web content filtering rules, the category identifier being indicative of one or more of a content type, and a content function.
25. The computer implemented method according to claim 24, wherein transmitting the query for web content filtering rules by the client device includes transmitting the query for web content filtering rules based upon, at least in part, a user defined category identifier.
26. The computer implemented method according to claim 21, further including receiving one or more filtered content rendering rules from the data store, the one or more filtered content rendering rules including instructions for rendering the requested web content.
27. The computer implemented method according to claim 21, further including: defining a client group;
associating at least a portion of the web content filtering rules with the client group; and
receiving web content filtering rules by the client device based upon, at least in part, participation of the client device in the client group.
28. The computer implemented method according to claim 27, wherein the client group includes one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
29. A computer program product residing on a computer readable medium having a plurality of instructions stored thereon, which, when executed by a processor, cause the processor to perform operations comprising:
receiving an indication of a request for web content;
generating a query for web content filtering rules based upon, at least in part, the request for web content;
transmitting the query for web content filtering rules to a data store including a plurality of web content filtering via a network;
receiving one or more web content filtering rules from the data store; and filtering the web content based upon, at least in part, the received on or more web content filtering rules.
30. The computer program product according to claim 29, wherein the network includes one or more of a local area network, a wide area network, and an Internet.
31. The computer program product according to claim 29, further including instructions for:
generating a web content filter rule submission; and
transmitting the web content filter rule submission to the data store.
32. The computer program product according to claim 29, wherein at least one category identifier is associated with at least a portion of the plurality of web content filtering rules, the category identifier being indicative of one or more of a content type, and a content function.
33. The computer program product according to claim 32, wherein the instructions for transmitting the query for web content filtering rules to the client device include instructions for transmitting the query for web content filtering rules based upon, at least in part, a user defined category identifier.
34. The computer program product according to claim 29, further including instructions for receiving one or more filtered content rendering rules from the data store, the one or more filtered content rendering rules including instructions for rendering the requested web content.
35. The computer program product according to claim 29, further including instructions for:
defining a client group;
associating at least a portion of the web content filtering rules with the client group; and
receiving web content filtering rules by the client device based upon, at least in part, participation of the client device in the client group.
36. The computer program product according to claim 35, wherein the client group includes one or more of a defined plurality of users, and a plurality of client devices associated with a group network.
PCT/US2011/029534 2010-03-23 2011-03-23 Cloud-based web content filtering WO2011119676A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
CA2793960A CA2793960C (en) 2010-03-23 2011-03-23 Cloud-based web content filtering
ES11714614T ES2786030T3 (en) 2010-03-23 2011-03-23 Filtering web content in the cloud
EP11714614.2A EP2550607B1 (en) 2010-03-23 2011-03-23 Cloud-based web content filtering
HRP20200730TT HRP20200730T1 (en) 2010-03-23 2020-05-07 Cloud-based web content filtering

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US31660910P 2010-03-23 2010-03-23
US61/316,609 2010-03-23

Publications (1)

Publication Number Publication Date
WO2011119676A1 true WO2011119676A1 (en) 2011-09-29

Family

ID=44228021

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2011/029534 WO2011119676A1 (en) 2010-03-23 2011-03-23 Cloud-based web content filtering

Country Status (8)

Country Link
US (1) US9323835B2 (en)
EP (1) EP2550607B1 (en)
CA (1) CA2793960C (en)
ES (1) ES2786030T3 (en)
HR (1) HRP20200730T1 (en)
HU (1) HUE048841T2 (en)
PT (1) PT2550607T (en)
WO (1) WO2011119676A1 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2013079645A1 (en) 2011-11-30 2013-06-06 Philip Morris Products S.A. Smoking article with a ventilated mouthpiece comprising first and second airflow pathways
WO2015114090A1 (en) * 2014-01-30 2015-08-06 Netzwelt Gmbh System and method for preventing a delivery of advertising content

Families Citing this family (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8930394B2 (en) 2010-08-17 2015-01-06 Fujitsu Limited Querying sensor data stored as binary decision diagrams
US8583718B2 (en) 2010-08-17 2013-11-12 Fujitsu Limited Comparing boolean functions representing sensor data
US8645108B2 (en) 2010-08-17 2014-02-04 Fujitsu Limited Annotating binary decision diagrams representing sensor data
US8495038B2 (en) 2010-08-17 2013-07-23 Fujitsu Limited Validating sensor data represented by characteristic functions
US8572146B2 (en) 2010-08-17 2013-10-29 Fujitsu Limited Comparing data samples represented by characteristic functions
US9002781B2 (en) 2010-08-17 2015-04-07 Fujitsu Limited Annotating environmental data represented by characteristic functions
US8874607B2 (en) * 2010-08-17 2014-10-28 Fujitsu Limited Representing sensor data as binary decision diagrams
US9138143B2 (en) 2010-08-17 2015-09-22 Fujitsu Limited Annotating medical data represented by characteristic functions
US9369433B1 (en) * 2011-03-18 2016-06-14 Zscaler, Inc. Cloud based social networking policy and compliance systems and methods
TW201312369A (en) * 2011-09-13 2013-03-16 Univ Nat Central Method for filetring web page content and network equipment
US9177247B2 (en) 2011-09-23 2015-11-03 Fujitsu Limited Partitioning medical binary decision diagrams for analysis optimization
US8838523B2 (en) 2011-09-23 2014-09-16 Fujitsu Limited Compression threshold analysis of binary decision diagrams
US8909592B2 (en) 2011-09-23 2014-12-09 Fujitsu Limited Combining medical binary decision diagrams to determine data correlations
US8719214B2 (en) 2011-09-23 2014-05-06 Fujitsu Limited Combining medical binary decision diagrams for analysis optimization
US9176819B2 (en) 2011-09-23 2015-11-03 Fujitsu Limited Detecting sensor malfunctions using compression analysis of binary decision diagrams
US8812943B2 (en) 2011-09-23 2014-08-19 Fujitsu Limited Detecting data corruption in medical binary decision diagrams using hashing techniques
US8620854B2 (en) 2011-09-23 2013-12-31 Fujitsu Limited Annotating medical binary decision diagrams with health state information
US9075908B2 (en) 2011-09-23 2015-07-07 Fujitsu Limited Partitioning medical binary decision diagrams for size optimization
US8781995B2 (en) 2011-09-23 2014-07-15 Fujitsu Limited Range queries in binary decision diagrams
US9286642B2 (en) * 2011-12-16 2016-03-15 Facebook, Inc. Content access management in a social networking system for externally stored content
US9947031B2 (en) * 2011-12-16 2018-04-17 Facebook, Inc. Content access management in a social networking system for locally stored content
US9385946B2 (en) 2012-07-26 2016-07-05 At&T Intellectual Property I, L.P. Network-based content filtering utilizing user-specified parameters
IN2014DN11230A (en) * 2012-08-06 2015-10-02 Ericsson Telefon Ab L M
US10025853B2 (en) * 2013-09-30 2018-07-17 Verizon Patent And Licensing Inc. Method and apparatus for filtering data based on content selected for future access
CN104780153B (en) * 2015-03-11 2018-06-19 小米科技有限责任公司 Information filtering method and device
US11190577B2 (en) * 2015-10-27 2021-11-30 Vmware, Inc. Single data transmission using a data management server
US10601669B2 (en) * 2015-10-27 2020-03-24 Vmware, Inc. Configurable client filtering rules
US20170212875A1 (en) * 2016-01-27 2017-07-27 Microsoft Technology Licensing, Llc Predictive filtering of content of documents
US11297058B2 (en) 2016-03-28 2022-04-05 Zscaler, Inc. Systems and methods using a cloud proxy for mobile device management and policy
US10839030B2 (en) * 2016-09-21 2020-11-17 International Business Machines Corporation Persistent filter content refinement system
RU2651251C1 (en) * 2017-04-28 2018-04-18 АО "Лаборатория Касперского" Method of downloading filtering rules to mobile device

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6605120B1 (en) * 1998-12-10 2003-08-12 International Business Machines Corporation Filter definition for distribution mechanism for filtering, formatting and reuse of web based content
US6701350B1 (en) * 1999-09-08 2004-03-02 Nortel Networks Limited System and method for web page filtering

Family Cites Families (56)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5951300A (en) * 1997-03-10 1999-09-14 Health Hero Network Online system and method for providing composite entertainment and health information
US5887133A (en) * 1997-01-15 1999-03-23 Health Hero Network System and method for modifying documents sent over a communications network
AU703492B2 (en) * 1995-09-14 1999-03-25 Matsushita Electric Industrial Co., Ltd. Data broadcast receiving apparatus
US5884033A (en) * 1996-05-15 1999-03-16 Spyglass, Inc. Internet filtering system for filtering data transferred over the internet utilizing immediate and deferred filtering actions
US5751716A (en) * 1996-06-19 1998-05-12 Aware, Inc. Multi-carrier transmission system adapted for packet data transfer
US6594682B2 (en) * 1997-10-28 2003-07-15 Microsoft Corporation Client-side system for scheduling delivery of web content and locally managing the web content
KR100460276B1 (en) * 2000-06-10 2004-12-04 유미특허법인 An internet service apparatus and service method
US20020129159A1 (en) * 2001-03-09 2002-09-12 Michael Luby Multi-output packet server with independent streams
US8601492B2 (en) * 2001-03-31 2013-12-03 Siebel Systems, Inc. User interface for multi-channel communication
JP2003037834A (en) * 2001-05-16 2003-02-07 Sony Corp Content distribution system, content distribution controller, content distribution control method, content distribution control program and content distribution control program-stored medium
US7191246B2 (en) * 2001-07-18 2007-03-13 Sharp Laboratories Of America, Inc. Transmission rate selection for a network of receivers having heterogenous reception bandwidth
US20030081582A1 (en) * 2001-10-25 2003-05-01 Nikhil Jain Aggregating multiple wireless communication channels for high data rate transfers
US7581017B2 (en) * 2001-11-22 2009-08-25 Panasonic Corporation Data transmission system, data transmission apparatus, data reception apparatus, and data transmission method
AU2003230868A1 (en) * 2002-04-10 2003-10-27 Akamai Technologies, Inc. Method and system for enhancing live stream delivery quality using prebursting
US7092999B2 (en) * 2002-06-10 2006-08-15 Gutman Levitan Data broadcast network for congestion-free internet access
US7418494B2 (en) * 2002-07-25 2008-08-26 Intellectual Ventures Holding 40 Llc Method and system for background replication of data objects
JP2004112113A (en) * 2002-09-13 2004-04-08 Matsushita Electric Ind Co Ltd Method and apparatus for adaptively controlling real-time communication, method of measuring for continuous erasure of receiving report packet, apparatus for dynamically deciding sending interval of receiving report packet, data receiver and data delivering apparatus
US20040062392A1 (en) * 2002-10-01 2004-04-01 Equity Broadcasting Group Inc. Central automated transmission system for broadcasting and method of operating
KR100427143B1 (en) * 2003-01-17 2004-04-14 엔에이치엔(주) Method for Transmitting and Dowloading Streaming Data
US8230359B2 (en) * 2003-02-25 2012-07-24 Microsoft Corporation System and method that facilitates computer desktop use via scaling of displayed objects with shifts to the periphery
US7299409B2 (en) * 2003-03-07 2007-11-20 International Business Machines Corporation Dynamically updating rendered content
JP3731665B2 (en) * 2003-03-27 2006-01-05 ソニー株式会社 Data communication system, information processing apparatus and information processing method, recording medium, and program
JP2004312413A (en) * 2003-04-08 2004-11-04 Sony Corp Content providing server, information processing device and method, and computer program
US8559406B2 (en) * 2003-06-03 2013-10-15 Qualcomm Incorporated Method and apparatus for communications of data in a communication system
US7656799B2 (en) * 2003-07-29 2010-02-02 Citrix Systems, Inc. Flow control system architecture
US8554876B2 (en) * 2004-01-23 2013-10-08 Hewlett-Packard Development Company, L.P. User profile service
US7978734B2 (en) * 2004-03-18 2011-07-12 Xocyst Transfer Ag L.L.C. Multichannel MAC data stream for wireless communication
KR20060082353A (en) * 2005-01-12 2006-07-18 와이더댄 주식회사 System and method for providing and handling executable web content
KR100664947B1 (en) * 2005-09-23 2007-01-04 삼성전자주식회사 Method for controlling throughput and communication apparatus using the same
JP4577267B2 (en) * 2006-05-17 2010-11-10 株式会社日立製作所 Thin client system
US8584139B2 (en) * 2006-05-23 2013-11-12 Seapass Solutions Inc. Apparatus and method for connecting incompatible computer systems
CA2653816A1 (en) * 2006-06-02 2007-12-13 Mats Cedervall Multicast delivery
US9602613B2 (en) * 2006-08-03 2017-03-21 Flash Networks, Ltd Method and system for accelerating browsing sessions
US20080098420A1 (en) * 2006-10-19 2008-04-24 Roundbox, Inc. Distribution and display of advertising for devices in a network
JP4973145B2 (en) * 2006-11-20 2012-07-11 船井電機株式会社 Management server and content transfer system
JP2008165459A (en) * 2006-12-28 2008-07-17 Sony Corp Content display method, content display device and content display program
GB2445764A (en) * 2007-01-22 2008-07-23 Surfcontrol Plc Resource access filtering system and database structure for use therewith
US7873710B2 (en) * 2007-02-06 2011-01-18 5O9, Inc. Contextual data communication platform
US8015174B2 (en) * 2007-02-28 2011-09-06 Websense, Inc. System and method of controlling access to the internet
WO2009007985A2 (en) * 2007-07-06 2009-01-15 Elitecore Technologies Limited Identity and policy-based network security and management system and method
US8190750B2 (en) * 2007-08-24 2012-05-29 Alcatel Lucent Content rate selection for media servers with proxy-feedback-controlled frame transmission
US7636789B2 (en) * 2007-11-27 2009-12-22 Microsoft Corporation Rate-controllable peer-to-peer data stream routing
US20090178131A1 (en) * 2008-01-08 2009-07-09 Microsoft Corporation Globally distributed infrastructure for secure content management
US7925774B2 (en) * 2008-05-30 2011-04-12 Microsoft Corporation Media streaming using an index file
US8112308B1 (en) * 2008-08-06 2012-02-07 Google Inc. Targeting using generated bundles of content sources
US8364842B2 (en) * 2009-03-13 2013-01-29 Novell, Inc. System and method for reduced cloud IP address utilization
US8286232B2 (en) * 2009-03-13 2012-10-09 Novell, Inc. System and method for transparent cloud access
US8370520B2 (en) * 2008-11-24 2013-02-05 Juniper Networks, Inc. Adaptive network content delivery system
US8555381B2 (en) * 2009-04-01 2013-10-08 Honeywell International Inc. Cloud computing as a security layer
US8213912B2 (en) * 2009-06-03 2012-07-03 Sandisk Il Ltd. Mobile system for providing personalized information
US8276202B1 (en) * 2009-06-30 2012-09-25 Aleksandr Dubrovsky Cloud-based gateway security scanning
US8417794B2 (en) * 2009-07-27 2013-04-09 Giraffic Technologies Ltd. Transferring multimedia content
US8259571B1 (en) * 2010-03-26 2012-09-04 Zscaler, Inc. Handling overlapping IP addresses in multi-tenant architecture
US10296653B2 (en) * 2010-09-07 2019-05-21 F5 Networks, Inc. Systems and methods for accelerating web page loading
US20120331160A1 (en) * 2011-06-22 2012-12-27 Telefonaktiebolaget L M Ericsson (Publ) Multi-path transmission control protocol proxy service
US10356579B2 (en) * 2013-03-15 2019-07-16 The Nielsen Company (Us), Llc Methods and apparatus to credit usage of mobile devices

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6605120B1 (en) * 1998-12-10 2003-08-12 International Business Machines Corporation Filter definition for distribution mechanism for filtering, formatting and reuse of web based content
US6701350B1 (en) * 1999-09-08 2004-03-02 Nortel Networks Limited System and method for web page filtering

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
BRANTNER M ET AL: "Building a Database in the Cloud", 16 October 2009 (2009-10-16), pages 1 - 49, XP002649174, Retrieved from the Internet <URL:http://cloud.pubs.dbs.uni-leipzig.de/sites/cloud.pubs.dbs.uni-leipzig.de/files/Brantner2008BuildingaDatabaseintheCloud.pdf> [retrieved on 20110707] *
GIANFRANCESCO C ET AL: "Extension Based Privacy Protection", 1 March 2007 (2007-03-01), pages 1 - 51, XP002649175, Retrieved from the Internet <URL:http://www.wpi.edu/Pubs/E-project/Available/E-project-031207-141503/unrestricted/MQP.pdf> [retrieved on 20110708] *

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2013079645A1 (en) 2011-11-30 2013-06-06 Philip Morris Products S.A. Smoking article with a ventilated mouthpiece comprising first and second airflow pathways
US9949504B2 (en) 2011-11-30 2018-04-24 Philip Morris Products S.A. Smoking article with a ventilated mouthpiece comprising first and second airflow pathways
WO2015114090A1 (en) * 2014-01-30 2015-08-06 Netzwelt Gmbh System and method for preventing a delivery of advertising content
US10929884B2 (en) 2014-01-30 2021-02-23 Ad-Ip Gmbh & Co. Kg System and method for preventing a delivery of advertising contents

Also Published As

Publication number Publication date
EP2550607A1 (en) 2013-01-30
US20110264804A1 (en) 2011-10-27
CA2793960A1 (en) 2011-09-29
HUE048841T2 (en) 2020-08-28
CA2793960C (en) 2018-05-22
EP2550607B1 (en) 2020-02-12
ES2786030T3 (en) 2020-10-08
HRP20200730T1 (en) 2020-07-24
PT2550607T (en) 2020-05-15
US9323835B2 (en) 2016-04-26

Similar Documents

Publication Publication Date Title
CA2793960C (en) Cloud-based web content filtering
US11134101B2 (en) Techniques for detecting malicious behavior using an accomplice model
US9230036B2 (en) Enhanced browser cookie management
EP3229148B1 (en) Website access method and device, and website system
EP3092577B1 (en) Offline content sharing
US8935755B1 (en) Managing permissions and capabilities of web applications and browser extensions based on install location
US9330420B2 (en) Using crowdsourcing to improve sentiment analytics
US20130166678A1 (en) Smart Suggestions Engine for Mobile Devices
US20170078343A1 (en) Information Sharing Method and Device
US8856958B1 (en) Personalized content access prompt
US11580294B2 (en) Techniques for web framework detection
JP6080866B2 (en) Computerized method, system, and computer program for mapping one or more dynamic visual objects of a network document
US11108788B1 (en) Techniques for managing projects and monitoring network-based assets
US20100211559A1 (en) System and method for exposing both portal and web content within a single search collection
US11088892B2 (en) System and method for managing content
EP2909731B1 (en) Identifying shared content stored by a service
US11210453B2 (en) Host pair detection
US20140195680A1 (en) Facilitating access to references in communications
US20150149582A1 (en) Sending mobile applications to mobile devices from personal computers

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 11714614

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 2793960

Country of ref document: CA

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2011714614

Country of ref document: EP