画像電子学会 第 9 回国際標準化教育研究会 -事業化と標準化教育- Web 型グループウェア開発における技術標準動向と人材育成の課題 The standard trend in Web groupware development and training 竹迫 良範 Yoshinori TAKESAKO サイボウズ・ラボ株式会社 〒112-0004 東京都文京区後楽 1-4-14 後楽森ビル 12F E-mail: [email protected] 図 1: Web 型グループウェア製品サイボウズ Office 9 のトップページ画面 1. は じ め に サ イ ボ ウ ズ 株 式 会 社 は 、 創 業 1997 年 か ら Web 型 グ ループウェアを開発しているソフトウェア会社である。 主 力 製 品 は す べ て Web ア プ リ ケ ー シ ョ ン と し て 実 装 されており、専用のソフトウェアをインストールする こ と な く 、 Web ブ ラ ウ ザ の み で 利 用 で き る ( 図 1)。 1.1. Web ブラウザの種 類 現 在 、動 作 を サ ポ ー ト し て い る Web ブ ラ ウ ザ の 種 類 は 、 Internet Explorer、 Firefox、 Chrome、 Safari の 各 バ ージョンと多岐に渡っており、各ブラウザの動作の違 い が 、 開 発 上 の 大 き な 問 題 と な っ て い る ( 図 2)。 図 2:サ ポ ー ト 対 象 Web ブ ラ ウ ザ 一 覧 画像電子学会 第 9 回国際標準化教育研究会 2. Web ブ ラ ウ ザ の バ ー ジ ョ ン ア ッ プ の 歴 史 1994 年 に リ リ ー ス さ れ た Netscape Navigator で は 、 -事業化と標準化教育- W3C が 勧 告 し た Web 標 準 に ど れ だ け 準 拠 し て い る か を 視 覚 的 に 確 認 で き る テ ス ト Acid1 Test( 図 4)を 初 テ キ ス ト を 点 滅 さ せ る 目 的 の <blink>を HTML 中 に 記 め て 作 成 し た 。こ の テ ス ト は CSS1 Test Suite に 取 り 込 載できるようにしていた。競争関係にあったライバル ま れ 、 Web 標 準 普 及 へ の 大 き な 前 進 と な っ た 1 。 の Internet Explorer は 、 テ キ ス ト を ス ク ロ ー ル 表 示 さ せ る <marquee>や 、音 を 鳴 ら す <bgsound>な ど を 次 々 に 導入した。当時ブラウザ間で全く互換性のない独自拡 張がベンダー主導で積極的に行われる時期があった。 各ブラウザの挙動と見栄えの違いによって、多くの Web 制 作 者 を 悩 ま す 結 果 と な っ た が 、 W3C に よ る HTML4.01 仕 様 の 勧 告 と CSS の 普 及 に よ っ て 、 各 ブ ラ ウザ・ベンダーは標準準拠を意識するようになった。 Netscape は 2008 年 に 開 発 を 終 了 し た が 、 そ の 後 Google Chrome の 登 場 に よ っ て Web ブ ラ ウ ザ の バ ー ジ ョ ン ア ッ プ 競 争 が 現 在 ま で 続 い て い る ( 図 3)。 図 5: Acid2 Test の 表 示 結 果 そ の 他 、 主 に CSS2.1 へ の 準 拠 度 を 視 覚 的 に 確 認 で き る Acid2 Test( 図 5)も 有 名 で あ る 。現 在 、デ ス ク ト ッ プ PC 向 け の ブ ラ ウ ザ で は ほ ぼ 準 拠 し て い る が 、 Opera Mini 4 や iPod touch 2 な ど ス マ ー ト フ ォ ン 上 の ブ ラウザでは正しく表示されない実装がある。 図 3: Browser History Timeline http://meyer we b.com/eric/browsers/timeline -str uctured. html 2.1. The Web Standards Project(WaSP) WaSP は 1998 年 に 設 立 さ れ た Web 標 準 に 沿 っ た ブ ラ 図 6: Acid3 Test の 100 点 満 点 結 果 ウザの実装とコンテンツ制作を支援する団体である。 最 近 は Ajax 技 術 の 普 及 に よ っ て 、JavaScript や DOM を 多 用 す る Web ア プ リ ケ ー シ ョ ン が 増 え て き た た め 、 主 に HTML の DOM Livel 2 や ECMAScript の 挙 動 を テ ス ト す る Acid3 Test( 図 6) が 2008 年 に 公 開 さ れ た 。 2.2. W3C CSS Working Group こ の よ う に 視 覚 的 に CSS の レ ン ダ リ ン グ 結 果 を 確 認 で き る よ う に し た テ ス ト ス イ ー ト は W3C の WG で も 作 成 さ れ 、 現 在 9,600 件 の テ ス ト が 公 開 さ れ て い る 2 。 1 図 4: 初 め て 作 成 さ れ た Acid1 Test ES ウ ェ ブ ブ ラ ウ ザ 通 信 - Acid1 テ ス ト http://shiki.esrille.com/2011/09/es -acid1.html 2 CSS2.1 Test Suite Results http://wiki.csswg.org/test/css2.1/results 画像電子学会 第 9 回国際標準化教育研究会 3. WHATWG と HTML5 の 関 係 -事業化と標準化教育- 3.2. HTML4 と HTML5 の違 い WHATWG は Web Hypertext Application Technology Working Group の 略 で W3C と は 別 の 団 体 で あ る( 図 7)。 従 来 の HTML4 の 文 章( 図 8)を XML valid で な い 書 き 方 が 許 容 さ れ た HTML5 で 書 き 直 す と 図 9 に な る 。 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"> <html> <head> <meta http-equiv="content-type" content="text/html; charset=UTF -8"> <title>HTML4.01 example</title> <script type="text/javascript"> alert("Hello!"); </script><style type="text/css"> body{background:#decafe}</style> </head> <body> <p>HTML4.01 sample document<hr/></p> </body> </html> 図 8: HTML4.01 の 文 書 サ ン プ ル 図 7: WHATWG の Web サ イ ト 従 来 W3C が 進 め て い た XHTML2.0 の 方 向 性 と 現 場 のニーズの無関心さに不満を持ったブラウザベンダー Opera、Mozilla、Apple の 3 社 が 集 ま り 、独 自 に 新 し い HTML 関 連 仕 様 を ま と め る た め 、 2004 年 に 設 立 し た 。 こ の と き の 仕 様 は Web Applications 1.0 と Web Forms 2.0 と し て ま と め ら れ た 。 の ち の HTML5 で あ る [1]。 <!DOCTYPE html> <html> <meta charset="UTF-8"> <title>HTML5 example</title> <script>alert("Hello!");</script> <style>body{background:#eff}</style> <p>HTML5 sample document<hr></p> </html> 図 9: HTML5 の 文 書 サ ン プ ル 3.1. XHTML2.0 の終 了 と HTML5 の登 場 結 局 W3C は 2007 年 に XHTML2.0 の 策 定 を あ き ら め 従 来 の HTML の 仕 様 で は 字 句 解 析 と 構 文 解 析 の ア ル て 、後 方 互 換 性 を 重 視 し た 新 し い HTML の 仕 様 を 策 定 ゴ リ ズ ム が 明 記 さ れ て お ら ず 、 HTML パ ー サ の 挙 動 が す る と 発 表 し た 。 WHATWG は 自 分 た ち で ま と め た 仕 ブ ラ ウ ザ の バ ー ジ ョ ン 毎 に 異 な っ て い た ( 図 10)。 様 を HTML5 と い う 新 し い 名 前 で 策 定 し て は ど う か と W3C に 対 し て 提 案 し [2]、HTML Working Group が W3C 内 に 新 設 さ れ た 。そ れ に 伴 い W3C は HTML5 の 仕 様 策 定 に 注 力 し 、 XHTML2 Working Group を 解 散 し た 3 。 表 1: HTML5 関 連 API の 実 装 状 況 対応ブラウザ バージョン Internet Explorer Firefox Chrome Safari Opera 8 9 10 3.6 4 10 5 11.50 Local Storage ○ ○ ○ ○ ○ ○ ○ ○ Session Storage ○ ○ ○ ○ ○ ○ ○ ○ Post Message ○ ○ ○ ○ ○ ○ ○ ○ Offline Applications × × × ○ ○ ○ ○ ○ WebSockets API × × × × × ○ ○ × Web Workers × × × ○ ○ ○ ○ ○ Query Selector ○ ○ ○ ○ ○ ○ ○ ○ WebSQL Database(廃止) × × × × × ○ ○ ○ IndexDB Database × × × × × × × × Drag and Drop ○ ○ ○ ○ ○ ○ ○ × File API × × ○ △ ○ ○ × ○ <!DOCTYPE html> <title>HTML5 Syntax Checker</title> <h2>Your Browser is...</h2> <img :src = "opera8.gif" x=``src = "ie.gif" srcZ/="netscape6.gif" src#= "netscape7.gif" = /src = "html5.gif" ''src^K= "safari.gif" /src = "firefox.gif" src = "others.gif" src = "lynx.gif" /> <hr/><!-- ^K is Vertical Tab '¥x0B' --> <p>http://www.w3.org/TR/html5/syntax.html</p> 図 10: HTML5 で は パ ー サ の 動 作 も 標 準 化 HTML5 は Web ア プ リ ケ ー シ ョ ン を 記 述 す る プ ラ ッ GeoLocation × ○ ○ ○ ○ ○ ○ ○ ト フ ォ ー ム の 仕 様 と し て JavaScript の API を 多 く 定 義 History Management × × × × ○ ○ ○ × し て い る 。 い く つ か API は 元 の HTML5 の 仕 様 か ら 分 離 し た 形 で 、個 別 に メ ン テ ナ ン ス を 行 っ て い る( 表 1)。 3 2010-12-17: The XHTML2 Working Group is closed. http://www.w3.org/MarkUp/ 画像電子学会 第 9 回国際標準化教育研究会 -事業化と標準化教育- 4.2. ECMAScript 5 th Edition の登 場 4. ECMAScript の 標 準 化 1996 年 3 月 に リ リ ー ス さ れ た Netscape Navigator 2.0 し か し 、 ECMAScript 4 の 言 語 は 後 方 互 換 性 が な く 、 に は Web ク ラ イ ア ン ト サ イ ド で 動 作 す る ス ク リ プ ト Web が 壊 れ て し ま う と 懸 念 し た 他 の ブ ラ ウ ザ ベ ン ダ ー 言 語 JavaScript の 最 初 の バ ー ジ ョ ン が 搭 載 さ れ て い た 。 から言語仕様の大幅な変更を受け入れてもらうことが 当 時 Netscape と Web 標 準 と ブ ラ ウ ザ シ ェ ア を 争 っ て い で き な か っ た [5]。 代 わ り に ECMAScript 3.1 を ベ ー ス た Microsoft は JavaScript と 互 換 性 の あ る ス ク リ プ ト 言 と し た 小 さ な 仕 様 改 訂 ECMAScript 5 が 承 認 さ れ た 。 語 JScript を 搭 載 し た Internet Explorer 3.0 を 8 月 に リ リ ー ス し た 。 Netscape は JScript の 発 表 に 危 機 感 を 覚 え 、 JavaScript の 標 準 化 を 決 意 し た 。当 初 W3C に JavaScript 4.3. ECMAScript5 の仕 様 忠 実 な処 理 系 「lv5」 2011 年 、サ イ ボ ウ ズ・ラ ボ ユ ー ス の 鈴 木 勇 介 4 は [6]、 の 標 準 化 の 話 を 持 っ て い っ た が 、断 ら れ て し ま っ た [3]。 最 新 の ECMAScript5 の 仕 様 に 忠 実 な 処 理 系 lv5 を 実 装 Netscape は 標 準 を 買 う こ と が で き る 団 体 を 求 め て 、ISO し た 。lv5 で は Array.length に 対 す る PropertyDescriptor や そ の 他 標 準 化 団 体 を 回 り 、欧 州 の ECMA International の設定が可能になっている。これは他のブラウザで 未 に 辿 り 着 き 、ECMAScript( ECMA-262)と し て JavaScript 実 装 な ECMAScript5 の 新 し い 仕 様 の 1 つ で あ る( 図 11)。 の 言 語 仕 様 を 標 準 化 す る こ と と な っ た ( 表 2)。 表 2: ECMAScript 各 版 の 標 準 化 動 向 版 時期 - 1996年3月 JavaScriptの誕生(Netscape Navigator 2.0) 概要 1 1997年6月 ECMA-262 1st Edition 2 1998年6月 ECMA-262 2nd Edition(ISO/IEC 16262:1998) 3 1999年12月 ECMA-262 3rd Edition Ecma Internationalで最初に規格化 以後、JIS X 3060:2000としてJIS規格化 ISO/IEC 16262:2002(2nd Edition)改訂 4 5 廃止 ActionScriptとJavaScriptの統合と大幅な拡張を試みるが挫折 2011年6月 ECMA-262 5.1th Edition として Errata 等の修正 ISO/IEC 16262:2011(3rd Edition)改訂 ES.next 図 11: Test262, 15.2.3.7-6-a-112.js 2009年12月 ECMA-262 5th Edition を10年ぶりに策定 各ブラウザで実装されている仕様の追認(内容的にはES3.1) 5.1 fun ct io n t es tc ase () { var a rr = [0 , 1]; Obj ec t.d ef in eP rop er ty (a rr, " 1 ", { val ue : 1 , con fi gur ab le : f al se }); try { Obj ec t.d ef in ePr op er ti es( ar r , { leng th : { val ue : 1 } }); ret ur n f al se ; } c at ch (e x) { var d esc = O bje ct .g et Own Pr o per ty De scr ip to r(a rr , "l eng th ") ; ret ur n e x in sta nc eo f Typ eE r ror & & des c. va lue = == 2 && des c.w ri ta bl e & & !d esc .e nu mer ab le && ! de sc. co nf ig ura bl e; } } 現在 新しいECMAScript HarmonyとしてTC39で仕様の拡張を検討中 TC39 で は 、ECMA-262 へ の 仕 様 準 拠 度 を 確 認 す る た め の Test Suite と し て Test262 を 提 供 し て い る 。lv5 は 、 Test262 の 11029 件 の 全 件 テ ス ト う ち 11011 件 99.83% を pass し て い る( 表 3)。残 り 18 件 に つ い て は Test262 Microsoft も 標 準 化 に 参 画 し 、 JScript も ECMA-262 に準拠するようにバージョンアップされた。 ECMA-262 は そ の 後 Fast-track 手 続 に よ っ て ISO/IEC 16262:1998 と し て 国 際 標 準 と し て 承 認 さ れ 、日 本 国 内 自 体 の バ グ の 可 能 性 が あ り 、Test262 の 開 発 者 に レ ポ ー ト を 送 り 、数 件 の テ ス ト ケ ー ス は 修 正 の 見 込 み で あ る 。 表 3:ECMAScript Test262 準 拠 度 テ ス ト 結 果 で も JIS X 3060:2000 と し て 翻 訳 JIS が 制 定 さ れ た 。 4.1. 消 えた ECMAScript 4 th Edition 2008 年 頃 ま で 、改 訂 を 目 指 し Adobe と Mozilla を 中 心 に ECMAScript 4 の 標 準 化 に 向 け た 準 備 が 着 々 と 進 Opera Safari Chrome Firefox lv5 all pass 11029 11029 11029 11029 11029 7276 10256 10611 10865 11011 fail 仕様準拠度(%) 3753 773 418 164 18 65.97 92.99 96.21 98.51 99.83 め ら れ て い た 。Adobe は ActionScript 3 の 高 速 な JIT 処 理 系 実 装 Tamarin を 公 開 し 、 Mozilla は JavaScript 2.0 に向けた言語仕様のバージョンアップを行っていた。 ECMAScript 4 は ActionScript と JavaScript の 言 語 大 統一を試みる野心的なプロジェクトであった。 ActionScript 由 来 の class 宣 言 や int 型 、string 型 、const 宣 言 が 可 能 に な り 、 type 宣 言 や テ ン プ レ ー ト 型 も 使 う こ と が で き 、 package、 namespace、 intrinsic 宣 言 な ど 、 ダイナミック言語の大規模開発で必要な要素はすべて ECMAScript 4 で 取 り 入 れ ら れ る 予 定 で あ っ た [4]。 4.4. ISO/IEC 16262:2011 の策 定 日 本 で は 情 報 規 格 調 査 会 の SC22 専 門 委 員 会 内 に ECMAScript ア ド ホ ッ ク を 招 集 し 、ISO/IEC 16262 の 改 訂 に 備 え た 。JSON 形 式 の サ ポ ー ト 、Strict モ ー ド の 追 加 、 ISO8601 形 式 の 日 付 対 応 、 エ ラ ー の 厳 密 化 な ど の 追 加 仕 様 部 分 を 主 に 審 議 し た 。ECMA か ら の Fast-Track 手 続 に よ り 、 JTC1 参 加 各 国 の SC22 mirror committee 4 慶應義塾大学理工学部 3 年 画像電子学会 第 9 回国際標準化教育研究会 -事業化と標準化教育- が投票を行ったが、コメント付きの反対投票を行った 弱 性 と な る 。利 用 者 が 安 心 し て Web ア プ リ ケ ー シ ョ ン の は 日 本 の JISC の み で あ っ た 。投 票 コ メ ン ト で は 、セ を利用するためにも、仕様の策定段階からセキュリテ ミ コ ロ ン 自 動 挿 入 や JSON の 表 記 ゆ れ に 対 す る 許 容 に ィを考慮した設計と確認作業が必要である。 つ い て 最 近 の 実 装 を 反 映 し た 柔 軟 性 の 改 善 、 %演 算 子 のゼロ除算時の振る舞いなど技術的な記述の明確化、 5.3. 世 界 から見 た日 本 のおかしな標 準 URI の 扱 い の 最 新 RFC へ の 準 拠 な ど 技 術 的 な 改 善 を 提 日 本 の 12 時 間 表 示 の 慣 習 で 、 午 後 0 時 と い う も の 案した他、出典として参照すべき仕様の追加、仕様の が あ る が 、通 常 デ ジ タ ル 時 計 の 表 示 は 12:00PM で あ る 。 不整合箇所や誤記など編集上の指摘を行 った。 そ の た め 、国 際 化 を 意 識 し た ソ フ ト ウ ェ ア で は 、午 前・ 午 後 で は な く AM/PM 表 示 を 採 用 し て い る ( 図 13)。 5. Web 標 準 の 課 題 現 在 の Web ア プ リ ケ ー シ ョ ン の 動 作 の 根 幹 を な す JavaScript に 関 す る 言 語 仕 様 は 、W3C で は な く 、ECMA TC39 が ECMA-262 と し て 仕 様 の 策 定 を 行 っ て い る 。 Web Socket の JavaScript 側 API 5 は W3C が 策 定 し て い る が 、 Web Socket の 通 信 プ ロ ト コ ル は IETF が 策 定 に 関 与 し て い る 6 。 HTML5 や 関 連 API は 基 本 的 に W3C が 策 定 し て い る が 、WaSP や WHATWG の よ う に 別 団 体 も 過 去 に 存 在 し て い た 。現 在 の Web 標 準 の 規 格 は 一 つ の団体が主導して決めているものではない。実装の追 認も含め、現実と理想のバランスを取りながら標準化 図 13: 日 時 表 示 の ロ ケ ー ル 設 定 画 面 を進めているのが現状である。複数の団体が将来のイ ンターネットのビジョンを共有し、同じ目的を持って 協調しながら仕様を策定していく必要がある。 日本の標準化の甘さが露呈した事件もあった。世界 か ら 見 る と 日 本 の ロ ー マ 字 の 標 準 は ISO 3602:1989 で あ る 。 こ れ は 「 富 士 通 」 を 「 HUZITU」 と 表 記 す る こ 5.1. Web 制 作 現 場 への標 準 化 教 育 Web 制 作 の 現 場 で は 未 だ に CSS ハ ッ ク と 呼 ば れ て い る 手 法 ( 図 12) が 使 わ れ て い る 。 ブ ラ ウ ザ 毎 に CSS とになり、ヘボン式に慣れている日本人には受け入れ が た い 。こ れ は Web サ イ ト 所 有 者 の 法 的 実 在 性 を 証 明 す る EV SSL の 標 準 化 に お い て 問 題 と な っ た [7]。 の適用範囲や見栄えが異なるため、字句解析器の 例外 に依存した形で条件分岐を記述するという手法である。 body { color: red; /* all browsers */ color: green¥9; /* IE6,7,8 */ *color: yellow; /* IE6,7 */ _color: orange; /* IE6 */ } 図 12: CSS ハ ッ ク と 呼 ば れ る 分 岐 手 法 これはブラウザの実装に依存した形で、将来の動作 が保証されたものではない。また、各ブラウザでの表 示確認に余計な時間と手間がかかってしまう。今後 HTML5 と CSS2.1 の 普 及 と 制 作 現 場 へ の 教 育 に よ っ て 、 こ の よ う な CSS ハ ッ ク が 不 要 に な る こ と が 望 ま し い 。 6. さ い ご に Web の 技 術 は 変 化 が 早 く 標 準 策 定 の サ イ ク ル が 速 い 。 最新の標準動向に敏感な若い世代の人材を標準化団体 の中に取り込んでいく施策も必要であると考える。 参考文献 [1] W3C, 2011, HTML5 A vocabulary and associated APIs for HTML and XHTML( Working Draft) http://www.w3.org/TR/html5/ [2] @IT, 2010, W3C は 賞 味 期 限 切 れ 組 織 ? http://www.atmarkit.co.jp/news/analysis/201001/19/w3c.html [3] Rob Larsen, 2011, ECMA-262 第 5 版 最 新 の JavaScript 仕 様 に 関 す る 調 査 htt p ://www. ib m.co m/ deve loperwork s/jp/web/ library/wa -ec ma262/ 5.2. Web セキュリティの問 題 近 年 の サ イ バ ー 攻 撃 で も Web シ ス テ ム が 攻 撃 の 対 象 と な っ て い る 。Web ブ ラ ウ ザ や Web ア プ リ ケ ー シ ョ ンのセキュリティはこれから益々重要となる。実装の ミ ス だ け で は な く 、 CSRF の よ う に 仕 様 上 の 欠 陥 も 脆 5 6 http://www.w3.org/TR/websockets/ http://tools.ietf.org/html/rfc6455 [4] 2007, Proposed ECMAScript 4th Edition http://www.ecmascript.org/es4/spec/overview.pdf [5] Chris Wilson, 2007, What I think about ES4. http://blogs.msdn.com/b/cwilso/archive/2007/10/31/ what-i-think-about-es4.aspx [6] 情 報 処 理 学 会 , 2012, 第 53 回 プ ロ グ ラ ミ ン グ シ ン ポ ジ ウ ム 予 稿 集 pp.171-176 [7] 秋 山 卓 司 , 2009, EV SSL こ ぼ れ 話 (ISO 3602:1989 の罠) http://yet2come.jp/2009/01/ev-ssl-iso-3602.html
© Copyright 2024 Paperzz