ホームページの問題点とサーバ処理の基本と必要性

サーバ処理について説明します。

下記のように、商品一覧を表形式で出力しているホームページがあるとします。

商品マスタ
商品コード商品名単価
1ペン100
2ノート100

サーバ処理でhtmlファイルをそのまま出力している場合は、新たに商品を追加したり、商品の値段が変わるごとに、htmlファイルを書き換えなければなりません。

<!DOCTYPE HTML>
<html>

<head>
  <title>商品マスタ</title>
  <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
</head>

<body>
  <table class="common-table">
    <caption>商品マスタ</caption>
    <thead>
      <tr>
        <th>商品コード</th>
        <th>商品名</th>
        <th>単価</th>
      </tr>
    </thead>
    <tbody>
    <!-- ↓この部分を商品の状態によって随時更新しなければならない -->
      <tr>
        <td>1</td>
        <td>ペン</td>
        <td>100</td>
      </tr>
      <tr>
        <td>2</td>
        <td>ノート</td>
        <td>200</td>
      </tr>
    <!-- ↑この部分を商品の状態によって随時更新しなければならない -->
    </tbody>
  </table>
</body>
</html>

商品データの件数分、明細の箇所を出力するように、サーバ側でプログラムを作成しておけば、商品の状態に応じてhtmlファイルを変更することなく、最新の商品の状態を表示することができます。

htmlファイルでは、サーバでプログラムを実行できません。

  • サーバに置いてあるhtmlファイルをaspファイルなど、プログラムを実行できるファイルに置き換えます。
  • サーバ側でプログラムを実行し、レスポンスするhtmlデータを作成します。
  • レスポンスされたあとは、htmlの場合と同じように、ブラウザに表示します。

サーバ側のプログラミング言語にはいろいろなものがありますが、今回はaspを使用して説明します。

aspの基本的な文法aspの基本的な文法について説明します。

データベースから商品を取得して出力するサーバ処理を組み込んだaspファイルは下記のようになります。

<!DOCTYPE HTML>
<html>

<head>
  <title>商品マスタ</title>
  <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
</head>

<body>
<% response.write("テスト:サーバ処理で出力") %>
  <table class="common-table">
    <caption>商品マスタ</caption>
    <thead>
      <tr>
        <th>商品コード</th>
        <th>商品名</th>
        <th>単価</th>
      </tr>
    </thead>
    <tbody>
<%
  dim Conn,Rs,strSql
  set Conn = Server.CreateObject("ADODB.Connection")
  set Rs = Server.CreateObject("ADODB.Recordset")
  Conn.Open "接続文字列"
  strSql = "SELECT 商品コード, 商品名, 単価 FROM 商品マスタ"
  Rs.ActiveConnection = Conn
  Rs.Open strSql,Conn,3,1
  If Not Rs.EOF Then
    Do While Not Rs.EOF
      '1件ずつ出力する
      response.write("<tr><td>" & Rs("商品コード") & "</td><td>" & Rs("商品名") & "</td><td>" & Rs("単価") & "</td>")
      Rs.MoveNext
    Loop
  End If

  Rs.Close
  Conn.Close
%>
    </tbody>
  </table>
</body>
</html>

サーバ処理を行い、実際にレスポンスされるhtmlは下記のようになります。

<!DOCTYPE HTML>
<html>

<head>
  <title>商品マスタ</title>
  <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
</head>

<body>
  テスト:サーバ処理で出力
  <table class="common-table">
    <caption>商品マスタ</caption>
    <thead>
      <tr>
        <th>商品コード</th>
        <th>商品名</th>
        <th>単価</th>
      </tr>
    </thead>
    <tbody>
<tr><td>1</td><td>ペン</td><td>100</td>
<tr><td>2</td><td>ノート</td><td>200</td>
    </tbody>
  </table>
</body>
</html>

関連記事

  • WEBアプリの基本的な仕組みと考え方

    WEBアプリの基本的な仕組みを説明します。まずは、WEBアプリで頻繁に登場する用語の説明を交えながら、ホームページの仕組みについて復習します。わかりやすくするためにかなり噛み砕いて説明しているため、実...


  • サーバ処理でクライアントからの情報を取得する方法

    クライアント側からサーバ側への送信処理は実装できたので、次はサーバ側でデータの登録を行う処理を実装します。まず、サーバ処理でデータの登録処理を実装しますが、その際、最初の初期表示としてアクセスされたの...


  • 登録時にクライアントとサーバでデータの入力チェックを行う方法

    誤って不正なデータを登録してしまうのを防ぐために、ユーザが入力した内容をチェックする処理を実装します。商品名と単価が未入力の場合と、同じ商品名がすでに登録されていた場合はアラートでエラーメッセージを表...


  • ホームページの基本的な仕組みと考え方

    はじめに、ホームページの基本的な仕組みを説明します。どちらもWEB上にあり、ウェブブラウザを用いて閲覧します。両者の違いはというと、厳密に定義されているわけではないと思いますが、ホームページとは基本的...


  • GETとPOSTの違い

    formのmethod属性には、GETとPOSTの2種類があります。method属性では送信(リクエスト)の方法を指定しています。何も指定しない場合はGETで送信されます。URLを入力して直接画面遷移...


  • 地附山で自然に触れ合い心も体もリフレッシュ

    日常から抜けだして、自然に触れて心も体もリフレッシュしたいなら、長野県の地附山がおすすめです。トレッキングというよりもハイキングのような感じで、登山装備もいらずに気軽に歩けるのでおすすめスポットです。...


  • 須坂市の絶景スポット米子大瀑布の紹介

    8月の新緑の季節に行ってきました長野県須坂市の米子大瀑布の、壮大な自然が絶景でとても感動したので紹介します。米子大瀑布は、須坂市の山中にある2つの滝です。米子大瀑布にあるこれらの滝は日本の滝百選に選ば...


  • WOWOWを自動音声通話で解約したが翌月になっても見れてしまったとき

    WOWOWの解約は電話で行いますが、回線が混み合っているときは自動音声案内で解約することができます。先月、WOWOWを解約するときに、自動音声案内で解約したのですが、翌月の1日に一応「ちゃんと解約でき...


  • WOWOWはチューナーやアンテナ不要ですぐに見れます

    私の周りでは見たいけど番組があるがWOWOWを契約するのを迷っている人が結構います。チューナーやアンテナなどを設置になければ見られないと思っている人や、申込み後に何週間も待たないと見られないと思ってい...


  • Windows7から10に無料でアップグレードする手順(2019年12月更新)

    Windows 7のサポート終了が2020年1月に迫っています。私の周りではWindows 10の新しいパソコンに買い換える人が多いですが、実はWindows 7から10に無料でアップグレードすること...