目次
1. なぜ、新人エンジニア研修でWebアプリケーションを学ぶのか?
当社の新人エンジニア研修でWebアプリケーションを学ぶ理由は以下の3点です。
- これまで学んできたJavaプログラミング、ネットワークとHTML、データベース全ての総復習になる
- Webアプリはデスクトップアプリよりも今後の成長が期待できる(参考リンク)
- 仮にWebアプリの仕事につかないとしてもセキュリティなど利用者の視点から学ぶことも多い
2. Webアプリケーションとは?
最近インターネットに接続しなかった日のことを思い出してみてください。
なかなか答えられない質問だったかもしれません。
では、インターネットで我々はどのようなことをしているでしょうか?
グーグルで調べ物をする
オンラインショッピングをする
SNSで友達と交流する
これらは皆、Webアプリケーションを使って実現できることなのです。
手前味噌になりますが、皆さんがいまお読みいただいている弊社のWebサイトも検索機能や編集機能があるWebアプリケーションです。
Webアプリケーションとは、ウェブすなわちWorld Wide Web技術を基盤としたアプリケーションソフトウェアのことです。
私達はすでにHTMLを学んでWebページを作成しました。
それらのWebページとこれから学ぶWebアプリケーションとは何が違うのでしょうか?
以前作成したWebサイトは静的サイトとも呼ばれます。
静的サイトは、HTMLとCSS等で構成された単なるファイルで、サーバーを通してクライアントにレスポンスされることで、ブラウザで表示されるものでした。
静的サイトは誰がいつアクセスしても同じファイルを送信します。
一方これから学ぶWebアプリケーションは動的サイトを提供します。
動的サイトは誰がいつアクセスするかによって異なるファイルを送信します。
動的サイトは、クライアントからリクエストがあった場合、サーバーでコンテンツを生成して、リクエストの内容に合わせてレスポンスを返すのです。
インターネットに接続されたブラウザさえあれば使えるため、いつでもどこからでもサービスを利用できます。
先に挙げた、サーチエンジン、オンラインショッピング、SNSなどはいずれもWebアプリケーションです。
2.1. Webアプリケーションの構成
当社の新人エンジニア研修で作成するWebアプリケーションの構成を下図1.1に紹介します。
クライアントとしてのWebブラウザ、アプリケーションサーバ、データベースサーバの3つで構成します。
クライアントサイドはすでにHTMLで、データベースサーバはすでにMySQLで学びました。
そのため今回はアプリケーションサーバの部分を学ぶことになります。
アプリケーションサーバはOSとコンテナとJSP/Servletの3つから成ります。
皆さんの場合OSはWindowsです。
コンテナ【container】には今回はGlassfishを使います。
コンテナとはJavaサーブレットを実行する際に必要となる実行環境です。
皆さんはトラックや船に乗ったコンテナを見たことがありますか?
何かを乗せるのがコンテナです。
私達はJavaSEでmainメソッドを学びました。
プログラムのエントリポイントでしたね。
ところがこれから学ぶサーブレットにはmainメソッドがありません。
新人エンジニアの皆さんが面喰らうところです。
実は、コンテナにmainメソッドがあって、そこからサーブレットのメソッドが呼び出されるのです。
また、アプリケーションサーバのJavaプログラムとMySQLがデータをやり取りするためにはJDBCが必要になってきます。
そしてここがイメージしにくいところですがこれら3つの役割を皆さんの1台のパソコンが担います。

本番の環境では、クライアントはもちろん、アプリケーションサーバとデータベースサーバでマシンを分けることもあります。
しかし、今回は1台3役ということでそれぞれの役割をしっかりイメージしながら学習するようにしてください。
実験1
ここで少し実験をしてみましょう。
ブラウザのアドレスバーに以下のように入力してエンターしてみてください。
「http://localhost:8080/」
下図1.2と図1.3どちらの表示になりましたか?


何が違うのでしょうか?
- localhostと8080の意味について調べてみましょう。
講師の説明: |
3. 本Webアプリケーション研修の方針
私達が今まで学んできたJavaはJavaSE【Java Platform, Standard Edition】でした。
これからはJavaEE【Java 2 Enterprise Edition】といって、サーバ向けや大規模システム向けの高度な機能を学んでいきます。
とはいえ、 JavaEEは、Java SEの拡張版ですので今まで学んだ JavaSEがその基礎にあります。
ここでこの研修の方針です。
- JavaEEの一部の機能のみを学びます
- 当社のシステム開発演習に必要な部分のみを学びます
- システム開発を経験するための道具としてJavaEEを使います。
なぜなら、皆さんが実務についてもJavaEEを使うとは限らないからです。
また、JavaEEの体系は膨大なので、そのほんの一部しか研修では触れられないからです。
さらにはJavaEEの詳細を知ることよりもhttpプロトコルの詳細を知るほうが長く活かせる知識になるからです。
とはいえ、フレームワークを使わずにゼロから作りますのでWebアプリケーションの仕組みがよく理解できるようになります。
現代の大工さんが木を切り出すところから家造りを始めないように、現代のITエンジニアも0からシステムを作ることは殆どありません。
しかし、大工さんが金槌やノコギリを使えないと困るように、ITエンジニアも基本を抑えておくことは非常に重要です。
その意味で貴重な体験になるものと思います。
この記事では、前半はJavaSEでもやった数あてゲームを、後半はシステム開発演習にもつながる自動車のオンラインストアを題材にします。
4. Webアプリケーションの学び方
ここで改めてプログラミングの学び方の留意点です。
プログラミングを覚えようとしてはいけません。
例えば、皆さんは以下の計算ができますか?
42 + 123 =
では、上記の計算を過去にやったことはありましたか?
算数を学んだとき足し算のコンセプトを学んだらどんな足し算もできるようになりましたね。
プログラミングも同じです。
理解すべきはコンセプトであり、詳細な文法ではありません。
一旦コンセプトを覚えれば、あとは応用すればよいだけです。
現代ではインターネット検索もIDEの補完機能もあなたを味方してくれています。
ただし、算数の九九のように覚えた方が便利なことがあることは否定しません。
5. 本記事の注意点
最後にこの記事の注意点です。
- アウトプット中心
- リファレンスを目指さない
- 他教科との連携
アウトプット中心ですから読んだだけでは身につきません。
かならず手を動かして、最初はコピーペーストでもいいので実際にお手元のPCでプログラミングしてください。
特にこの記事では変化しやすいHOWよりも変化しにくい原理原則を中心にお話したいと思います。
つまり、JavaEEの独自ルールの解説は最低限にとどめて、HTTPプロトコルなどのルールを充実させるという方針です。
また、リファレンスとして全ての文法事項を網羅することも目指しません。
リファレンス的知識はインターネットで調べればよいのです。(例. Jakarta EE 8 仕様 API )
調べて、実験して、また調べ倒す気概があればエンジニアだけでなくどんな仕事についても大丈夫でしょう。
本記事には以下のような実験コーナーも設けています。
実験1
実験は必ずしもやらなくても研修に大きな支障はありません。
しかし、一度試してみるとより良くWebアプリケーションのことが理解できるテーマを選んでいます。
対して以下のような練習問題はアウトプットの機会です。
例題1
手だけでなく頭も動員することで記憶に定着しますから必ずやってください。
記憶の定着のためには紙とペンを使って書き込むことも有効です。
ところどころに以下のような書き込み欄を設けているのはそのためです。
あなたの答え: |
今回はWebアプリケーションについて学びました。
また、今後の学習の指針を示すこともいたしました。
次回は、 MVCモデル について学びます。
このMVCモデルを学ぶことが本研修のゴールになります。