JP2018509679A - サーバデバイスによるリソースの改善されたクライアント主導型プッシュ - Google Patents
サーバデバイスによるリソースの改善されたクライアント主導型プッシュ Download PDFInfo
- Publication number
- JP2018509679A JP2018509679A JP2017537233A JP2017537233A JP2018509679A JP 2018509679 A JP2018509679 A JP 2018509679A JP 2017537233 A JP2017537233 A JP 2017537233A JP 2017537233 A JP2017537233 A JP 2017537233A JP 2018509679 A JP2018509679 A JP 2018509679A
- Authority
- JP
- Japan
- Prior art keywords
- data
- push
- client
- server
- request
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000000034 method Methods 0.000 claims abstract description 137
- 230000004044 response Effects 0.000 claims description 78
- 238000001914 filtration Methods 0.000 claims description 43
- 238000006467 substitution reaction Methods 0.000 claims description 37
- 230000008859 change Effects 0.000 claims description 26
- 238000010276 construction Methods 0.000 claims description 24
- 238000004590 computer program Methods 0.000 claims description 6
- 230000005540 biological transmission Effects 0.000 abstract description 16
- 238000004891 communication Methods 0.000 abstract description 7
- 230000008569 process Effects 0.000 description 38
- 230000003044 adaptive effect Effects 0.000 description 18
- 238000012545 processing Methods 0.000 description 16
- 230000006870 function Effects 0.000 description 14
- 238000013459 approach Methods 0.000 description 10
- 230000006399 behavior Effects 0.000 description 10
- 230000007246 mechanism Effects 0.000 description 10
- 230000009286 beneficial effect Effects 0.000 description 9
- 238000012360 testing method Methods 0.000 description 8
- 238000012790 confirmation Methods 0.000 description 6
- 230000015654 memory Effects 0.000 description 6
- 238000012986 modification Methods 0.000 description 6
- 230000004048 modification Effects 0.000 description 6
- 239000000872 buffer Substances 0.000 description 5
- 230000014509 gene expression Effects 0.000 description 5
- 238000009877 rendering Methods 0.000 description 5
- 230000003068 static effect Effects 0.000 description 5
- 230000008901 benefit Effects 0.000 description 4
- 230000001419 dependent effect Effects 0.000 description 4
- 238000000605 extraction Methods 0.000 description 4
- 238000013475 authorization Methods 0.000 description 3
- 238000004422 calculation algorithm Methods 0.000 description 3
- 238000006243 chemical reaction Methods 0.000 description 3
- 210000001072 colon Anatomy 0.000 description 3
- 239000000284 extract Substances 0.000 description 3
- 101100242901 Quaranfil virus (isolate QrfV/Tick/Afghanistan/EG_T_377/1968) PB2 gene Proteins 0.000 description 2
- 101150082826 Segment-2 gene Proteins 0.000 description 2
- 101100194052 Thogoto virus (isolate SiAr 126) Segment 2 gene Proteins 0.000 description 2
- 230000006835 compression Effects 0.000 description 2
- 238000007906 compression Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 239000012634 fragment Substances 0.000 description 2
- 101150013335 img1 gene Proteins 0.000 description 2
- 101150071665 img2 gene Proteins 0.000 description 2
- 238000013507 mapping Methods 0.000 description 2
- 101100242890 Quaranfil virus (isolate QrfV/Tick/Afghanistan/EG_T_377/1968) PA gene Proteins 0.000 description 1
- 101100247669 Quaranfil virus (isolate QrfV/Tick/Afghanistan/EG_T_377/1968) PB1 gene Proteins 0.000 description 1
- 101150025928 Segment-1 gene Proteins 0.000 description 1
- 101150027881 Segment-3 gene Proteins 0.000 description 1
- 101150091797 Segment-4 gene Proteins 0.000 description 1
- 101100242902 Thogoto virus (isolate SiAr 126) Segment 1 gene Proteins 0.000 description 1
- 101100242891 Thogoto virus (isolate SiAr 126) Segment 3 gene Proteins 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 239000003795 chemical substances by application Substances 0.000 description 1
- 239000002131 composite material Substances 0.000 description 1
- 238000000354 decomposition reaction Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 238000003780 insertion Methods 0.000 description 1
- 230000037431 insertion Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- AWSBQWZZLBPUQH-UHFFFAOYSA-N mdat Chemical compound C1=C2CC(N)CCC2=CC2=C1OCO2 AWSBQWZZLBPUQH-UHFFFAOYSA-N 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 230000000153 supplemental effect Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 230000003936 working memory Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/55—Push-based network services
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/957—Browsing optimisation, e.g. caching or content distillation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/70—Admission control; Resource allocation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/70—Admission control; Resource allocation
- H04L47/83—Admission control; Resource allocation based on usage prediction
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/61—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
- H04L65/612—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for unicast
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/61—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
- H04L65/613—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for the control of the source by the destination
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/56—Provisioning of proxy services
- H04L67/568—Storing data temporarily at an intermediate stage, e.g. caching
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/45—Management operations performed by the client for facilitating the reception of or the interaction with the content or administrating data related to the end-user or to the client device itself, e.g. learning user preferences for recommending movies, resolving scheduling conflicts
- H04N21/454—Content or additional data filtering, e.g. blocking advertisements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/47—End-user applications
- H04N21/472—End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content
- H04N21/4722—End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content for requesting additional data associated with the content
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/60—Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client
- H04N21/63—Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
- H04N21/637—Control signals issued by the client directed to the server or network components
- H04N21/6377—Control signals issued by the client directed to the server or network components directed to server
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/61—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/22—Parsing or analysis of headers
Landscapes
- Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Multimedia (AREA)
- Databases & Information Systems (AREA)
- Computer Security & Cryptography (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Information Transfer Between Computers (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
- Computer And Data Communications (AREA)
Abstract
Description
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストはサーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともに、第2データをプッシュすることに関連する指示を含む1つまたは複数の追加のヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;
第2データをプッシュすることに関連する指示を表す確認応答データをクライアントデバイスに送るステップ;および
1つまたは複数のヘッダフィールドだけ、および場合によってはさらに第1データ特定情報、を用いて、サーバデバイス上の第2データの特定を可能にする第2データ特定情報を決定するステップ;
を含む。
第2データのプッシュをアナウンスするプッシュ約束メッセージをクライアントデバイスに送るステップおよび/または第2データをクライアントデバイスにプッシュするステップを含む。
サーバデバイスから得られるべきデータを特定するステップ;
特定されたデータから第1データを得るHTTPリクエストを生成するステップであって、HTTPリクエストは、サーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともにサーバデバイスが第2データをプッシュするべきか第2データをプッシュするべきでないかに関する指示を含む1つまたは複数の追加のヘッダフィールドを含む、生成するステップ;
第1データを得るとともにサーバデバイスに第2データをプッシュさせまたはプッシュさせないためにHTTPリクエストをサーバデバイスに送るステップ;および
HTTPリクエストを送ることに応答して確認応答データをサーバデバイスから受け取るステップであって、確認応答データは第2データをプッシュすることに関連する指示を表す、受け取るステップ;を含み、
1つまたは複数の追加のヘッダフィールドは、1つまたは複数の追加のヘッダフィールドだけに、および場合によってはさらに第1データ特定情報に、基づいて、サーバデバイス上の特定されたデータから第2データの特定を可能にする第2データ特定情報を定義する。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストはサーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともに、1つまたは複数の追加のヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;および
1つまたは複数の追加のフィールドに含まれる第2データをプッシュすることに関連する指示の関数として第2データをクライアントデバイスにプッシュするかまたはプッシュしないステップ;
を含む。
サーバデバイスから得られるべきデータを特定するステップ;
特定されたデータから第1データを得るHTTPリクエストを生成するステップであって、HTTPリクエストは、サーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともにサーバデバイスが第2データをプッシュするべきか第2データをプッシュするべきでないかに関する指示を含む1つまたは複数の追加のヘッダフィールドを含む、生成するステップ;および
第1データを得るとともにサーバデバイスに第2データをプッシュさせまたはプッシュさせないためにHTTPリクエストをサーバデバイスに送るステップ;
を含む。
第1データを得るHTTPリクエストを送るステップであって、HTTPリクエストは、サーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともに1つまたは複数の追加のヘッダフィールドを含む、送るステップ;
もしクライアントがサーバデバイスに第1データと異なる第2データをプッシュしてほしくないならば、クライアントはサーバにHTTPリクエストに応じて第2データをプッシュしてほしくないということを示す情報アイテムを1つまた複数の追加のヘッダフィールドのうちの少なくとも1つに挿入するステップ;および
HTTPリクエストをサーバデバイスに送るステップ;
を含む。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストはサーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともに、1つまたは複数の追加のヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;および
サーバはHTTPリクエストに応じて第1データと異なる第2データをプッシュしないということを示す情報アイテムをクライアントに送るステップ;
を含む。
第1データを得るHTTPリクエストを送るステップであって、HTTPリクエストは、サーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともに1つまたは複数の追加のヘッダフィールドを含む、送るステップ;
もしクライアントがサーバデバイスに第1データと異なる第2データをプッシュしてほしくないならば、クライアントはサーバにHTTPリクエストに応じて第2データをプッシュしてほしくないということを示す情報アイテムを1つまた複数の追加のヘッダフィールドのうちの少なくとも1つに挿入するステップ;
HTTPリクエストをサーバデバイスに送るステップ;
HTTPリクエストを送ることに応答して、サーバデバイスから確認応答データを受け取るステップであって、確認応答データは、サーバは第1データと異なる第2データをプッシュしないということを示す情報アイテムを含む、受け取るステップ;
を含む。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストはサーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともに、クライアントはHTTPリクエストに応じてサーバにより第2データをプッシュしてほしくないということを示す情報アイテムを含む1つまたは複数の追加のヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;および
HTTPリクエストに応じて、サーバは第1データと異なる第2データをクライアントにプッシュしないということを示す情報アイテムを送るステップ;
を含む。
任意ヘッダフィールドは、第2データ特定情報を定義するために第1データ特定情報内のサブパーツ情報に取って代わる代入サブパーツ情報を含む。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストは、サーバデバイス上の第1データを特定することを可能にする第1データ特定情報を含むとともに、第2データを特定することを可能にする1つまたは複数の任意ヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;および
もし任意ヘッダフィールドがHTTPリクエスト内に存在するならば:
任意ヘッダフィールドだけ、および場合によってはさらに第1データ特定情報、を用いて、サーバデバイス上の第2データを特定することを可能にする第2データ特定情報を決定するステップ、を含む。すなわちHTTPリクエストの内容だけを使用して;および
第2データのプッシュをアナウンスするプッシュ約束メッセージをクライアントデバイスに送るステップおよび/または第2データをクライアントデバイスにプッシュするステップ;
を含む。
サーバデバイスから得られるべきデータを特定するステップ;
その特定されたデータから第1データを得るHTTPリクエストを生成するステップであって、HTTPリクエストは、サーバデバイス上の第1データを特定することを可能にする第1データ特定情報を含むとともに1つまたは複数の任意ヘッダフィールドを含み、任意ヘッダフィールドだけ、および場合によってはさらに第1データ特定情報(すなわち、HTTPリクエストの内容だけ)、に基づいて、サーバデバイス上の特定されたデータから第2データを特定することを可能にする第2データ特定情報を定義する、生成するステップ;
第1データを得るとともにサーバデバイスに第2データをプッシュさせるためにHTTPリクエストをサーバデバイスに送るステップ;
を含む。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストは、サーバデバイス上の第1データを特定することを可能にする第1データ特定情報を含むとともに第2データを特定することを可能にする1つまたは複数の任意ヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;ならびに
もしHTTPリクエスト内に任意ヘッダフィールドが存在するならば:
任意ヘッダフィールドだけ、および場合によってはさらに第1データ特定情報、を用いて、サーバデバイス上の第2データを特定することを可能にする第2データ特定情報を決定するステップ;および
第2データのプッシュをアナウンスするプッシュ約束メッセージをクライアントデバイスに送るステップおよび/または第2データをクライアントデバイスにプッシュするステップ;
を実行するように構成された少なくとも1つのマイクロプロセッサを含む。
サーバデバイスから得られるべきデータを特定するステップ;
その特定されたデータから第1データを得るHTTPリクエストを生成するステップであって、HTTPリクエストは、サーバデバイス上の第1データを特定することを可能にする第1データ特定情報を含むとともに1つまたは複数の任意ヘッダフィールドを含み、任意ヘッダフィールドだけ、および場合によってはさらに第1データ特定情報、に基づいて、サーバデバイス上の特定されたデータから第2データを特定することを可能にする第2データ特定情報を定義する、生成するステップ;
第1データを得るとともにサーバデバイスに第2データをプッシュさせるためにHTTPリクエストをサーバデバイスに送るステップ;
を実行するように構成された少なくとも1つのマイクロプロセッサを含む。
任意ヘッダフィールドは、第2データ特定情報を定義するために第1データ特定情報内のサブパーツ情報に取って代わる代入サブパーツ情報を含む。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストは1つまたは複数のフィルタリングパラメータを含む第1任意ヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;ならびに
もしその第1任意ヘッダフィールドがHTTPリクエスト内に存在するならば:
HTTPリクエストから得られるメインリソースを用いてデータのセットを特定するステップ;
第2データのリストを得るために1つまたは複数のフィルタリングパラメータを用いて、特定されたセットの各データをフィルタリングするステップ;および
第2データをクライアントデバイスにプッシュするステップ;
を含む。
第1データを得るHTTPリクエストを生成するステップであって、HTTPリクエストは1つまたは複数のフィルタリングパラメータを含む第1任意ヘッダフィールドを含む、生成するステップ;
第1データを得るとともにサーバデバイスに、HTTPリクエストから推定されるメインリソースにおいて参照される第2データを、フィルタリングパラメータに従って、プッシュさせるためにHTTPリクエストをサーバデバイスに送るステップ;
を含む。
− リソースタイプを定義し;その1つまたは複数のリソースタイプは、アプリケーションタイプ、テキストタイプ、イメージタイプ、ビデオタイプ、オーディオタイプからの1つまたは複数のタイプを含み;または
− DASHメディアプレゼンテーション記述内のエレメントの識別子を用いてデータの1つまたは複数のグループを特定し;または
− メインリソースのサブパーツを特定する時間レンジを用いて第1任意ヘッダフィールドにおいて定義される。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストは1つまたは複数のフィルタリングパラメータを含む第1任意ヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;ならびに
もし第1任意ヘッダフィールドがHTTPリクエスト内に存在するならば:
HTTPリクエストから得られるメインリソースを用いてデータのセットを特定するステップ;
第2データのリストを得るために1つまたは複数のフィルタリングパラメータを用いて、特定されたセットの各データをフィルタリングするステップ;および
第2データをクライアントデバイスにプッシュするステップ;
を実行するように構成された少なくとも1つのマイクロプロセッサを含む。
− リソースタイプを定義し;その1つまたは複数のリソースタイプは、アプリケーションタイプ、テキストタイプ、イメージタイプ、ビデオタイプ、オーディオタイプからの1つまたは複数のタイプを含み;または
− DASHメディアプレゼンテーション記述内のエレメントの識別子を用いてデータの1つまたは複数のグループを特定し;または
− メインリソースのサブパーツを特定する時間レンジを用いて第1任意ヘッダフィールドにおいて定義される。
第1データを得るHTTPリクエストを生成するステップであって、HTTPリクエストは1つまたは複数のフィルタリングパラメータを含む第1任意ヘッダフィールドを含む、生成するステップ;
第1データを得るとともにサーバデバイスに、HTTPリクエストから推定されるメインリソースにおいて参照される第2データを、フィルタリングパラメータに従って、プッシュさせるためにHTTPリクエストをサーバデバイスに送るステップ;
を実行するように構成された少なくとも1つのマクロプロセッサを含む。
− クライアントはサーバにリクエストを送り、そのリクエストは様々な種類の“ヘッダ”が任意に後に続く“request_line”から構成される。“request−line”は、普通、場合によってはレンジヘッダなどを用いてサーバ上の要求されたリソースまたはデータを特定する“Request−URI”パラメータと共にメソッド(例えば“GET”)を含む;
− サーバは、そのウェブリソースのリプリゼンテーションを含むレスポンスを用いてクライアントのリクエストに応える。
− HEADERS:HTTPヘッダの送信のために提供される
○HTTP/2はヘッダ(任意である。すなわち処理側デバイスに理解されなければ無視される)をより厳しいルールに従う疑似ヘッダから区別する。後者は、HTTPメソッドおよびrequest−URIを示すために以前のHTTPバージョンで定義されているrequest−lineのマッピングに対応する。本文書においては、“HTTPヘッダ”または“ヘッダ”は、任意のヘッダを指定するべく意図されているのであり、明示的にそのようなものとして指定される疑似ヘッダを指定するべく意図されているのではない。
○さらに、本文書においてもなお、“Request−URI”は、RFC2616で定義されているRequest−URI(すなわち、“request−line”に用いられているサーバ上の要求されているリソースを特定するパラメータ)またはそれの同等物/HTTP/2疑似ヘッダへの変換を指定するべく意図されている。
− DATA:これは、HTTPメッセージ内容の送信のために提供される
− PUSH_PROMISE:これはプッシュされる内容をアナウンスするために提供される
− PRIORITY:これはストリームの優先順位をセットするために提供される
− WINDOW_UPDATE:これは制御フローウィンドウの値をアップデートするために提供される
− SETTINGS:これは設定パラメータを伝えるために提供される
− CONTINUATION:これはヘッダブロックフラグメントのシーケンスを継続させるために提供される
− RST_STREAM:これはストリームを終端させまたはキャンセルするために提供される
などの様々な意味を有するフレームの限られたセットを定義する。
− 潜在的な無用の(クライアントにとって)データがサーバによりプッシュされるのを避けるためにクライアント制御の送信を維持すること;
− 上で言及されたスケーラビリティの利点を維持するためにサーバ側での特定のアプリケーション知識の使用を防止すること;
− レガシークライアントおよび/または本発明を実装しないサーバの間でのインタオペラビリティおよびキャッシュ能力を維持するためにリソースおよびサブリソースを在来の仕方で要求する仕方を維持すること。例えば、DASHセグメントの場合、これは、要求されたセグメントを処理するために特定の動作(例えばリクエスト−URIの変換など)を必要とするリクエストフォーマットの導入を避けるべきである;
− サーバ側の処理を少なく保つこと;
のうちのなるべく多くが満たされるべきであることを意味する。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、このHTTPリクエストは、サーバデバイス上の第1データを特定することを可能にする第1データ特定情報を含むとともに第2データを可能にする1つまたは複数の任意ヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;ならびに
もしその任意ヘッダフィールドがHTTPリクエスト内に存在するならば:
任意ヘッダフィールドだけ、および場合によってはさらに第1データ特定情報、を用いて、サーバデバイス上の第2データを特定することを可能にする第2データ特定情報を決定するステップ、を含む。すなわち、HTTPリクエストは第2リソースを決定するために自給自足的である、すなわち、自己記述的である;および
第2データをクライアントデバイスにプッシュするとアナウンスするプッシュ約束メッセージを送るおよび/または第2データをクライアントデバイスにプッシュするステップ;
を含む。
サーバデバイスから得られるべきデータを特定するステップ;
その特定されたデータから第1データを得るHTTPリクエストを生成するステップであって、HTTPリクエストは、サーバデバイス上の第1データを特定することを可能にする第1データ特定情報を含むとともに1つまたは複数の任意ヘッダフィールドを含み、その任意ヘッダフィールドだけ、および場合によってはさらに第1データ特定情報(すなわち、HTTPリクエストの内容だけ)、に基づいて、サーバデバイス上の特定されたデータから第2データを特定することを可能にする第2データ特定情報を定義する、生成するステップ;
第1データを得るとともにサーバデバイスに第2データをプッシュさせるためにHTTPリクエストをサーバデバイスに送るステップ;
を含む。
− “プリフェッチ”または“次”を明示する“rel”値を有する<link>エレメント;
− 例えばCSSリソースを選択するスタイルシート関連リソースを明示する<link>エレメント;
− 例えばjavaスクリプトコードに対応するサブリソースを選択する<script>エレメント;
− <img>および/または<video>のようなメディアエレメント;
に依拠することができる。
<Push−Request:HTTP://server/path/segment−2.mp4>
<Push−Request:HTTP://server/path/segment−{1}.mp4;{2−5}>
ここで{1}は変化部分を定義し、{2−5}は代入値である。
<Push−Request:request−URI;segment−{1}.mp4;{2−5}>
ここで“request−URI”はサポートであり、“segment−{1}.mp4”は変化部分{1}を有するサポートにより定義されるURIの部分であり、{2−5}は代入値である。
<Push−Request:“mp4−live−h264bl_low−{1}.m4s”;{(N+1)−(N+K)}>
push_request=“Push−Request:“header_name”;“uri_template*(“;”definition)
header_name=“URI”|HeaderName
定義=値|リスト|レンジ
ここで値は、代入値を文字の列として表現する第1の可能性である;
リスト=値|レンジ*(“:”値|レンジ)は、代入値を値(または値のレンジ)のコロン分離リストとして表現する第2の可能性である。コンマ文字は慣習的に同じヘッダのための数個の値を分離するために使用されるので、コンマ文字よりもコロン文字の方が選択されていることに注意されたい。
レンジ=“{“スタート”−“エンド”}”は、代入値をレンジとして表現する第3の可能性である。これは、‘スタート’と‘エンド’との間の、‘スタート’と‘エンド’との両方を含む、全ての値のリストと解釈されるべきである。これは、整数である値のためにだけ可能である。
1.uri_templateのリストの入手
− 第1変数拡張(提供された順序での第1)のために、特定プッシュヘッダで定義されているuri_templateが使用される。
− 次の1つまたは複数の変数拡張(提供された順序での)のために、先行する1つまたは複数の変数の拡張からもたらされるuri_templateのリストが使用される。
2.得られたリストの中の各uri_templateは、次のようにして得られたuri_templateのリストに置き換えられる:
− 拡張ステップで考察された変数の各値のために、uri_templateが複製され、URIテンプレートの中の変数は代入値のうちの1つに置き換えられる。
− ‘a−1’
− ‘a−2’
− ‘b−1’
− ‘b−2’
− ‘a−1’
− ‘b−1’
− ‘a−2’
− ‘b−2’
− ‘a−3’
− ‘b−3’
− ‘a−1’
− ‘a−2’
− ‘b−1’
− ‘b−2’
− ‘a−1’
− ‘b−1’
− ‘a−2’
− ‘b−2’
− ‘a−3’
− ‘b−3’
GET/server1/video/segment−1.mp4
であるならば、特定プッシュヘッダは次のようであり得る
<Push−Request:URI;segment−{1}.mp4;{2−4};var_base=/AnotherServer/video/>
http://AnotherServer/video/segment−2.mp4
http://AnotherServer/video/segment−3.mp4
http://AnotherServer/video/segment−4.mp4
− 第1のものはクライアントの興味の対象であるリソースを示す。これは、上に記載された特定プッシュヘッダである;
− 第2のものは、クライアントがサーバプッシュを受け入れることをサーバに示す。これは接続セットアップ時に取り決められ得るのであるが、クライアントにとっては、プッシュされたデータをそれが何時受け入れ得るかということとプッシュをキャンセルするより大きなリスクが何時存在するか(例えばクライアントが頻繁な切り替えを伴うよく確立されていないビデオモードを経験する時)ということとをサーバに告げることは有益であろう。
− 例えば、クライアントが次のセグメントを予想したいとき;
− あるいはクライアントがビデオにおける時間オフセットを探したいとき;
− あるいは所与の期間にサーバが次のセグメントを送るとクライアントが信頼しているとき;
− あるいはクライアントが切り替えを予想しているとき;
− あるいはクライアントが関連付けられているリソースに関心を持っているとき;
− あるいはクライアントが多重化されていないオーディオ−ビデオセグメントを要求するとき。そのような場合、ビデオセグメントを要求するとき、それは対応するオーディオセグメントに対する関心を示し得る。
Push−Request:header_name“;”uri_template
Push−Values:definition[*(“;”definition)]
この別の実施形態に関しては、下記の例850は次のように書き換えられるであろう:
GET/server/video/Rep−R1/segment−01.mp4
Push−Request:URI;segment−{1}.mp4;
Push−Values:02:10
さらに、下記の例865は次のようになるであろう:
GET/server/video/Rep−R1/segment−01.mp4
Push−Request:URI;Rep−{1}/segment−{2}.mp4
Push−Values:R1:R2;{01−03}
GET/server/video/Rep−R1/segment−01.mp4
Push−Request:URI;Rep−{var1}/segment−{var2}.mp4
Push−Values:var1=R1:R2
Push−Values:var2={01−03}
Push−Support:URI
Push−Pattern:segment−{var}.mp4
Push−Values:var=02:10
− クライアントがプッシュに関心を持っていないこと;あるいは
− クライアントが、幾つかのリクエストのためのプッシュを中断させたがっていること。
0*(ゼロまたはそれ以上)個の特定media−typeパラメータ(例えば:charset);これは例えば、リクエスト:*.jpg、*.pngを発行するクライアントによりサポートされるメディアタイプのリストであり得る
0−1個の“q”パラメータ(相対的重さを示すための)
0*個の拡張パラメータ(拡張パラメータが存在するならばセパレータとして“q”パラメータは必須である)
を持つことを許す。
Accept−Push−Policy:<urn>[‘:’<urn−specific−param>*];q=<N>
に帰着し、この“q”パラメータは、何らかのグローバルパラメータが存在するならば、必須である。
Accept−Push−Policy:urn:mpeg:dash:fdh:push−next;5
を用いて、1つの要求されたセグメントに続く次の5つのセグメントをプッシュするようにサーバに求めることができ、ここで第1部分、URN、はプッシュディレクティブまたは使用するプッシュポリシーのタイプを一意的に特定する。‘;’セパレータの次の第2パラメータ(任意の)は、このプッシュポリシーにおいて適用するパラメータに対応する。
Accept−Push−Policy:urn:mpeg:dash:fdh:push−next;3、
urn:mpeg:dash:fdh:push−next;5;q=0.5
Accept−Push−Policy:urn:canon:dash:fdh:push−fast−start;high、
urn:canon:dash:fdh:push−fast−start;mid;q=0.7
urn:canon:dash:fdh:push−fast−start;low;q=0.3
あるいは解像度の方を選んで:
Accept−Push−Policy:urn:canon:dash:fdh:push−fast−start;HD、
urn:canon:dash:fdh:push−fast−start;SD;q=0.7
Supported−Push−Policies:urn:dash:adobe:k−push、urn:dash:canon:fast−start
Supported−Push−Policies: urn:dash:adobe:k−push;0−100、urn:dash:canon:fast−start;low:medium
Supported−Push−Policies: urn:dash:adobe:k−push;0−100;q=0.4、urn:dash:canon:fast−start;low:medium;q=0.9
<meta name=<<dash:fdh:pushDirective >> content= << urn:one_push_directive_ID>> />
ここで名前属性に許される新しい“dash:fdh:pushDirective”値は既存のエクステンションリスト:https://wiki.whatwg.org/wiki/MetaExtensionsに登録され得るであろう。そのような登録は、メディア配信を最適化するストラテジーをアプリケーションサーバが考慮し、メディアが例えば<video>エレメントとしてウェブページに埋め込まれるということをウェブクライアントが知らされることを可能にする。コンテンツ属性に置く値は、図12bの参照番号1230の登録された値のうちの1つであり得る。
Push−Request:segment−{1}.mp4;{02−04}:{10−13}
Push−Request:push−next
Push−Request:push−time
Push−Request:fast−start
Push−Request:mpd−update
Push−Request:push−next;5
Push−Request:push−time;2
Push−Request:fast−start;2
Push−Request:mpd−update;patch
Push−Request:push−next;
Push−Request:URN*[‘;’<urn−specific−params>]
として表現され得る。
urn:mpeg:dash:fdh:2015:push−next−*
または
urn:mpeg:dash:fdh:2015:push−time−2
として登録するのが有利であり得るということに留意するべきである。
− URL:要求されたリソースのURLを示す。対応するJSONパラメータは“url”である。
− PushDirective:クライアント選択されたPushDirectiveのURNを示し、JSON名“PushDirective”を有する。
− pushDirectiveに特有であるとともにpushDirectiveにより定義される値を示す任意のpushParams。
第1データを得るHTTPリクエストをクライアントデバイスから受け取るステップであって、HTTPリクエストは1つまたは複数のフィルタリングパラメータを含む第1任意ヘッダフィールドを含む、受け取るステップ;
第1データを取り出してクライアントデバイスに送るステップ;ならびに
もし第1任意ヘッダフィールドがHTTPリクエスト内に存在するならば:
HTTPリクエストから得られたメインリソースを用いてデータのセットを特定するステップ;
第2データのリストを得るために1つまたは複数のフィルタリングパラメータを用いて、特定されたセットの各データをフィルタリングするステップ;および
第2データをクライアントデバイスにプッシュするステップ;
を含む。
第1データを得るHTTPリクエストを生成するステップであって、HTTPリクエストは1つまたは複数のフィルタリングパラメータを含む第1任意ヘッダフィールドを含む、生成するステップ;
第1データを得るとともにサーバデバイスに、HTTPリクエストから推定されるメインリソースにおいて参照される第2データを、フィルタリングパラメータに従って、プッシュさせるためにHTTPリクエストをサーバデバイスに送るステップ;
を含む。
Push−Request: application/javascript;q=1、text/css;q=0.8、text/html;q=0.7、image/png;q=0.6、image/*;q=0.4
Push−Request:Referer;image/png;q=0.6,image/*;q=0.4
Referer:the_url_to−web−page
Push−Request:video/mp4;q=1、video/webm;q=0.4
Push−Request:URI;video.{1};{video/*.mp4;q=1,video/webm;q=0.4}
を書くことであり得る。
Push−Request:Range;{1};[1400−4000];q=1:[4000−6000];q=0.8
Push−Request:Referer;video.{1};video/*.mp4
Referer:the_url_to−MPD
Claims (29)
- サーバデバイスとクライアントデバイスとの間でデータを送信する方法であって、この方法は、前記サーバデバイスにおいて:
第1データを得るHTTPリクエストを前記クライアントデバイスから受け取るステップであって、前記HTTPリクエストは前記サーバデバイス上の前記第1データの特定を可能にする第1データ特定情報を含むとともに、第2データをプッシュすることに関連する指示を含む1つまたは複数の追加のヘッダフィールドを含む、前記受け取るステップ;
前記第1データを取り出して前記クライアントデバイスに送るステップ;
第2データをプッシュすることに関連する前記指示を表す確認応答データを前記クライアントデバイスに送るステップ;および
前記1つまたは複数のヘッダフィールドだけ、および場合によってはさらに前記第1データ特定情報、を用いて、前記サーバデバイス上の前記第2データの特定を可能にする第2データ特定情報を決定するステップ;
を含む、方法。 - 前記第2データの前記プッシュをアナウンスするプッシュ約束メッセージを前記クライアントデバイスに送るステップおよび/または前記第2データを前記クライアントデバイスにプッシュするステップ、
をさらに含む、請求項1に記載の方法。 - 前記確認応答データは前記第2データをプッシュするための指示を表す、請求項1に記載の方法。
- 第2データをプッシュすることに関連する前記指示は、第2データをプッシュすることに関連する少なくとも2つの異なる指示を含むリストを含む、請求項1に記載の方法。
- 前記確認応答データは第2データをプッシュすることに関連する前記少なくとも2つの異なる指示のうちの1つを含み、第2データをプッシュすることに関連する前記少なくとも2つの異なる指示のうちの前記の1つは、前記クライアントデバイスにプッシュされるべき前記第2データを特定するために使用される、請求項4に記載の方法。
- 第2データをプッシュすることに関連する前記指示は前記第2データのデータのタイプと関連付けられ、前記データのタイプは記述データタイプまたはコンテンツデータタイプを含み、前記第2データはコンテンツデータにまたは記述データに属する、請求項1に記載の方法。
- 前記確認応答データは、第2データをプッシュすることに関連する指示を含み、前記確認応答データ内の第2データをプッシュすることに関連する前記指示は、前記HTTPリクエスト内の第2データをプッシュすることに関連する前記指示とは異なる、請求項1に記載の方法。
- 第2データをプッシュすることに関連する前記指示は、少なくとも1つの一意識別子を含み、前記少なくとも1つの一意識別子は、第2データをプッシュするためのディレクティブとプッシュされるべき前記第2データのアイデンティフィケーションとを表すかまたは第2データをプッシュしないためのディレクティブを表す、請求項1に記載の方法。
- 前記1つまたは複数の追加ヘッダフィールドは1つまたは複数の任意ヘッダフィールドである、請求項1に記載の方法。
- 前記第1および第2のデータ特定情報は、それぞれ、第1および第2のユニフォームリソースアイデンティファイア、URI、を含む、請求項1に記載の方法。
- 前記1つまたは複数の任意ヘッダフィールドは、前記HTTPリクエストの前記内容から前記第2URIを生成する少なくとも1つの構築ルールを含む、請求項10に記載の方法。
- 前記1つまたは複数の任意ヘッダフィールドは変化部分情報および代入情報を含み、前記変化部分情報は参照URI内の少なくとも1つの変化サブパーツを特定し、前記代入情報は1つまたは複数の前記第2のURIを定義するために前記参照URIにおいて特定される前記変化サブパーツに取って代わる少なくとも1つの代入値を含む、請求項10に記載の方法。
- 前記第1データ特定情報は、前記サーバデバイス上のメインリソースを特定する第1ユニフォームリソースアイデンティファイア、URI、を含むとともに、前記メインリソースのサブパーツを前記第1データとして定義するサブパーツ情報を含み;および
前記任意ヘッダフィールドは、前記第2データ特定情報を定義するために前記第1データ特定情報内の前記サブパーツ情報に取って代わる代入サブパーツ情報を含む、
請求項11に記載の方法。 - 前記サブパーツ情報は、前記メインリソースの中のバイトのレンジ値を含む、請求項13に記載の方法。
- 前記1つまたは複数の任意ヘッダフィールドは変化部分情報および代入情報を含み、前記変化部分情報は参照URI内の少なくとも1つの変化サブパーツを特定し、前記代入情報は1つまたは複数の前記第2のURIを定義するために前記参照URIにおいて特定される前記変化サブパーツに取って代わる少なくとも1つの代入値を含む、請求項10に記載の方法。
- 前記変化部分情報は、前記代入情報に含まれるそれぞれの1つまたは複数の代入値を用いて置換されるべき前記参照URI内の2つ以上のサブパーツを特定する、請求項15に記載の方法。
- サーバデバイスとクライアントデバイスとの間でデータを送信する方法であって、前記方法は、クライアントデバイスにおいて:
前記サーバデバイスから得られるべきデータを特定するステップ;
前記特定されたデータから第1データを得るHTTPリクエストを生成するステップであって、前記HTTPリクエストは、前記サーバデバイス上の前記第1データの特定を可能にする第1データ特定情報を含むとともに前記サーバデバイスが第2データをプッシュするべきか第2データをプッシュするべきでないかに関する指示を含む1つまたは複数の追加のヘッダフィールドを含む、前記生成するステップ;
前記第1データを得るとともに前記サーバデバイスに第2データをプッシュさせまたはプッシュさせないために前記HTTPリクエストを前記サーバデバイスに送るステップ;および
前記HTTPリクエストを送ることに応答して確認応答データを前記サーバデバイスから受け取るステップであって、前記確認応答データは第2データをプッシュすることに関連する前記指示を表す、前記受け取るステップ;を含み、
前記1つまたは複数の追加のヘッダフィールドは、前記1つまたは複数の追加のヘッダフィールドだけに、および場合によってはさらに前記第1データ特定情報に、基づいて、前記サーバデバイス上の前記特定されたデータから第2データの特定を可能にする第2データ特定情報を定義する、
方法。 - サーバデバイスからクライアントデバイスによりデータを受け取る方法であって、前記方法は、前記クライアントデバイスにおいて:
第1データを得るHTTPリクエストを送るステップであって、前記HTTPリクエストは、前記サーバデバイス上の前記第1データの特定を可能にする第1データ特定情報を含むとともに1つまたは複数の追加のヘッダフィールドを含む、前記送るステップ;
もし前記第1データと異なる第2データを前記サーバデバイスがプッシュすることを前記クライアントが希望しなければ、前記HTTPリクエストに応答して第2データが前記サーバによりプッシュされることを前記クライアントが希望しないことを示す情報アイテムを前記1つまたは複数の追加ヘッダフィールドのうちの少なくとも1つに挿入するステップ;および
前記HTTPリクエストを前記サーバデバイスに送るステップ;
を含む、方法。 - データをサーバデバイスからクライアントデバイスに送る方法であって、前記方法は、前記サーバデバイスにおいて:
第1データを得るHTTPリクエストを前記クライアントデバイスから受け取るステップであって、前記HTTPリクエストは前記サーバデバイス上の第1データの特定を可能にする第1データ特定情報を含むとともに、1つまたは複数の追加のヘッダフィールドを含む、前記受け取るステップ;
前記第1データを取り出して前記クライアントデバイスに送るステップ;および
前記サーバは前記HTTPリクエストに応じて前記第1データと異なる第2データを前記クライアントにプッシュしないということを示す情報アイテムを送るステップ;
を含む、方法。 - 前記サーバは第2データをプッシュしないということを示す前記情報は少なくとも1つの一意識別子を含み、前記少なくとも1つの一意識別子は第2データをプッシュさせないためのディレクティブを表す、請求項19に記載の方法。
- 前記HTTPリクエストを送ることに応答して、前記サーバデバイスから確認応答データを受け取るステップをさらに含み、前記確認応答データは、前記第1データと異なる第2データを前記サーバがプッシュしないということを示す情報アイテムを含む、請求項18に記載の方法。
- 前記第1データを取り出して前記クライアントデバイスに送るステップ;および
前記サーバは、前記HTTPリクエストに応答して、前記第1データと異なる第2データを前記クライアントに送らないということを示す情報アイテムを前記クライアントに送るステップ;
をさらに含む、請求項19に記載の方法。 - 前記サーバが第2データをプッシュしないということを示す前記情報は少なくとも1つの一意識別子を含み、前記少なくとも1つの一意識別子は第2データをプッシュしないためのディレクティブを表す、請求項19に記載の方法。
- 前記サーバにより第2データがプッシュされることを前記クライアントが希望しないということを示す前記情報は少なくとも1つの一意識別子を含み、前記少なくとも1つの一意識別子は第2データをプッシュしないためのディレクティブを表す、請求項19に記載の方法。
- サーバデバイスとクライアントデバイスとの間でデータを送信する方法であって、前記方法は、前記サーバデバイスにおいて:
第1データを得るHTTPリクエストを前記クライアントデバイスから受け取るステップであって、前記HTTPリクエストは1つまたは複数のフィルタリングパラメータを含む第1任意ヘッダフィールドを含む、前記受け取るステップ;
前記第1データを取り出して前記クライアントデバイスに送るステップ;ならびに
もし前記第1任意ヘッダフィールドが前記HTTPリクエスト内に存在するならば:
前記HTTPリクエストから得られたメインリソースを用いてデータのセットを特定するステップ;
第2データのリストを得るために前記1つまたは複数のフィルタリングパラメータを用いて、前記特定されたセットの各データをフィルタリングするステップ;および
前記第2データを前記クライアントデバイスにプッシュするステップ;
を含み、前記1つまたは複数のフィルタリングパラメータは:
− リソースタイプを定義し;前記1つまたは複数のリソースタイプはアプリケーションタイプ、テキストタイプ、イメージタイプ、ビデオタイプ、オーディオタイプからの1つまたは複数のタイプを含み;または
− DASHメディアプレゼンテーション記述内のエレメントの識別子を用いてデータの1つまたは複数のグループを特定し;または
− 前記メインリソースのサブパーツを特定する時間レンジを用いて前記第1任意ヘッダフィールドにおいて定義される;
方法。 - サーバデバイスとクライアントデバイスとの間でデータを送信する方法であって、前記方法は、前記クライアントデバイスにおいて:
第1データを得るHTTPリクエストを生成するステップであって、前記HTTPリクエストは1つまたは複数のフィルタリングパラメータを含む第1任意ヘッダフィールドを含む、前記生成するステップ;
前記第1データを得るとともに前記サーバデバイスに、前記HTTPリクエストから推定されるメインリソースにおいて参照される第2データを、前記フィルタリングパラメータに従って、プッシュさせるために前記HTTPリクエストを前記サーバデバイスに送るステップ;
を含み、
前記1つまたは複数のフィルタリングパラメータは:
− リソースタイプを定義し;前記1つまたは複数のリソースタイプは、アプリケーションタイプ、テキストタイプ、イメージタイプ、ビデオタイプ、オーディオタイプからの1つまたは複数のタイプを含み;または
− DASHメディアプレゼンテーション記述内のエレメントの識別子を用いてデータの1つまたは複数のグループを特定し;または
− 前記メインリソースのサブパーツを特定する時間レンジを用いて前記第1任意ヘッダフィールドにおいて定義される;
方法。 - プログラマブルな装置のためのコンピュータプログラム製品であって、前記コンピュータプログラム製品は、前記プログラムがプログラマブルな装置によってロードされて実行されたとき請求項1、17、18、19、25および26のうちのいずれか1つに記載の方法の各ステップを実行するための命令を含む、コンピュータプログラム製品。
- 請求項1、17、18、19、25および26のうちのいずれか1つに記載の方法を実行するためのコンピュータプログラムの命令を記憶しているコンピュータ可読記憶媒体。
- 請求項1、17、18、19、25および26のうちのいずれか1つに記載の方法の各ステップを実行するようになされている手段を含むデバイス。
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB1501437.6 | 2015-01-28 | ||
GB1501437.6A GB2534849A (en) | 2015-01-28 | 2015-01-28 | Client-driven push of resources by a server device |
GB1509094.7A GB2534617A (en) | 2015-01-28 | 2015-05-27 | Improved client-driven push of resources by a server device |
GB1509094.7 | 2015-05-27 | ||
PCT/EP2016/050713 WO2016120089A1 (en) | 2015-01-28 | 2016-01-15 | Improved client-driven push of resources by a server device |
Publications (3)
Publication Number | Publication Date |
---|---|
JP2018509679A true JP2018509679A (ja) | 2018-04-05 |
JP2018509679A5 JP2018509679A5 (ja) | 2019-02-21 |
JP6686029B2 JP6686029B2 (ja) | 2020-04-22 |
Family
ID=52674078
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2017537233A Active JP6686029B2 (ja) | 2015-01-28 | 2016-01-15 | サーバデバイスによるリソースの改善されたクライアント主導型プッシュ |
Country Status (7)
Country | Link |
---|---|
US (2) | US10348846B2 (ja) |
EP (1) | EP3251322B1 (ja) |
JP (1) | JP6686029B2 (ja) |
KR (1) | KR102007105B1 (ja) |
CN (1) | CN107211022B (ja) |
GB (3) | GB2534849A (ja) |
WO (1) | WO2016120089A1 (ja) |
Families Citing this family (45)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP2953313A1 (en) * | 2014-06-05 | 2015-12-09 | Thomson Licensing | Method for operating a cache arranged along a transmission path between client terminals and at least one server, and corresponding cache |
US11917002B2 (en) | 2014-10-14 | 2024-02-27 | Comcast Cable Communications, Llc | Manipulation and recording of content transmissions |
US11943289B2 (en) | 2014-10-14 | 2024-03-26 | Comcast Cable Communications, Llc | Manipulation of content transmissions |
US10880357B2 (en) * | 2014-12-23 | 2020-12-29 | Adobe Inc. | Reducing requests for media segments in streaming of multimedia content |
GB2534849A (en) * | 2015-01-28 | 2016-08-10 | Canon Kk | Client-driven push of resources by a server device |
GB2540632B (en) * | 2015-07-24 | 2018-05-16 | Canon Kk | Methods, devices and computer programs for pushing data in a network environment comprising cache servers |
US10158682B2 (en) | 2015-09-23 | 2018-12-18 | Adobe Systems Incorporated | Power efficient multimedia content streaming based on a server push |
US10152080B2 (en) * | 2015-09-23 | 2018-12-11 | Adobe Systems Incorporated | Power efficient multimedia content streaming based on media segment duration |
CN106604077B (zh) * | 2015-10-14 | 2020-09-29 | 中兴通讯股份有限公司 | 自适应流媒体传输方法及装置 |
US20180109577A1 (en) * | 2016-10-13 | 2018-04-19 | Sharp Laboratories Of America, Inc. | Systems and methods for enabling communications associated with digital media distribution |
CN107959667B (zh) * | 2016-10-18 | 2020-10-09 | 华为技术有限公司 | 一种媒体分片的推送方法、服务器及客户端 |
US20180176325A1 (en) * | 2016-12-15 | 2018-06-21 | Huawei Technologies Co., Ltd. | Data pre-fetching in mobile networks |
CN108512876B (zh) * | 2017-02-27 | 2020-11-10 | 腾讯科技(深圳)有限公司 | 数据的推送方法及装置 |
US11659057B2 (en) | 2017-04-19 | 2023-05-23 | Comcast Cable Communications, Llc | Methods and systems for content delivery using server push |
KR102307447B1 (ko) * | 2017-05-02 | 2021-09-30 | 삼성전자주식회사 | 네트워크 환경 모니터링에 기반하는 http 적응적 스트리밍 서버, 방법, 및 클라이언트 단말 |
US11477305B2 (en) * | 2017-05-03 | 2022-10-18 | Comcast Cable Communications, Llc | Local cache bandwidth matching |
CA3011330A1 (en) * | 2017-07-14 | 2019-01-14 | Comcast Cable Communications, Llc | Reduced content manifest size |
US11622020B2 (en) * | 2017-08-31 | 2023-04-04 | Micro Focus Llc | Push control |
JP6950408B2 (ja) * | 2017-09-28 | 2021-10-13 | 京セラドキュメントソリューションズ株式会社 | 情報処理システム、画像形成装置、および情報処理方法 |
US10461884B2 (en) * | 2017-10-05 | 2019-10-29 | Comcast Cable Communications, Llc | Server selected variable bitrate streaming |
GB2567665B (en) * | 2017-10-19 | 2022-06-22 | Arm Ip Ltd | Asset update service |
US20190141075A1 (en) * | 2017-11-09 | 2019-05-09 | Monarx, Inc. | Method and system for a protection mechanism to improve server security |
CN109981695B (zh) * | 2017-12-27 | 2021-03-26 | Oppo广东移动通信有限公司 | 内容推送方法、装置及设备 |
CN109063142B (zh) * | 2018-08-06 | 2021-03-05 | 网宿科技股份有限公司 | 网页资源推送方法、服务器及存储介质 |
US11716264B2 (en) * | 2018-08-13 | 2023-08-01 | Cisco Technology, Inc. | In situ triggered function as a service within a service mesh |
CA3057118A1 (en) | 2018-09-28 | 2020-03-28 | Comcast Cable Communications, Llc | Per-segment parameters for content |
CN109151492B (zh) * | 2018-09-29 | 2021-02-02 | 网宿科技股份有限公司 | 一种直播视频的快速启动方法及装置 |
CN109359215B (zh) * | 2018-12-03 | 2023-08-22 | 江苏曲速教育科技有限公司 | 视频智能推送方法和系统 |
US11159635B2 (en) | 2019-05-07 | 2021-10-26 | Hulu, LLC | Soft server push in video streaming |
US11212368B2 (en) * | 2019-05-17 | 2021-12-28 | Netflix, Inc. | Fire-and-forget offload mechanism for network-based services |
CN110730206A (zh) * | 2019-09-06 | 2020-01-24 | 浪潮金融信息技术有限公司 | 一种应用于新零售平台数据展示的数据服务方案 |
US11425187B2 (en) * | 2019-09-30 | 2022-08-23 | Tencent America Llc. | Session-based information for dynamic adaptive streaming over HTTP |
CN111427850A (zh) | 2019-11-06 | 2020-07-17 | 杭州海康威视数字技术股份有限公司 | 一种显示报警文件的方法、装置及系统 |
CN111586100B (zh) * | 2020-04-01 | 2022-04-22 | 富途网络科技(深圳)有限公司 | 目标对象消息发送装置及方法 |
CN111988235B (zh) * | 2020-08-13 | 2023-05-09 | 暨南大学 | 一种基于多http/3连接的并行传输方法 |
US20220078261A1 (en) * | 2020-09-10 | 2022-03-10 | Microsoft Technology Licensing, Llc | Controlling client/server interaction based upon indications of future client requests |
CN112600823A (zh) * | 2020-12-09 | 2021-04-02 | 上海牙木通讯技术有限公司 | 句柄标识解析缓存方法、查询方法及句柄标识解析系统 |
US11451602B2 (en) * | 2021-01-06 | 2022-09-20 | Tencent America LLC | Methods and apparatuses for dynamic adaptive streaming over HTTP |
US11816177B2 (en) * | 2021-07-21 | 2023-11-14 | Yext, Inc. | Streaming static web page generation |
CN114553947B (zh) * | 2022-01-29 | 2024-01-19 | 北京金堤科技有限公司 | 一种对消息进行处理的方法及装置 |
US12034789B2 (en) * | 2022-04-19 | 2024-07-09 | Tencent America LLC | Extensible request signaling for adaptive streaming parameterization |
CN115022280B (zh) * | 2022-06-16 | 2023-07-14 | 杭州楷知科技有限公司 | 一种nat探测的方法、客户端及系统 |
CN114827633B (zh) * | 2022-06-17 | 2022-09-13 | 浙江华创视讯科技有限公司 | 一种媒体流容灾方法、装置和相关设备 |
KR102663914B1 (ko) * | 2022-07-13 | 2024-05-13 | 주식회사 시큐다임 | 전자 장치 및 이에 의한 http 트래픽의 분석 방법 |
US11824745B1 (en) * | 2022-12-15 | 2023-11-21 | Amazon Technologies, Inc. | Reverse engineering computer network system functionality |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20130246583A1 (en) * | 2012-03-14 | 2013-09-19 | Canon Kabushiki Kaisha | Method, system and server device for transmitting a digital resource in a client-server communication system |
KR20140055340A (ko) * | 2012-10-31 | 2014-05-09 | 삼성전자주식회사 | 적응형 스트리밍을 이용한 미디어 세그먼트 송수신 방법 및 장치 |
WO2015004276A2 (en) * | 2013-07-12 | 2015-01-15 | Canon Kabushiki Kaisha | Adaptive data streaming method with push messages control |
Family Cites Families (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1599910A (zh) * | 2001-12-06 | 2005-03-23 | 株式会社爱可信 | 用于向移动设备提供订购内容服务的系统和方法 |
CN1881242A (zh) * | 2005-06-14 | 2006-12-20 | 张晓东 | 汽车行业跨企业供应链系统web应用平台 |
US7873710B2 (en) * | 2007-02-06 | 2011-01-18 | 5O9, Inc. | Contextual data communication platform |
CN101350820A (zh) * | 2008-08-29 | 2009-01-21 | 中兴通讯股份有限公司 | 一种推送业务代理网关对推送业务发起者的安全认证方法 |
CN101370033B (zh) * | 2008-09-26 | 2011-09-14 | 成都市华为赛门铁克科技有限公司 | 一种推送消息的方法和设备 |
WO2011100901A2 (zh) * | 2011-04-07 | 2011-08-25 | 华为技术有限公司 | 媒体内容的传输处理方法、装置与系统 |
CN103036960A (zh) * | 2012-12-07 | 2013-04-10 | 中国联合网络通信集团有限公司 | 一种信息推送方法、装置及系统 |
GB2516112B (en) * | 2013-07-12 | 2016-10-26 | Canon Kk | Methods for providing media data, method for receiving media data and corresponding devices |
JP6698553B2 (ja) * | 2014-02-13 | 2020-05-27 | コニンクリーケ・ケイピーエヌ・ナムローゼ・フェンノートシャップ | 1つの要求メッセージに基づいたネットワーク・ノードへの多数のチャンクの要求 |
GB2534849A (en) * | 2015-01-28 | 2016-08-10 | Canon Kk | Client-driven push of resources by a server device |
-
2015
- 2015-01-28 GB GB1501437.6A patent/GB2534849A/en not_active Withdrawn
- 2015-05-27 GB GB1509094.7A patent/GB2534617A/en not_active Withdrawn
-
2016
- 2016-01-15 US US15/543,534 patent/US10348846B2/en active Active
- 2016-01-15 KR KR1020177023038A patent/KR102007105B1/ko active IP Right Grant
- 2016-01-15 JP JP2017537233A patent/JP6686029B2/ja active Active
- 2016-01-15 CN CN201680007911.4A patent/CN107211022B/zh active Active
- 2016-01-15 EP EP16700629.5A patent/EP3251322B1/en active Active
- 2016-01-15 WO PCT/EP2016/050713 patent/WO2016120089A1/en active Application Filing
- 2016-02-09 GB GB1602333.5A patent/GB2538832B/en active Active
- 2016-09-28 US US15/279,231 patent/US20170230442A1/en not_active Abandoned
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20130246583A1 (en) * | 2012-03-14 | 2013-09-19 | Canon Kabushiki Kaisha | Method, system and server device for transmitting a digital resource in a client-server communication system |
KR20140055340A (ko) * | 2012-10-31 | 2014-05-09 | 삼성전자주식회사 | 적응형 스트리밍을 이용한 미디어 세그먼트 송수신 방법 및 장치 |
WO2015004276A2 (en) * | 2013-07-12 | 2015-01-15 | Canon Kabushiki Kaisha | Adaptive data streaming method with push messages control |
Also Published As
Publication number | Publication date |
---|---|
GB201602333D0 (en) | 2016-03-23 |
WO2016120089A1 (en) | 2016-08-04 |
US20180013845A1 (en) | 2018-01-11 |
JP6686029B2 (ja) | 2020-04-22 |
GB201509094D0 (en) | 2015-07-08 |
US10348846B2 (en) | 2019-07-09 |
GB201501437D0 (en) | 2015-03-11 |
GB2534849A (en) | 2016-08-10 |
GB2534617A (en) | 2016-08-03 |
EP3251322B1 (en) | 2021-11-24 |
CN107211022A (zh) | 2017-09-26 |
KR20170106426A (ko) | 2017-09-20 |
EP3251322A1 (en) | 2017-12-06 |
US20170230442A1 (en) | 2017-08-10 |
CN107211022B (zh) | 2020-10-27 |
KR102007105B1 (ko) | 2019-08-02 |
GB2538832A (en) | 2016-11-30 |
GB2538832B (en) | 2019-10-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6686029B2 (ja) | サーバデバイスによるリソースの改善されたクライアント主導型プッシュ | |
US11375031B2 (en) | Adaptive data streaming method with push messages control | |
JP5658820B2 (ja) | Httpストリーミングのためのメディアプレゼンテーション記述デルタファイル | |
US20160241639A1 (en) | Proxy server with byte-based include interpreter | |
JP2016531466A5 (ja) | ||
GB2534057A (en) | Methods for providing media data, method for receiving media data and corresponding devices | |
GB2517060A (en) | Adaptive data streaming method with push messages control | |
GB2575189A (en) | Adaptive client-driven push of resources by a server device | |
GB2543279A (en) | Methods, devices and computer programs for optimizing use of bandwidth when pushing data in a network environment comprising cache servers | |
GB2551674A (en) | Adaptive data streaming method with push messages control |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20190108 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20190108 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20191030 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20191112 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20200110 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20200303 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20200401 |
|
R151 | Written notification of patent or utility model registration |
Ref document number: 6686029 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R151 |