JP3766197B2 - ソフトウエア流通方法およびサーバ装置およびクライアント装置 - Google Patents
ソフトウエア流通方法およびサーバ装置およびクライアント装置 Download PDFInfo
- Publication number
- JP3766197B2 JP3766197B2 JP00947998A JP947998A JP3766197B2 JP 3766197 B2 JP3766197 B2 JP 3766197B2 JP 00947998 A JP00947998 A JP 00947998A JP 947998 A JP947998 A JP 947998A JP 3766197 B2 JP3766197 B2 JP 3766197B2
- Authority
- JP
- Japan
- Prior art keywords
- software
- file
- client terminal
- download
- function unit
- 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.)
- Expired - Fee Related
Links
Images
Description
【発明の属する技術分野】
本発明は、ソフトウェア流通システムに関する。
【0002】
【従来の技術】
計算機および計算機ネットワークが普及し、ソフトウェアの流通は現金などを用いた従来の取引形態によらずとも、全て電子的に行うことができるようになった。
【0003】
今日では、インターネットの急速な普及に伴って、プログラムなどの情報を電子的に配布し課金するシステムが広く行われている。
インターネット等のネットワークを介してのソフトウェアの流通に必要とされる主な要求課題としては、(1)ソフトウェアを入手しようとする人が誰であるかを特定し安全に課金を行うこと(高いセキュリティ性)、(2)ソフトウエアは比較的容易にコピー(複写)を作成することのできるため、その対応策であるソフトウエアの著作権の保護(違法コピーの防止)、(3)ウイルスを含んだソフトウエアの蔓延への取り組み等がある。
【0004】
従来、計算機ネットワーク上での課金のメカニズムは、暗号技術に基いた認証技術が用いられてきた。例えば、計算機ネットワークを使ってクレジットカード番号を伝える場合、通信回線を盗聴することによって他人がクレジットカード番号を盗めるのでは困るから、クレジットカード番号を暗号化して転送するようになっていた。
【0005】
また、違法コピー防止の方法も考えられてきた。最も良く使われる方法は、ソフトウェアに何らかの暗号化を施し、データを復号する鍵(暗号鍵やパスワードなど)を持っている人だけが内容を知ることができる方法である。しかし、この方法によっても、パスワード自体を違法にコピーすることによって、ソフトウェアの違法コピーが可能となってしまう。
【0006】
また、ネットワークを介してプログラム等の情報交換を行うわけであるからウイルスを含んだソフトウエアの蔓延への取り組みは不可欠である。
さらに、ネットワークを介して大容量の情報を送信するわけであるから回線費用等も考慮して通信資源の有効利用を考慮する必要もある。
【0007】
ユーザの利便性を考慮すれば、ネットワークを介してプログラム等をダウンロードして、それを自端末にインストールする等の操作はパソコンの扱いに不慣れな者にとって酷である。このようなシステムを広く普及させるためには、パソコン、通信等の知識がなくとも簡単に操作できるような仕様であることが要求されるであろう。
【0008】
また ネットワークを介しての電子的情報の販売においては、購入した製品に不満があった場合に返品が不可能であるため、その対策も必要である。
また、ネットワークを介してソフトウエアのバージョンアップへの対応が容易に行えるようであれば、ユーザの販売者への信頼が高まり購入意欲を高め、システムの普及も図れるであろう。
【0009】
【発明が解決しようとする課題】
このように、従来のソフトウエア流通システムは、ユーザの利便性、ネットワークのレスポンス、ソフトウエアの違法コピー等に対しては充分に配慮されていないという問題点があった。
【0010】
本発明は、ネットワークを介して提供されるソフトウエアの購入要求指示、インストール、頻繁に起こるソフトウエアのバージョンアップ等のさまざまな手続きを簡潔に設定し、ユーザが安全かつ簡便な方法でソフトウエアの利用および決済が行われることを可能とするソフトウエア流通システムを提供することを目的とする。
【0011】
【課題を解決するための手段】
(1)本発明のソフトウエア流通方法は、ソフトウエア提供者が指定されたソフトウエアをネットワークを介して利用者に提供するソフトウエア流通方法において、利用者側の装置から、指定するソフトウエアの提供を要求するためのソフトウェア要求をソフトウエア提供者へ送信し、ソフトウェア提供者側の装置から、前記ソフトウェア要求により指定されたソフトウエアに対応した複数のファイルのインストール情報をまとめて前記利用者へ送信し、利用者側の装置が、前記複数のインストール情報を参照して要求すべきファイルを選択し、この選択したファイルを要求するためのダウンロード要求を前記ソフトウェア提供者へ送信し、ソフトウェア提供者側の装置から、前記ダウンロード要求に示されるファイルを含むダウンロード情報を送信し、利用者側の装置が、前記ダウンロード情報に従って前記ファイルのインストールを行うことを特徴とする。
【0012】
本発明によれば、ソフトウェア提供者(サーバ)から複数のファイルのインストール情報(例えばインストールリスト)が送られるため、この中から利用者側の装置(クライアント端末)が自動的に必要なものを選択し、必要なものだけをサーバに要求することが可能となる。そして、サーバから送られるダウンロード情報(要求したファイルの他に例えばインストールの仕方などが含まれていてもよい)に従って必要なファイルをインストールする。
【0013】
インストール情報には、例えばファイル名が含まれ、既に利用者側に存在するファイル以外のものを自動的に要求することができる。したがって、同じファイルを二度ダウンロードしてしまい、結果的に二重に課金されてしまうようなことを、ユーザの手を煩わせることなく、防ぐことができる。
【0014】
また、インストール情報には、例えばファイルのバージョン情報が含まれていてもよく、既に利用者側に存在するバージョンより新しいバージョンのものを自動的に要求することができる。
【0015】
また、インストール情報には、例えばファイルのサイズの情報が含まれていてもよく、利用者側の装置の記憶容量にそのファイルが格納できるだけの余裕があるファイルに限って要求するようなこともできる。
【0016】
(2)ソフトウェア提供者側の装置と利用者側の装置は、ソフトウエア提供者と利用者とで共有された共有鍵を記憶し、利用者側の装置は、前記ダウンロード要求をこの共有鍵に関連付けて送信し、ソフトウェア提供者側の装置は、前記ダウンロード要求の正当性を自装置の記憶する共有鍵を用いて検査した後に、前記ダウンロード情報を送信するようにしてもよい。
【0017】
こうすると、サーバは、ダウンロード要求の正当性(例えばソフトウェア料金の決済ができるユーザ本人からの要求であること)が確認された場合にのみダウンロードを許すようなことができる。
【0018】
(3)ソフトウェア提供者側の装置と利用者側の装置は、ソフトウエア提供者と利用者とで共有された共有鍵を記憶し、ソフトウェア提供者側の装置は、前記ダウンロード情報をこの共有鍵に関連付けて送信し、利用者側の装置は、前記ダウンロード情報の正当性を自装置の記憶する共有鍵を用いて検査した後に、前記ファイルのインストールを行うようにしてもよい。
【0019】
こうすると、クライアント端末は、正当なサーバからのダウンロード情報である(例えばウィルスが混入していないと判断できる)と確認された場合にのみインストールを実行するようなことができる。
【0020】
(4)利用者側の装置は、ソフトウエア要求を送信する際に、当該ソフトウエアのインストールに関連する利用者側の環境判定結果(例えばクライアント端末のOSが何であるかなど)を併せて送信し、ソフトウェア提供者側の装置は、この環境判定結果に応じて内容の異なる、複数のインストール情報を送信するようにしてもよい。
【0021】
(5)ソフトウエア提供者から提供されるソフトウエアを、単独で動作可能な能動機能部と、この能動機能部に組み込まれて動作可能となる受動機能部から構成し、ソフトウェア提供者側の装置は、利用者からのダウンロード要求に示されるファイルに前記受動機能部に対応するファイルが含まれる場合に、該受動機能部に対応するファイルについて課金を行い、前記能動機能部に対応するファイルについては無料で提供するようにすることも有効である。
【0022】
これによれば、例えばまずソフトウェアの試供版を能動機能部としてユーザに無料で提供し、ユーザがそれを気に入れば正規の製品としての機能を実現するための受動機能部を有料で提供することができる。
【0023】
(6)本発明において課金を行うために、ソフトウェア提供者側の装置と利用者側の装置は、ソフトウエア提供者と利用者とで共有された共有鍵を記憶し、ソフトウェア提供者側の装置は、送信しようとするダウンロード情報に有料部分が含まれる場合には、この共有鍵を用いて該ダウンロード情報の有料部分もしくは全部を暗号化して送信し、利用者側の装置は、前記ダウンロード情報を自装置の記憶する共有鍵を用いて復号化してインストールを行うようにしてもよい。このとき、ソフトウェア提供者側の装置と利用者側の装置が記憶する共有鍵は、利用者のソフトウエア料金の決済に関わる識別情報との対応付けが保証された共有鍵であることが好ましい。
【0024】
このようにすれば、提供するソフトウェアのうち少なくとも有料部分のファイルは、クライアント端末にダウンロードされると暗号化されたまま格納され、サーバと共有された共有鍵を持っていない限り復号化できない。
【0025】
(7)そして、この共有鍵をあらかじめ料金決済に関わる識別情報との対応付けが保証されたものとしておけば、ソフトウェア購入の都度セキュリティ性の高いクレジットカード番号等をクライアントからサーバへ送信する必要がなくなり、安全性が確保される。
【0026】
なお、上記の共有鍵を、クライアント端末毎に一義的に定められるコード情報に基づいて暗号化して、クライアント端末に記憶しておくようにすれば、単純にファイルや共有鍵を違法コピーしてもコード情報を得られなければそのソフトウェアは実行不可能であるため、ソフトウェアの違法コピーにも対処できる。
【0027】
(8)ソフトウェア提供者側の装置は、1つのファイルを分割して複数のダウンロード情報として提供する場合には、このファイルのインストール情報に分割に関する情報を含めて送信することもできる。
【0028】
こうすれば、例えば大きなファイルの途中までダウンロードしたところで回線が切れたりした場合に、クライアント端末には分割された複数のデータのうち一部が存在することになり、分割された複数のデータのうち存在しない部分だけをダウンロード要求にてサーバに要求することも可能になる。
【0029】
(9)利用者側の装置に設けられた、前記ダウンロード要求を送信するためのプログラム、および、前記ダウンロード情報に従ってインストールを行うためのプログラムのうちの少なくとも一方は、それ自体のバージョン情報を持ち、ソフトウェア提供者側の装置は、複数のインストール情報を送信する際に、利用者側のこれらのプログラムに推奨されるバージョン情報を併せて送信し、利用者側の装置は、前記ダウンロード要求の送信もしくは前記インストールに先立ち、利用者側のこれらのプログラム自身のバージョンアップに必要な情報をソフトウエア提供者に要求するようにしてもよい。
【0030】
(10)本発明は、指定されたソフトウエアをネットワークを介してクライアント端末に提供するサーバ装置(上記ソフトウエア提供者側の装置)であって、クライアント端末から受信したソフトウェア要求により指定されたソフトウエアに対応した複数のファイルのインストール情報を記述したインストールリストを、該クライアント端末がこれら複数のファイルのうち必要なものを選択できるように、該クライアント端末へ送信するインストールリスト送信手段と、クライアント端末が選択した必要なファイルを示すダウンロード要求を受信し、このダウンロード要求に示されるファイルを含むダウンロード情報を、該クライアント端末がこのダウンロード情報に従って該ファイルをインストールできるように、該クライアント端末へ送信するダウンロード情報送信手段とを具備したことを特徴とする。
【0031】
(11)本発明は、ネットワークを介してサーバから提供されたソフトウエアを利用するクライアント装置(上記利用者側の装置)であって、指定するソフトウエアの提供を要求するためのソフトウェア要求を、サーバへ送信するソフトウェア要求送信手段と、このソフトウェア要求の指定するソフトウエアに対応した複数のファイルのインストール情報が記述されたインストールリストをサーバから受信し、この受信したインストールリストを参照して要求すべきファイルを選択し、この選択したファイルを要求するためのダウンロード要求を該サーバへ送信するダウンロード要求送信手段と、このダウンロード要求の示すファイルを含むダウンロード情報をサーバから受信し、この受信したダウンロード情報に従って前記ファイルのインストールを行うダウンロード情報受信手段とを具備したことを特徴とする。
【0032】
【発明の実施の形態】
以下、本発明の一実施形態について図面を参照して説明する。
図1は、本発明に係るソフトウエア流通方法を用いたソフトウエア流通システムの全体の構成を示したもので、主に、ソフトウエアを販売するサーバ1とソフトウエアを購入するクライアント端末2とを、例えばインターネット等のネットワークを介して接続して構成される。
【0033】
図1に示すソフトウエア流通システムは、ソフトウエアを安全かつ簡便に電子的にユーザに配布して、その配布したソフトウエアへの課金を行うシステムである。すなわち、ユーザは、自端末(クライアント端末)2の例えばブラウザでネットワークを介してサーバ1にアクセスし、所望のソフトウエアの購入要求を送信し、サーバ1では、その要求されたソフトウエアをクライアント端末2にダウンロードすると同時に課金を行うもので、ユーザ側では、自端末のマウスを操作するだけでソフトウエアの購入、そのインストールが可能となる。
【0034】
さて、図1のソフトウエア流通システムの利用を希望するユーザは、まず、入会ソフトウエアを自端末(例えば、パソコン)2で起動する。
入会ソフトウエア(以下、簡単に入会ソフトと呼ぶこともある)は、主に、クライアント端末2にて所定のシステム設定およびサーバ1へのユーザ登録を行うものである。本実施例においてはサーバーは1つとして書かれているため、そのサーバーにおけるソフトウエア提供者のサイトへの「入会」あるいは「ユーザ登録」として記述しているが、一般には複数のサーバーにアクセスすることができる。その場合、利用する各サーバーごとに共有鍵を管理することになる。
【0035】
入会ソフトは、サーバ1の入会ソフトウエア格納部22に予め格納されており、クライアント端末2からの要求に応じて入会ソフトダウンロード機能部11により、ネットワークを介してクライアント端末2にダウンロードされると同時にクライアント端末2にインストールされる。
【0036】
入会ソフトウエア機能部31は、クライアント端末2にインストールされることによりクライアント端末2にて実行可能な状態に設定されて入会ソフトウエアの機能を実行する機能部である。
【0037】
なお、入会ソフトは、CD−ROM等の記録媒体にて予めユーザに配布されているものであってもよい。
入会ソフトウエア機能部31が起動されると、まず、所定のシステム設定を行う。
【0038】
次に、サーバ1へのユーザ登録を行う。まず、サーバ1との間でセキュリティ性の高い情報(例えば、クレジットカード番号、認証情報等)を送受信する際に、これらを暗号化・復号化するための鍵データ(セッション鍵、共有鍵等)を生成し、この生成された鍵データに対し所定の暗号化処理を施し、共有鍵は情報ファイル34に格納する。
【0039】
さらに、クライアント端末2に表示される手順に従って、ユーザは、自分の氏名、住所、クレジットカード番号、クレジットカードの有効期限、年齢、生年月日等の個人情報等を入力すると、それらは予めサーバ1との間で定められた暗号鍵を用いて暗号化された後、ネットワークを介してサーバ1に送信される。
【0040】
サーバ1の入会ソフト受け付け機能部12にて、暗号化された個人情報および鍵データを受信すると、所定の暗号鍵を用いて復号化を行い、信用照会部13を介してカード会社との間で与信照会を行い、与信できた場合はデータベース登録部14を介しての個人情報ファイル24への個人情報および鍵データの書込み登録処理を終了する。
【0041】
ユーザ登録が正常に終了して、その旨の通知を受けたクライアント端末2では、ユーザがソフトウエア購入の際、起動すべきプログラム、すなわち、ダウンロードプログラム35をインストールする。すなわち、ダウンロードプログラム35は、入会ソフトウエアとともにダウンロードされており、それが入会ソフトウエア機能部31から吐き出されて、クライアント端末2にインストールされる。
【0042】
ダウンロードプログラム機能部32は、クライアント端末2にインストールされ、メモリ上にローディングされ起動されることによりクライアント端末2にて実行可能な状態に設定されてダウンロードプログラムの機能を実行する機能部である。実行可能な状態においては、ダウンロード要求送信部321およびダウンロード情報受信部322が機能できる。
【0043】
入会ソフトウエア機能部31がダウンロードプログラムをインストールする際には、ダウンロードプログラムを自動的に起動するための設定を行う。この設定は、例えば、クライアント端末2で受信したデータのヘッダ部分から、予め定められた識別情報(ここでは、Content−type:Application/ABC)を検知したときにダウンロードプログラムを起動するよう所定のファイルに登録することにより設定がなされる。
【0044】
以上で入会ソフトウエアに具備された機能を用いたユーザ登録は終了する。
次に、ユーザがサーバ1から所望のソフトウエアをダウンロードする際のソフトウエア流通システムの各機能部について説明する。
【0045】
まず、ユーザは、クライアント端末2の例えばブラウザを起動してマウスを操作することによりサーバ1にアクセスして、所望のソフトウエアをリクエストする。具体的には、ソフトウエア要求送信部39がインストールリスト送信部15に対しソフトウエアの提供の要求を送る。その際、自パソコンに関する環境設定の情報を併せて送信しても良い。
【0046】
この送信要求を受けたサーバ1のインストールリスト送信部15では、ユーザにより指定されたソフトウエアに対応するインストールリスト(どのファイルをどのようにインストールするかを記述したリスト)をインストールリスト格納部25から読み出してクライアント端末2に送信する。その際、前記環境設定情報を得た場合には、それに応じてインストールリストを変更して送信する。
【0047】
クライアント端末2のダウンロードプログラム機能部は、インストールリストを受信するとダウンロード要求送信部321がそれを処理し、インストールリストに基づき選択された要求(ダウンロード要求)をサーバ1に送信する。インストールリストには、ユーザが要求したソフトウエアに関して、必要なファイル、各々のバージョン、インストール先、サイズ、レジストリへの登録情報、インストール時に実行すべきプログラムなどが書かれていて、それを基に判断する。例えば、既に最新バージョンのファイルを持っていれば、当該ファイルのダウンロード要求を省略する。
【0048】
ファイルは持っているがバージョンが古い時にはダウンロード要求が必要であるが、その際、自分の持っているファイルのバージョン情報を送るのが良い。なぜなら、その情報をサーバ側が利用し、最新ファイルを送信するかわりにサイズの小さいパッチ情報を送信することを選択することができるからである。
【0049】
サーバ1のダウンロード情報送信部16では、クライアント端末からの要求に応じて、コアソフト格納部26、受動機能ファイル格納部27、ライブラリ格納部28のいずれかからファイルを読み出し、個人情報ファイル格納部24に格納された個人情報を参照して、予め登録されたユーザであることが確認できたら、読み出したファイルをクライアント端末2に送信する。その際、データの圧縮、必要ならばデータの暗号化等を行う。また、クライアント端末2から要求されたファイルが課金対象のものであるときは、個人情報ファイル格納部24に格納された個人情報を参照して、所定の課金処理を行う。
【0050】
予め登録されたユーザであることを確認する方法として最も簡単な方法は、予めソフウエア提供者と利用者とで共有された共有鍵を保存しておき、その情報を利用するものであり、これについては後に詳述する。この場合、例えば送信される要求をその共有鍵に関連付けた何らかのチェック、例えば一方向関数を使ったハッシュ値を付けるなどすればよい。これら認証方法については、知られている一般的な方法を用いれば良く、また認証に使う鍵は必ずしも共有鍵である必要も無い。
【0051】
クライアント端末2にて実行中のダウンロードプログラムは、ダウンロード情報受信部322がサーバ1からダウンロード情報を受信し、エラーがなければ、インストールする。この際もやはり前述した通り共有鍵を用いるなどして認証を行い、例えば偽のサーバからウイルスを含んだソフトウエアがダウンロードされるような被害を防ぐことができる。
【0052】
コアソフト機能部33は、サーバ1からダウンロードされたソフトウエアがクライアント端末2にインストールされることによりクライアント端末2にて実行可能な状態に設定されて所定の情報処理の機能を実現する機能部で、前もってインストールされたコアソフト36が、その起動時に受動機能ファイル37を組み込むことにより正規の機能を呈するようになっている。
【0053】
なお、ダウンロードするプログラムはコアソフト、受動機能部以外の汎用のプログラムであってもよく、それは、ライブラリ38としてサーバ1からダウンロードされる。
【0054】
インストール済み情報格納部101には、サーバ1からクライアント端末2にダウンロードされて、インストールされたコアソフト36を構成するファイルおよび受動機能部ファイル37に関する情報(ファイル名、バージョン情報、サイズ等)が登録されるようになっている。
【0055】
なお、商品としてのソフトウエアは、後述するように、能動機能部ファイルと受動機能部ファイルから構成され、受動機能部ファイルは暗号化されてサーバ1からダウンロードされ、暗号化されたままクライアント端末2に格納される。
【0056】
コアソフト機能部33が起動されると、インストール済み情報格納部101を検索して、受動機能部ファイルがインストールされているか否かをチェックする。関連する受動機能部ファイルがインストールされているときは、その暗号化された受動機能部ファイルを復号化して、これを組み込むことにより正規の動作を実行するようになっている。
【0057】
次に、図2を参照して、図1のソフトウエア流通システムで用いられる鍵データの流れの一例を説明する。また、必要に応じて、ユーザ登録時のデータの流れの一例を示した図3も参照する。
【0058】
入会ソフトウエア機能部31に具備される乱数生成部51は、サーバ1とクライアント端末2にて共有される共有鍵61を乱数で生成する。
この共有鍵61は、ソフトウエアの違法コピー防止等に用いられるもので、各クライアント端末2に固有のプロダクトIDを用いて、例えば、DES(Data Encryption Standard)等の秘密鍵暗号化方式で暗号化されて情報ファイル格納部34に鍵ファイル52として格納される。
【0059】
また、クライアント端末2にてパスワード62の設定が可能であるならば、そのパスワード62を共有鍵61を用いてハッシュし、その出力を購入鍵63とする。購入鍵63は、商品(ソフトウエア)購入の際のユーザ認証に用いられるものである。なお、パスワードがないときは、共有鍵61をそのまま購入鍵63としてもよい。
【0060】
乱数生成部51は、ユーザ登録時にクライアント端末2でセッション鍵64および共有鍵61を生成する。
セッション鍵64は、ユーザ登録時に個人情報および鍵データ(共有鍵61、購入鍵64)を、例えばDES等の秘密鍵暗号方式を用いて暗号化する際に用いられる(図3参照)。このとき、セッション鍵64も、入会ソフトウエアに含まれるソフトウエア販売者との間で予め定められた公開鍵65を用いてRSA(Rivest−Shamir−Adleman)等の公開鍵暗号方式にて暗号化されてサーバ1に送信されるようになっている。
【0061】
サーバ1でクライアント端末2から送信された、暗号化された個人情報および鍵データ(共有鍵61、購入鍵63)、セッション鍵を受信すると、まず、暗号化されたセッション鍵64をRSAにて復号化し、この復号化されたセッション鍵64を用いて暗号化された個人情報および鍵データをDESにて復号化する。その後セッション鍵64は廃棄される。
【0062】
サーバ1では、復号化された個人情報、鍵データを個人情報ファイル24に保存するとともに、個人情報に基づく信用照会を行うようになっている(図3参照)。
【0063】
なお、信用照会の際には、必要に応じて別経路でクライアント端末2に対し再確認を行うようにしてもよい。
図4は、個人情報ファイル24に格納される個人情報の記憶例を示したものである。図4に示すように、各ユーザのクライアント端末2から送られてきた鍵データ(共有鍵、購入鍵)とクレジットカード番号、氏名、住所等の個人情報が対応付けされて、ユーザの登録順に記憶されるようになっている。
【0064】
個人情報ファイル24に格納された情報は、ここに登録された各ユーザが商品としてのソフトウエアを購入する際のユーザ認証、クレジットカード会社への信用照会とソフトウエアに対する課金処理のために参照される。
【0065】
図5は、図1のソフトウエア流通システムで用いられる鍵データの流れと、ユーザがサーバ1から商品ソフトウエアをダウンロードする際のデータの流れを説明するためのものである。
【0066】
サーバ1からクライアント端末2へダウンロードされる商品ソフトウエアのうち、コアソフトは、暗号化されておらず、前述したようにクライアント端末にダウンロードと同時にインストールされている。
【0067】
一方、受動機能部ファイルをダウンロードする際には、サーバ1では、まず、そのソフトウエアの送信要求を行ったユーザの所定の認証処理および課金処理を行った後、そのユーザとの共有鍵61を用いて指定された受動機能部ファイルを暗号化し、クライアント端末2にダウンロードする。
【0068】
クライアント端末2では、暗号化された受動機能部ファイルを受信すると、それを所定の領域(暗号化ソフトウエア格納部41(図7参照))に格納する。
コアソフトが起動されると、コアソフトは、まず、鍵ファイル52に格納されている暗号化された共有鍵61をプロダクトID67を用いて復号し、復号化された共有鍵61を用いて受動機能部ファイルを復号し、これを組み込む。
【0069】
さて、ここで、本実施形態に係るソフトウエア流通システムにてダウンロードされる商品ソフトウエアの特徴について説明する。
図6は、商品ソフトウエアの構成を模式的に示したものである。図6に示すように、商品ソフトウエアは大きく分けてコアソフト(能動機能部ファイル)36と受動機能部ファイル37から構成される。
【0070】
コアソフト36は、単独で動作可能な無料で提供される、機能・期間限定版のいわゆる試供用のソフトである。
受動機能部ファイル37は、ユーザの要求に応じて提供されるもので、すでに配布済みのコアソフト36の期間限定解除、機能追加(バージョンアップを含む)のためのものである。これ単独では動作せず、コアソフトに組み込まれて動作可能となる。
【0071】
受動機能部ファイル37は原則有料で、暗号化されてクライアント端末に配布され、クライアント端末では、暗号化されたまま格納されるデータファイルあるいはプログラムファイルである。
【0072】
また、コアソフト36は通常複数のファイルから構成され、サイズが大きく、受動機能部は、比較的サイズが小さいものであると考えてよい。
図7は、コアソフトの機能を説明するための模式図である。
【0073】
コアソフト36は、クライアント端末2にてインストールされても、そのままでは完全には動作しない。これに暗号化された受動機能部ファイル37を復号して追加することによって機能を追加することができる。
【0074】
つまり、受動機能部ファイル37を復号する権限のない者が実行しても、全ての機能が動作するわけではない。
コアソフト36が起動されるとまず、インストール済み情報格納部101を検索して、そのコアソフトに関連する受動機能部ファイルがインストールされているか否かをチェックする。関連する受動機能部ファイルがインストールされているときは、その暗号化された受動機能部ファイルを暗号化ソフトウエア格納部41から読み出し、ソフトウエア復号部36aにより共有鍵61で復号し、結果として得られた復号受動機能ファイル37を復号ソフトローディング部36bに格納する。このとき、もし、共有鍵61を得られない場合は、復号ソフトローディング部36bには正しいデータが格納されない。
【0075】
コアソフト36は、ここに配置された受動機能部ファイル37が正しいデータであることを確認する。確認の方法は、例えばここに格納された受動機能部ファイル37が、コアソフトによってあらかじめ予定されたデータに等しい(正しく復号されている)ことをチェックするという方法と、ここに格納された受動機能部ファイル37そのものをプログラムとして実行するという方法が代表的である。
【0076】
このように、商品ソフトウエアをコアソフトと受動機能部ファイルに分けて配布することにより次のような利点がある。
まず、商品ソフトウエアの有料部分だけを受動機能部ファイルとして販売することができる。例えば、コアソフトは、印刷機能と通信機能が制限されたワードプロセッサであり、印刷機能と通信機能はそれぞれ有料のソフトウェアとして販売される。この方法を用いれば、例えばソフトウェアを購入の都度、サーバ1から送信するのではなく、CD−ROMや電子掲示板のような誰でも入手し参照することが可能な媒体でコアソフトを無料配布しておき、好評ならば有料部分を購入してもらうということができる。
【0077】
従来の通信販売の場合、品物が確かめられない制約から、クーリング・オフという制度があるが、形を持たないソフトウェアの場合、一旦購入した物を返品することが不可能である。したがって、コアソフトをまず試供版として顧客に利用してもらうことにより、クーリング・オフのできないことによる顧客の不利益を防ぐことができる。実際に試用した上で、気にいった場合だけ有料の追加機能(受動機能部ファイル)を購入することができる。また、この追加機能は1つだけでなく複数設定することもできるので、「有料」と「無料」の2種類だけでなく、必要な部分だけを適正な価格で買うことができる(不要機能まで抱き合わせ販売されてしまうという不公正流通が防げる)。
【0078】
次に、暗号化や復号に必要なデータ量が削減できる。一般に、暗号化や復号の計算はデータ量に比例した時間がかかるため、非常に大きなサイズのソフトウェアをその都度暗号化して販売すると、購入(ダウンロード)に時間がかかったり、実行(復号)の際に時間がかかったりするので、暗号化の必要な部分はなるべく小さくする必要がある。
【0079】
また、データ量が削減できるということは、通信回線が細くても良いということを意味する。つまり、有料の受動機能部を買うための店舗と顧客との通信回線が遅い場合、一般にはダウンロードに時間を要してしまうが、コアソフトだけはCD−ROMで配布しておいたり、他の高速ネットワークを通じて入手したりしておけば、あとはサイズの小さい暗号化された受動機能部ファイルだけを入手すれば良く、購入に時間がかからなくなる。
【0080】
さらに、違法コピーへの対策としても用いることができる。すなわち、クライアント端末2では、受動機能部ファイルを復号化する際に用いられる共有鍵61は、プロダクトID67によって暗号化保存するという形態を取り、復号された受動機能部ファイルは、コアソフト36が実行される際のメモリ上に存在するだけになるので、単純に、鍵ファイル52、コアソフト36、暗号化された受動機能ファイル37の全てをコピーしても、プロダクトIDを入手しない限り、その違法コピーされたソフトウエアを実行することは不可能となる。また、ソフトウェアの動作メカニズムを解析して違法コピーを作り出すことは難しく、手間をかけてまで違法コピーする価値はなくなる。
【0081】
例えば、販売するソフトウェアが書籍である場合、最終的にはメモリ上で計算機等で読める形式の文字列データに変換されてしまうため、そのデータをメモリ上から盗み読むことは比較的簡単にできてしまう。しかし、コアソフト36は「書籍を読むソフト」としておき、有料の追加機能である個々のソフト(書籍)を受動機能部ファイルとして読み込んで、その内容を画面に表示するという仕組みにしておくことができる。この場合、コアソフト36が必要なデータ(暗号化されたデータ)を随時復号して表示する仕組みにすれば、書籍のデータ(文字)全部をまとめて読み出すというのは非常に困難になる。
【0082】
また、復号された受動機能部ファイルは、コアソフト36が実行される際のメモリ上に存在するだけになるので、コアソフト36が暗号化ソフトウェアを利用する方法手順を煩雑にすることによって、販売されたソフトウェアの暗号を解く手間が非常に大きくなり、安全性が高まる。
【0083】
一般に、ネットワークで販売されるソフトウェアは、バージョンアップが比較的頻繁であったり、一時的にしか価値のない情報(例えば天気予報)のようなものである場合が多く、ソフトウェアの違法コピー作成に知恵を絞るよりも、正しくお金を払ってソフトウェアを購入した方がはるかにコストが安くなるため、違法行為を行う意味がなくなり、ソフトウェアの公正な流通が促進される。
【0084】
次に、図8を参照して、ユーザがサーバ1から所望のソフトウエアをダウンロードする際のより詳細な処理手順、すなわち、ダウンロードプログラム機能部32の処理手順について説明する。
【0085】
ユーザは、クライアント端末2の例えばブラウザを起動してマウスを操作することによりサーバ1にアクセスして、サーバ1に対し所望のソフトウエアをリクエストする。このとき、クライアント端末2にて予め実行された環境自動判定結果の内容を記述したファイルもサーバ1に送信される(ステップS1)。
【0086】
この送信要求を受けたサーバ1のインストールリスト送信部15では、ユーザにより指定されたソフトウエアに対応するインストールリスト(どのファイルをどのようにインストールするかを記述したリスト)をインストールリスト格納部25から読み出してクライアント端末2に送信する(ステップS2)。
【0087】
図9は、サーバ1から送信されるデータ構成例を示したもので、主に、ヘッダ部とデータ部から構成される。
ヘッダ部には、識別情報71(Content−type:Application/ABC)を含み、クライアント端末2で、この識別情報71を検知するとダウンロードプログラムを自動的に起動するようになっている(この設定は、入会ソフトウエア機能部31がダウンロードプログラムをインストールする際になされている)。
【0088】
データ部には、ここでは例えばインストールリストが挿入されている。図9に示すように、インストールリストには、ダウンロードプログラムの最新バージョン(Download−version)、サーバ1のアドレス情報(例えば、URL)、複数の「命令」から構成される。
【0089】
この「命令」は、ユーザがマウスをクリックした際に、何の機能を選択したのかをダウンロードプログラムに知らせるためのもので、例えば、図10に示すように、どのファイルをどのようにインストールするかを記述した(コアソフトあるいは受動機能の)インストール命令がある。図11に図10に示したインストール命令の具体例を示す。
【0090】
図11に示したインストール命令の意味は、「ファイル名:MTのversion1のdic2機能のRevision3が必要で、これを3個に分割して送信する。1個目と2個目の送信量は512Kバイトで3個目の送信量は139Kバイトである。3つのファイルを連結した後に圧縮の解凍をすると7439Kバイトのファイルになる。」である。このように、図10に示したインストール命令によりソフトウエアの分割ダウンロードが可能となる。なお、図10の分割指定のフィールドにおいて、n=1とすれば一括ダウンロードの指定も可能である。
【0091】
分割ダウンロードが指定された場合には、各分割データごとに繰り返しサーバにダウンロードを要求する。その際、何番目のデータを要求するのかサーバに対し指定する。例えば、ファイル名に一定の規則の拡張子(例えば、_PART1、_PART2)を付けることによって表現できる。
【0092】
「命令」には、図10に示したようなインストール命令の他に、例えば、「ユーザの購入済みソフトのバージョンアップ情報の表示」命令もある。この命令は、この命令文内で指定されたファイルがインストールされていないときは、以下のインストール命令の実行をエラーとするもので、これは、受動機能部を販売する際には、必ずそれに対応するコアソフトがインストールされて正常に動作していることを確認するためのものである。
【0093】
また、この「命令」は、「このプログラムを実行した結果がこの値ならばこのインストールを行う」といった条件式であっても良い。その際に動かすプログラム自体がインストール命令に書かれていれば、「まずこのプログラムをダウンロードし、それを動かした結果によってこのインストールを行う」という動作が可能なので、こういった複雑なインストール条件が、単純な「命令」の組合わせで実現できる。
【0094】
例えば、「Install checkprogram 100 230」という命令に続き、「IF checkprogram 0 Install DIC MT/1/dic8.3 100400」という命令の書かれているインストールリストを用いれば、「checkprogramという名前のプログラムをまずダウンロードし、しかる後にそのプログラムを実行し、その結果の値が0であったらDICをインストールする」という複雑なインストール指定を行うことも容易にできる。
【0095】
さて、ステップS2で、クライアント端末2がサーバ1からインストールリストを受け取ると、図9のヘッダ部に含まれる識別情報71を検知し、ダウンロードプログラムを起動する。そして、受信したインストールリストに含まれるダウンロードプログラムの最新バージョン(Download−version)をチェックする(ステップS3)。新しくなっていたら、最新のダウンロードプログラムのダウンロードをサーバ1に要求する(ステップS4)。サーバ1は、所定のソフトウエア格納部から最新版のダウンロードプログラムのファイルを読み出して、暗号化せずにクライアント端末2にダウンロードする(ステップS5)。
【0096】
クライアント端末2で、最新版のダウンロードプログラムのファイルを受け取ると、他のファイルのダウンロードとは別に扱う。すなわち、現在実行中のダウンロードプログラムに上書きすることはなく、例えば、現在実行中のダウンロードプログラムが「download1」の名前でインストールされているならば、最新版のダウンロードプログラムを「download2」の名前でインストールし、さらに、ダウンロードプログラムの自動実行するための設定ファイルの書き換えも行う。その後、現在実行中のダウンロードプログラム「download1」で処理中のデータをそのまま最新版のダウンロードプログラム「download2」に渡して、最新版のダウンロードプログラムを起動する。従って、バージョンアップ後は常に「download1」と「download2」の2つのプログラムファイルが存在することになる。
【0097】
このように、最新版のダウンロードプログラムのバージョンアップを他のファイルのダウンロードとは別に扱う理由は、現在実行中のダウンロードプログラムに新しいファイルを上書きしても現在実行中のダウンロードプログラムの実行内容が新しくなるわけではないからである。
【0098】
次に、クライアント端末2では、インストールリストに記述された、先にユーザにより指定されたソフトウエアを構成するファイル(コアソフト、受動機能部ファイル)のバージョン情報とインストール済み情報格納部101に登録されているファイルのバージョン情報とを比較し、バージョンアップされているファイルがあるか否か、あるいは、インストールリストに新たな追加機能ファイル(受動機能部ファイル)が存在するか否か等をチェックして、そのようなファイルが存在する場合には、必要なファイルに関してサーバ1に所定のヘッダ情報を付けたダウンロード要求を出す(ステップS6)。
【0099】
ダウンロード要求には、例えば、現在インストールされているファイルのバージョン等の情報も含まれている。また、ヘッダ情報には、ユーザ登録済みである旨を示す各種情報(例えば、購入鍵等)が含まれている。
【0100】
サーバ1は、クライアント端末2からのダウンロード要求を受け取り、そのヘッダ情報からユーザ登録済みのユーザであることを認識すると、ダウンロード要求の処理を実行し、図12に示すようなフォーマットにて、指定されたファイルのダウンロードを行う(ステップS7)。
【0101】
その際、ダウンロード要求された情報が有料のものである場合には、必要な課金処理を行う。その際、共有鍵はソフトウエア利用者のソフトウエア料金の決済に関わる識別情報との対応付けが入会手続き時に保証されているので、その識別情報を利用して課金を行うのが普通である。さらに、予め暗号化するものと指定された有料の受動機能である場合には共有鍵によってその暗号化も行う。
【0102】
図12において、送信フォーマットのフィールドには送信されるデータの種類が記述される。例えば、「0」はファイル全体を一括して送る、「1」はデータの差分を一括して送る、「2」は分割ダウンロードで全体を送る、「3」は分割ダウンロードでデータの差分を送る、である。
【0103】
データ本体のフィールドに挿入されるファイルは、所定の圧縮プログラムにより圧縮されていてもよい。このとき、その解凍プログラムはダウンロードプログラムに含まれていてもよいし、外部のプログラムを読み込むようにしてもよい。
【0104】
データサイズはデータ本体のサイズ、MASKは、復号時に共有鍵にかけるマスク、check sumは、でデータ本体(暗号化していないもの)に対するチェックサム、ハッシュ値は、データサイズ、データ本体、check sum、MASKの全体にハッシュ関数をかけたものである。ハッシュ値が正しくなければダウンロードプログラムはエラーを検知するようになっている。なお、MASKが「0」のとき、このフォーマットのデータ本体であるファイルは暗号化対象でないことを意味する。
【0105】
このように、ダウンロード情報を共有鍵に関連付けておくことにより、正規のサーバ(すなわち自分の共有鍵を知っているサーバ)からのダウンロード情報であることを確認することができ、ウイルスが入り込むなどの不正なインストールが防ぎやすくなる。
【0106】
サーバ1では、ファイルの送出後、そのファイルが有料である場合は、購入鍵をキーに個人情報ファイル24を参照して、そのユーザのクレジットカード番号を取得し、それを基にクレジットカード会社との間で信用照会および課金処理を行う。
【0107】
また、ダウンロードの際に、暗号化を要する部分は予め登録された共有鍵で暗号化する。
なお、課金されたがダウンロードの途中で失敗(回線が切れた等)した場合は、そのまま無視する。そのユーザが再度購入操作をしたとき課金処理を行うことなくダウンロードやり直すだけである。
【0108】
以上、説明したように、本実施形態に係るソフトウエア流通システムの効果を以下にまとめる。
(1) 自動インストール機能
クライアント端末2における環境自動判定結果をサーバ1に送信し、サーバ1は、それに応じたソフトウエアを配布し、クライアント端末2においてダウンロードプログラムに具備されるインストーラにてダウンロードされたファイルを受け取ると同時にインストールする。これにより、パソコンの知識がなくとも簡単にかつ間違いなくインストールすることが可能となる。
【0109】
また、サーバ1からダウンロードされるファイルを自動インストールする際には、クライアント端末2のダウンロードプログラムは、ユーザ登録時に設定された識別情報を認識して処理を実行することにより、ウイルスの入り込む心配がない。
(2)自動課金機能
ユーザ登録時にクレジットカード番号等をサーバ1に登録することにより、ソフト購入時には、所望するソフトウエアの購入要求のみを送信すれば、後はサーバ1にて、その登録されたクレジットカード番号を用いてオンライン信用照会により、即時課金を行う。従って、ユーザは、マウスのクリックだけでソフトウエアの購入ができるため、安価なソフトウエアの販売にも向いている。購入の都度クレジットカードの番号を入力することもないので、安全性が高くなる。
【0110】
また、本発明の手順によれば、ユーザは実際に必要な(持っていない)情報のみをダウンロード要求するため、既に持っている情報に関して二重に課金されることは起らない。従来のシステムにおいては、例えば初回のダウンロード時に課金ログをサーバ側に生成し、2回目以降はその課金ログを元に非課金とするといった煩雑なチェックが必要であった。
(3)自動バージョンアップ機能
ダウンロードプログラムは、サーバ1から送信されるインストールリストを参照して、自端末にインストール済みのファイルがバージョンアップされているか否かをチェックし、その結果をユーザに提示する。ユーザはこれをもとに必要なファイルのダウンロード要求をマウス等を操作するだけで簡単行える。しかも、必要な部分のみサーバ1からダウンロードされるわけであるから通信量が少なく回線費用が割安となる。
(4)ソフトウエアの試供
まず、無料の試供版ソフト(コアソフト)を試用した後にそれに付加して正規の動作が可能となる課金対象部分のソフト(受動機能部)を購入する仕組みなので、購入した製品のトラブルや不満が無くなり、返品が不可能な電子的情報の販売に向いている。
(5)違法コピー防止機能
課金対象部分のソフト(受動機能部)は、サーバからダウンロードされてクライアント端末にインストールされる際に暗号化されたまま格納され、ソフトの起動時の度にコアソフトの復号化組込機能にて受動機能部ファイルが復号化されて実行可能なように変換される。そして、その復号化の際に用いられるユーザ固有の共有鍵は、クライアント端末に一義的に定められるプロダクトIDにて暗号化されて格納されている。従って、単純に、鍵ファイル52、コアソフト36、暗号化された受動機能ファイル37の全てを違法にコピーしても、プロダクトIDを入手しない限り、その違法コピーされたソフトウエアを実行することは不可能となる。
(6)ダウンロードプログラムのバージョンアップ
クライアント端末2のダウンロードプログラムでは、サーバ1から送信されるインストールリストに記述されるダウンロードプログラムのバージョン情報をチェックし、新しくなっていたら最新のダウンロードプログラムのダウンロードを自動的にサーバ1に要求することにより、ダウンロードプログラムのバージョンアップが容易に行え、従って、インストールリストに記述される命令の種類の追加等が容易となる。
(7)ソフトウエアの分割ダウンロード
サイズの大きいソフトウエアをダウンロードする際には、分割してダウンロードすることを指定した命令を、インストールリストに含めることにより、その旨をクライアント端末2に通知することができゆえに分割ダウンロードが可能となる。
【0111】
これにより、ダウンロード時にサーバ1とクライアント端末2との間の通信回線に障害が発生して、正常にダウンロードできなくとも、再度マウスのクリック等の簡単な操作により、ダウンロードを継続することができる。
【0112】
また、インターネット上では1セッションの通信サイズが制限される場合があるが、そのようなネットワークにおいても、分割ダウンロードを利用することにより、どんなにサイズの大きな情報でも確実に送信することができる。
【0113】
なお、上記実施形態において、受動機能部は課金対象のソフトウエアとして説明したが、この場合に限らず、能動機能部への無料の追加機能としても同様に実現することができる。従って、この場合は受動機能部の暗号化は必ずしも行う必要はない。
【0114】
【発明の効果】
本発明によれば、ソフトウエア提供者がソフトウエアのインストールにかかわるインストールリストを予め送信し、それを利用者のパソコン等でダウンロードする前に解釈する手順を踏むことにより、ソフトウエアのインストールに際して実際に必要なデータだけを効率良くしかも自動的に転送しインストールすることができるため、簡易な操作でネットワークを介したソフトウエアの流通が可能となる。
【0115】
また、必要なデータだけ送ることは、単に送信データ量が少なくなるだけでなく、各データそのものに価格を設定することができるため、ソフトウエアの提供の際に柔軟な課金を行うことができる。
【図面の簡単な説明】
【図1】本発明の実施形態に係るソフトウエア流通システムの全体の構成図。
【図2】図1のソフトウエア流通システムで用いられる鍵データの流れを説明するための図。
【図3】ユーザ登録時のデータの流れを説明するための図。
【図4】個人情報ファイルに格納される個人情報の記憶例を示した図。
【図5】図1のソフトウエア流通システムで用いられる鍵データの流れと、ユーザがサーバから商品ソフトウエアをダウンロードする際のデータの流れを説明するための図。
【図6】商品ソフトウエアの構成を模式的に示した図。
【図7】コアソフトの機能を説明するための図。
【図8】ダウンロードプログラム機能部の処理手順について説明するための図。
【図9】サーバから送信されるデータの構成例を示した図。
【図10】インストールリストに記述されるインストール命令の一例を示した図。
【図11】図10のインストール命令の具体例を示した図。
【図12】ダウンロードデータの構成例を示した図。
【符号の説明】
1…サーバ
2…クライアント端末
11…入会ソフトダウンロード機能部
12…入会ソフト受け付け機能部
15…インストールリスト送信部
16…ダウンロード情報送信部
31…入会ソフトウエア機能部
32…ダウンロードプログラム機能部
33…コアソフト機能部
36…コアソフト
37…受動機能ファイル
Claims (8)
- サーバ装置がネットワークを介してクライアント端末にソフトウェアを提供するソフトウエア流通方法において、
前記サーバ装置は、ソフトウェアの購入が可能なクライアント端末と共有する共有鍵及び当該クライアント端末の購入鍵とを対応付けて記憶する第1の記憶手段を備え、
前記クライアント端末は、単独で動作可能な能動機能部ソフトウェアのファイルと、当該能動機能部ソフトウェアにより復号され、当該能動機能部ソフトウェアに組み込まれて動作可能となる少なくとも1つの受動機能部ソフトウェアのファイルを含むソフトウエアをインストールするための第2の記憶手段を備え、
前記クライアント端末が前記サーバ装置へ、所望のソフトウエアの提供を要求するためのソフトウェア要求を送信し、
前記サーバ装置が、前記ソフトウェア要求により指定されたソフトウエアに対応する能動機能部ソフトウェア及び受動機能部ソフトウェアの各ファイルと、各ファイルのバージョン情報とを示すインストールリストを前記クライアント端末へ送信し、
前記クライアント端末が、前記インストールリストの各ファイル及びバージョン情報と、前記第2の記憶手段にインストールされている各ファイル及び各ファイルのバージョン情報とを比較して、当該インストールリストからダウンロードを要求するファイルを選択し、当該クライアント端末を認証するための購入鍵を含み、当該選択されたファイルを要求するためのダウンロード要求を前記サーバ装置へ送信し、
前記サーバ装置が、前記能動機能部ソフトウェアのファイルが前記ダウンロード要求で指定されている場合には、当該能動機能部ソフトウェアを前記クライアント端末へダウンロードし、暗号化すべき前記受動機能部ソフトウェアのファイルが前記ダウンロード要求で指定されている場合には、当該受動機能部ソフトウェアのファイルを、前記ダウンロード要求に含まれる購入鍵に対応付けて前記第1の記憶手段に記憶されている共有鍵で暗号化して、前記クライアント端末へダウンロードし、
前記クライアント端末が、前記サーバ装置からダウンロードされたファイルを、前記第2の記憶手段にインストールすることを特徴とするソフトウエア流通方法。 - 前記クライアント端末は、前記ソフトウェア要求を送信する際に、当該ソフトウェアのインストールに関連する当該クライアント端末の環境判定結果を併せて送信し、
前記サーバ装置は、前記環境判定結果に応じたインストールリストを送信することを特徴とする請求項1に記載のソフトウエア流通方法。 - 前記クライアント端末が、前記第2の記憶手段にインストールしたファイルのうちの前記能動機能部ソフトウェアを実行することにより、前記第2の記憶手段にインストールしたファイルのうちの暗号化された前記受動機能部ソフトウェアのファイルが、当該クライアント端末が有する前記共有鍵で復号され、得られた前記受動機能部ソフトウエアが前記能動機能部ソフトウエアに組み込まれて動作可能となることを特徴とする請求項1記載のソフトウェア流通方法。
- 前記クライアント端末は、前記サーバ装置と共有する前記共有鍵を当該クライアント端末固有のプロダクトIDを用いて暗号化して記憶する第3の記憶手段をさらに備え、
前記クライアント端末が、前記第2の記憶手段にインストールしたファイルのうちの前記能動機能部ソフトウェアを実行することにより、前記第3の記憶手段に記憶された暗号化された共有鍵が前記プロダクトIDを用いて復号され、この復号された共有鍵を用いて、前記第2の記憶手段にインストールされたファイルのうち暗号化された前記受動機能部ソフトウェアのファイルが復号されて、
得られた前記受動機能部ソフトウエアが前記能動機能部ソフトウエアに組み込まれて動作可能となることを特徴とする請求項1記載のソフトウェア流通方法。 - 前記インストールリストには、前記指定されたソフトウェアに対応するファイルのうち、複数個に分割してダウンロードするファイルについては分割に関する情報が含まれていることを特徴とする請求項1に記載のソフトウエア流通方法。
- 前記クライアント端末は、前記サーバ装置から所望のソフトウェアをダウンロードするためのダウンロードプログラムをインストールする第4の記憶手段をさらに備え、
前記第4の記憶手段にインストールされるダウンロードプログラムを実行することにより、前記ソフトウエア要求を前記サーバ装置へ送信し、
前記ソフトウェア要求を受けて前記サーバ装置から送信される前記インストールリストは、ダウンロードプログラムの最新のバージョン情報を含み、
前記クライアント端末は、現在実行中のダウンロードプログラムのバージョンが、前記インストールリスト内のダウンロードプログラムのバージョン情報よりも古いとき、前記サーバ装置に要求して、当該サーバ装置からダウンロードされた最新のバージョンのダウンロードプログラムを前記第4の記憶手段にインストールし、前記最新のバージョンのダウンロードプログラムを実行することにより、ダウンロードを要求するファイルを選択して、前記ダウンロード要求を前記サーバ装置へ送信する請求項1記載のソフトウェア流通方法。 - ネットワークを介してクライアント端末にソフトウェアを提供するサーバ装置において、
ソフトウェアの購入が可能なクライアント端末と共有する共有鍵及び当該クライアント端末の購入鍵とを対応付けて記憶する記憶手段と、
前記クライアント端末から送信されたソフトウェア要求を受信する手段と、
前記ソフトウェア要求により指定されたソフトウエアに対応する、単独で動作可能な能動機能部ソフトウェア及び当該能動機能部ソフトウェアに組み込まれて動作可能となる少なくとも1つの受動機能部ソフトウェアの各ファイルと、各ファイルのバージョン情報とを示すインストールリストを前記クライアント端末へ送信する手段と、
前記クライアント端末から、当該クライアント端末を認証するための購入鍵を含み、前記インストールリストを基に選択されたファイルを要求するためのダウンロード要求を受信する手段と、
前記能動機能部ソフトウェアのファイルが前記ダウンロード要求で指定されている場合には、当該能動機能部ソフトウェアを前記クライアント端末へダウンロードし、暗号化すべき前記受動機能部ソフトウェアのファイルが前記ダウンロード要求で指定されている場合には、当該受動機能部ソフトウェアのファイルを、前記ダウンロード要求に含まれる購入鍵に対応付けて前記第1の記憶手段に記憶されている共有鍵で暗号化して、前記クライアント端末へダウンロードする手段と、
を具備したことを特徴とするサーバ装置。 - ネットワークを介してサーバ装置から提供されたソフトウエアを利用するクライアント装置において、
前記サーバ装置と共有する共有鍵及び購入鍵を前記サーバ装置へ送信する手段と、
前記共有鍵を暗号化して記憶する第1の記憶手段と、
単独で動作可能な能動機能部ソフトウェアのファイルと、当該能動機能部ソフトウェアにより復号され、当該能動機能部ソフトウェアに組み込まれて動作可能となる受動機能部ソフトウェアの前記共有鍵で暗号化された少なくとも1つの暗号化ファイルを含むソフトウエアをインストールするための第2の記憶手段と、
所望のソフトウエアの提供を要求するためのソフトウェア要求を、前記サーバ装置へ送信するソフトウエア要求送信手段と、
前記ソフトウェア要求により指定されたソフトウエアに対応する前記能動機能部ソフトウェア及び前記受動機能部ソフトウェアの各ファイルと、各ファイルのバージョン情報を示すインストールリストを受信する手段と、
前記インストールリストの各ファイル及び各ファイルのバージョン情報と、前記第2の記憶手段にインストールされている各ファイル及び各ファイルのバージョン情報とを比較して、当該インストールリストからダウンロードを要求するファイルを選択し、当該クライアント端末を認証するための前記購入鍵を含み、当該選択されたファイルを要求するためのダウンロード要求を前記サーバ装置へ送信するダウンロード要求送信手段と、
前記サーバ装置からダウンロードされたファイルを前記第2の記憶手段にインストールする手段と、
を具備したことを特徴とするクライアント装置。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP00947998A JP3766197B2 (ja) | 1997-01-21 | 1998-01-21 | ソフトウエア流通方法およびサーバ装置およびクライアント装置 |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP9-8867 | 1997-01-21 | ||
JP886797 | 1997-01-21 | ||
JP00947998A JP3766197B2 (ja) | 1997-01-21 | 1998-01-21 | ソフトウエア流通方法およびサーバ装置およびクライアント装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH10269078A JPH10269078A (ja) | 1998-10-09 |
JP3766197B2 true JP3766197B2 (ja) | 2006-04-12 |
Family
ID=26343476
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP00947998A Expired - Fee Related JP3766197B2 (ja) | 1997-01-21 | 1998-01-21 | ソフトウエア流通方法およびサーバ装置およびクライアント装置 |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP3766197B2 (ja) |
Families Citing this family (36)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2000215602A (ja) * | 1999-01-21 | 2000-08-04 | Nissan Motor Co Ltd | 情報提供装置、デ―タ送受信方法および記憶媒体 |
KR20000057127A (ko) * | 1999-02-03 | 2000-09-15 | 송동호 | 소프트웨어 임대 시스템을 위한 분산컴퓨팅 환경에서의프로그램 수행시스템 및 그 방법 |
EP1163592A1 (en) * | 1999-03-18 | 2001-12-19 | Kent Ridge Digital Labs | Software distribution, execution and upgrading |
EP1049036A2 (en) * | 1999-04-29 | 2000-11-02 | Citibank, N.A. | System and method for web trading |
GB9910164D0 (en) * | 1999-04-30 | 1999-06-30 | Hugh Symons Group Plc | The distributed management of network devices |
JP2001195373A (ja) * | 2000-01-13 | 2001-07-19 | Ntt Comware Corp | エージェント実行装置、エージェント管理装置、エージェント処理システム、エージェント実行方法およびエージェント管理方法 |
JP2002032685A (ja) * | 2000-05-11 | 2002-01-31 | Nec Corp | コンテンツレンタルシステム |
US20030135467A1 (en) * | 2000-05-30 | 2003-07-17 | Akiyoshi Okamoto | Rental system of digital content |
JP4568963B2 (ja) | 2000-06-08 | 2010-10-27 | ソニー株式会社 | 情報処理装置、情報通信システム |
JP2002006416A (ja) * | 2000-06-19 | 2002-01-09 | Noritsu Koki Co Ltd | 写真処理システムおよび写真処理装置のバージョンアップ方法 |
JP2002006974A (ja) * | 2000-06-22 | 2002-01-11 | Nippon Digital Kenkyusho:Kk | プログラムのレンタル及び販売方法と、試供、レンタル又は販売したプログラムの管理方法及び端末にインストールされるプログラムの記録媒体 |
CN100447773C (zh) * | 2000-07-20 | 2008-12-31 | 国际商业机器公司 | 在计算机销售端为购买的计算机安装程序的方法及系统 |
JP2002094473A (ja) * | 2000-09-11 | 2002-03-29 | Victor Co Of Japan Ltd | 番組購入用端末及び復号鍵格納装置並びに番組購入システム |
JP2002117305A (ja) * | 2000-10-04 | 2002-04-19 | Tokyo Electric Power Co Inc:The | コンテンツ配布システム及びサーバ |
JP2002132614A (ja) | 2000-10-18 | 2002-05-10 | Nec Corp | データ配信システム |
JP4205299B2 (ja) * | 2000-10-24 | 2009-01-07 | セイコーエプソン株式会社 | コンテンツ配信のためのシステム及び方法 |
US20040128145A1 (en) * | 2000-10-26 | 2004-07-01 | Kenji Sato | Digital content selling method and system using communication network |
KR20020051198A (ko) * | 2000-12-22 | 2002-06-28 | 엘지전자 주식회사 | 프로그래머블 로직 디바이스 프로그램의 원격 다운로드 방법 |
JP2002251343A (ja) * | 2001-02-23 | 2002-09-06 | Nec Nexsolutions Ltd | 複数ファイル一括ダウンロードシステムと方法およびプログラム |
JP2002259563A (ja) * | 2001-02-28 | 2002-09-13 | Sanyo Electric Co Ltd | 薬剤情報改版システム及び改版方法 |
JP4728501B2 (ja) * | 2001-04-19 | 2011-07-20 | 株式会社東芝 | 通信システム、ボタン電話システム用交換機、サーバコンピュータ、プログラム、ライセンス管理方法、ライセンス取得方法 |
JP2003029863A (ja) * | 2001-07-18 | 2003-01-31 | Dainippon Printing Co Ltd | ソフトウェアライセンス管理システム |
JP4332344B2 (ja) * | 2001-12-28 | 2009-09-16 | 株式会社Access | 利用期限管理方法、利用期限管理システム、および管理サーバ |
CN1161924C (zh) * | 2002-04-02 | 2004-08-11 | 华为技术有限公司 | 一种二层交换设备的数据升级方法 |
US8737981B2 (en) | 2002-12-19 | 2014-05-27 | Qualcomm Incorporated | Downloadable configuring application for a wireless device |
EP1465182A1 (en) * | 2003-04-04 | 2004-10-06 | Sony DADC Austria AG | Optical media protection driver |
JP3895358B2 (ja) | 2003-05-16 | 2007-03-22 | 株式会社ジャパン・ウェーブ | デジタルコンテンツの不正使用防止システム、再生装置およびデジタルコンテンツの不正再生防止方法 |
JP4537670B2 (ja) * | 2003-07-01 | 2010-09-01 | 株式会社リコー | 情報処理装置、インストール方法、インストールプログラム、バージョン情報管理装置及び認証情報管理装置 |
JP2005228155A (ja) * | 2004-02-13 | 2005-08-25 | National Institute Of Advanced Industrial & Technology | 生物学情報統合装置、生物学情報統合方法及び生物学情報統合プログラム |
JP2006119897A (ja) * | 2004-10-21 | 2006-05-11 | Oki Electric Ind Co Ltd | 自動取引装置、監視サーバおよび自動取引装置監視システム |
JP2008282251A (ja) * | 2007-05-11 | 2008-11-20 | Sourcenext Corp | ダウンロードプログラム、情報記憶媒体、ダウンロードシステム及びダウンロード方法 |
JP2009211260A (ja) * | 2008-03-03 | 2009-09-17 | Hitachi Ltd | 情報通信システム |
JP5497501B2 (ja) * | 2010-03-18 | 2014-05-21 | エスアイアイ・データサービス株式会社 | ユーザ登録装置およびユーザ登録方法 |
KR101284551B1 (ko) * | 2011-04-21 | 2013-07-11 | (주)지온네트웍스 | 휴대단말기간의 어플리케이션 이체설치 방법 |
JP6547350B2 (ja) * | 2015-03-18 | 2019-07-24 | 株式会社リコー | 課金処理システム、課金処理方法及びプログラム |
JP6571602B2 (ja) * | 2016-07-26 | 2019-09-04 | 日立オートモティブシステムズ株式会社 | 車両制御装置、車載ネットワークシステム |
-
1998
- 1998-01-21 JP JP00947998A patent/JP3766197B2/ja not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
JPH10269078A (ja) | 1998-10-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3766197B2 (ja) | ソフトウエア流通方法およびサーバ装置およびクライアント装置 | |
US6195432B1 (en) | Software distribution system and software utilization scheme for improving security and user convenience | |
US6920567B1 (en) | System and embedded license control mechanism for the creation and distribution of digital content files and enforcement of licensed use of the digital content files | |
US8443455B2 (en) | Apparatus, method, and computer program for controlling use of a content | |
JP4974534B2 (ja) | デジタルアプリケーションのライセンスを取得するためのコンピューティングデバイスおよび方法 | |
US7577853B2 (en) | Restricted software and hardware usage on a computer | |
US7752139B2 (en) | Method and system for managing software licenses and reducing unauthorized use of software | |
US6041411A (en) | Method for defining and verifying user access rights to a computer information | |
EP1907917B1 (en) | Secure software updates | |
EP2628125B1 (en) | Method and apparatus for downloading drm module | |
JP4835167B2 (ja) | ライセンス管理のためのプログラム、システム及び方法 | |
EP1287416B1 (en) | System and embedded license control mechanism for the creation and distribution of digital content files and enforcement of licensed use of the digital content files | |
US20040015958A1 (en) | Method and system for conditional installation and execution of services in a secure computing environment | |
JP2002503365A (ja) | 一意的にカスタマイズされ、認証かつ追跡可能なソフトウェア・アプリケーションのネットワーク化インストール方法およびシステム | |
JPH1021144A (ja) | ディジタル著作物配布システム及び不正な複製物の検出方法 | |
US20020055910A1 (en) | Program component distribution | |
EP1465043A2 (en) | Keyed-build system for controlling the distribution of software | |
JP2004030617A (ja) | インターネットを利用したトランザクションサービスシステムおよびその方法 | |
JP2001069133A (ja) | 情報処理方法及びその装置 | |
JP2004062864A (ja) | インターネットを利用したオンラインショッピングシステム | |
KR100648207B1 (ko) | 디지털 컨텐츠의 유통방법 | |
JP2004046448A (ja) | 配信データ管理システム及びその方法 | |
WO2003036530A1 (en) | A method and a system for licensing digital resources and services | |
JP2004030618A (ja) | インターネットを利用したサービスシステムおよびその方法 | |
JP2003337705A (ja) | インターネットを利用したソフトウェア配送システムおよびその方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20041006 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20050125 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20050328 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20050913 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20051107 |
|
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: 20060124 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20060126 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100203 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100203 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110203 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120203 Year of fee payment: 6 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120203 Year of fee payment: 6 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130203 Year of fee payment: 7 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20140203 Year of fee payment: 8 |
|
LAPS | Cancellation because of no payment of annual fees |