<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
   <channel>
      <title>システム開発のアイロベックス　フィード</title>
      <link>http://www.ilovex.co.jp/</link>
      <description></description>
      <language>ja</language>
      <copyright>Copyright 2010</copyright>
      <lastBuildDate>Thu, 02 Sep 2010 10:56:00 +0900</lastBuildDate>
      <generator>http://www.sixapart.com/movabletype/</generator>
      <docs>http://blogs.law.harvard.edu/tech/rss</docs> 

      
      
      <item>
         <title>MySQLでテーブルの修復を行う</title>
         <description><![CDATA[Access2007よりMySQLのデータベースを参照していたところ、
以下のエラーメッセージが表示されました。

「このフォームまたはレポートで指定されているレコードソース'クエリ名'が存在しません。」

エラーの示す通りクエリ自体が存在しない、
または名前がフォームで指定しているものと違っているのではないかと確認しましたが、
クエリはAccess内に存在していましたし、名前も一致していました。

よく確認してみると、クエリ内で使用しているテーブルの1つが壊れているのが原因でした。
そこでMySQLの以下のコマンドを使用してテーブルのチェックと修復を行いました。

●テーブルのチェック

CHECK TABLE [テーブル名];

テーブルが正常な場合は以下のように表示されます。

-------ここから-------

<pre class="code" name="xml">
+---------------------------+-------+----------+----------+
| Table                     | Op    | Msg_type | Msg_text |
+---------------------------+-------+----------+----------+
| DatabaseName.TableName    | check | status   | OK       |
+---------------------------+-------+----------+----------+
1 row in set (0.05 sec)
</pre>

-------ここまで-------

上記項目は以下のようになっています。

Table...チェックしたデータベース名とテーブル名
Op...常に'check'
Msg_type...現在の状態
Msg_text...説明文

上記以外の表示がされた場合はテーブルが壊れている可能性があるので、
修復が必要になります。

●テーブルの修復

REPAIR TABLE [テーブル名];

修復を行った後にもう一度テーブルのチェックを行います。
以下のように表示されればテーブルの修復成功です。

-------ここから-------

<pre class="code" name="xml">
+---------------------------+-------+----------+----------+
| Table                     | Op    | Msg_type | Msg_text |
+---------------------------+-------+----------+----------+
| DatabaseName.TableName    | repair| status   | OK       |
+---------------------------+-------+----------+----------+
1 row in set (0.05 sec)
</pre>

-------ここまで-------

<注意>
テーブルの修復を行う際は、失敗したときに備えて
バックアップをとるなどの対応が必要です。

]]></description>
         <link>http://www.ilovex.co.jp/blog/system/industrysystem/mysqlde.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/industrysystem/mysqlde.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">030_産業システム部</category>
        
        
         <pubDate>Thu, 02 Sep 2010 10:56:00 +0900</pubDate>
      </item>
      
      <item>
         <title>Google Mapを画像にして貼りつけられるAPI</title>
         <description><![CDATA[<b>Google Mapを画像としてホームページに埋め込む方法です。</b>

一般的に使われている<a href="#iframe">iframeで表示する方法※1</a>では、
ひとつのページに複数のMapを貼りつけたときにページの読み込みが遅くなってしまいます。
たとえMapひとつだけだとしても、わずかな表示のタイムラグが気になる方もいるでしょう。

そういった場合にこのAPIが活躍します。
APIの詳細は、<a href="http://code.google.com/intl/ja-JP/apis/maps/documentation/staticmaps/" target="_blank">Google code「Static Maps API デベロッパー ガイド」</a>をご覧いただければ良いですが、手っ取り早く作るには次のページをご利用ください。

「Google Static Maps ウィザード」
<a href="http://ajax.appspot.com/gmaps-samples/simplewizard/makestaticmap.html" target="_blank">http://ajax.appspot.com/gmaps-samples/simplewizard/makestaticmap.html</a>

ソースのkey&#61;の後ろには、<a href="http://code.google.com/intl/ja-JP/apis/maps/signup.html" target="_blank">APIキー</a>を入れます。
APIキーはGoogleアカウントでログインした状態で、ホームページのURLを入力すれば取得できます。

ソースはimgタグで記述します。→&#60;img src&#61;&#34;生成されたURL&#34; &#47;&#62;
imgタグなのでaltも入れられます。

<b>＜完成サンプル＞</b>
<img src="http://maps.google.com/staticmap?center=35.691391,139.703543&markers=35.693154,139.705824,red&path=rgba:0x0000FF80,weight:5|35.69315,139.70582|&zoom=16&size=350x300&key=ABQIAAAA12H8DhPaMNuk4Pk-e3YZYBSAEgcGe_nXJSe8MzFvpwsyVG3smRSjgCBhjTKipS2QhDBbbCfcRJYUrg" alt="株式会社アイロベックス" />
<a href="http://maps.google.co.jp/maps?f=q&source=s_q&hl=ja&geocode=&q=%E3%82%A2%E3%82%A4%E3%83%AD%E3%83%99%E3%83%83%E3%82%AF%E3%82%B9&sll=35.691417,139.704841&sspn=0.00569,0.009806&brcurrent=3,0x60188cdc1d00b42d:0x2b06aa45928dbab5,0&ie=UTF8&hq=%E3%82%A2%E3%82%A4%E3%83%AD%E3%83%99%E3%83%83%E3%82%AF%E3%82%B9&hnear=&ll=35.693151,139.706333&spn=0.010944,0.019612&z=16&iwloc=A" target="_blank">地図をGoogle Mapで見る</a>



【ご注意】
<a href="http://code.google.com/intl/ja-JP/apis/maps/documentation/staticmaps/" target="_blank">Google code「Static Maps API デベロッパー ガイド」</a>にも同じようにリンクURLを作成してくれるページを紹介していますが、そこで作成すると画像が表示できませんでした。
これは赤字の部分が原因でした。

誤）http://maps.google.com/<span style="color:red;">maps/api/</span>staticmap&#38;center=.....
正）http://maps.google.com/staticmap&#38;center=.....


また、Mapのキャプチャを撮影して使用すると著作権侵害になりますが、Google Mapの規約では、APIから取得した情報をそのまま使用する場合は問題ないそうです。（Googleへ確認済み）



<a name="iframe"></a>※1　iframeで貼り付ける方法

Google Mapの画面右上の「リンク」ボタンからHTMLソースを取得します。
<span class="mt-enclosure mt-enclosure-image" style="display: inline;"><a href="http://www.ilovex.co.jp/blog/system/assets_c/2010/09/googlemaps-341.html" onclick="window.open('http://www.ilovex.co.jp/blog/system/assets_c/2010/09/googlemaps-341.html','popup','width=1297,height=720,scrollbars=no,resizable=no,toolbar=no,directories=no,location=no,menubar=no,status=no,left=0,top=0'); return false"><img src="http://www.ilovex.co.jp/blog/system/assets_c/2010/09/googlemaps-thumb-300x166-341.jpg" width="300" height="166" alt="googleMaps" class="mt-image-none" style="" /><br />※クリックすると拡大します</a></span>
]]></description>
         <link>http://www.ilovex.co.jp/blog/system/webconsulting/google-mapapi.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/webconsulting/google-mapapi.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">051_Webコンサルティング部</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">Google Apps</category>
        
        
          <category domain="http://www.sixapart.com/ns/types#tag">API</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">google</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">Google Apps</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">Google Maps</category>
        
         <pubDate>Wed, 01 Sep 2010 21:19:55 +0900</pubDate>
      </item>
      
      <item>
         <title>ADO接続文字列で、PROVIDER=SQLNCLIを使用する</title>
         <description><![CDATA[ASP(VBScript)のWebシステムで、SQLServer2005に接続するシステムを開発しました。

DBはミラーリングされるので、接続文字列を以下のように設定しました。


"PROVIDER=SQLNCLI;USER ID=[ID];PASSWORD=[Password];INITIAL CATALOG=[DB];Server=[サーバ]Failover Partner=[フェイルオーバーサーバ]"


「PROVIDER=SQLNCLI」の「SQLNCLI」は、SQL Native Client OLE DB プロバイダのことで、
SQLServer2005の新機能を使用したい場合に指定します。

この接続文字列で、DBにも接続出来、フェイルオーバー発生時には
DBが切り替わったのですが、システム内でストアドを実行する処理で、
エラーが発生してしまいました。

<pre name="code" class="vb">
	Set cmd = Server.CreateObject("ADODB.Command")
	Set cmd.ActiveConnection = goConn
	
	With cmd
		.CommandText = [ストアド名]
		.CommandType = adCmdStoredProc
		
		.Parameters.Refresh
		.Parameters("@Param") = Param
		
		.Execute ln, , adExecuteNoRecords		'※←エラー発生行
	End with
</pre>

エラー内容：
　　ADODB.Command (0x800A0E7C)
　　Parameter オブジェクトが適切に定義されていません。
　　矛盾した、または不完全な情報が提供されました。


これを解決するには、上記の接続文字列に、
「DataTypeCompatibility=80」を追加する必要があります。


"PROVIDER=SQLNCLI;USER ID=[ID];PASSWORD=[Password];INITIAL CATALOG=[DB];Server=[サーバ]Failover Partner=[フェイルオーバーサーバ];DataTypeCompatibility=80"


「DataTypeCompatibility」は、使用するデータ型処理モードを指定し、
プロバイダ データ型の "0" または、SQL Server 2000 データ型の "80" を指定できるようです。

MSDNによると、

　　SQL Native Client を使用できるようにするには、
　　ADO アプリケーションで、接続文字列に次のキーワードを実装する必要があります。

ということなので、「PROVIDER=SQLNCLI」を指定する場合は、
「DataTypeCompatibility=80」をセットにして記述する必要があるようです。

詳しくは、下記のページでご確認ください。

＜参考＞
SQL Native Client と ADO の併用
<a href="http://technet.microsoft.com/ja-jp/library/ms130978(SQL.90).aspx">http://technet.microsoft.com/ja-jp/library/ms130978(SQL.90).aspx</a>

SQL Native Client での接続文字列キーワードの使用
<a href="http://technet.microsoft.com/ja-jp/library/ms130978(SQL.90).aspx">http://technet.microsoft.com/ja-jp/library/ms130822(v=SQL.90).aspx</a>
]]></description>
         <link>http://www.ilovex.co.jp/blog/system/softwaredevelopment/adoprovidersqlncli.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/softwaredevelopment/adoprovidersqlncli.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">040_ソフトウエア開発部</category>
        
        
         <pubDate>Wed, 01 Sep 2010 11:45:44 +0900</pubDate>
      </item>
      
      <item>
         <title>タスクスケジューラを設定する時の注意点</title>
         <description><![CDATA[みなさん、こんにちは。
流通システム部の赤羽です。

Windows Vista 以降、タスクスケジューラの設定画面が大きく変化しました。
先日、タスクスケジューラを使用してバッチプログラムを実行するときに、
悩んだことがありましたので、そのことについてお話いたします。

Windows Vista 以降のタスクスケジューラでプログラムを動作させる場合、
注意しなければならないことがあります。
それは「作業フォルダ」の設定です。

動作させるプログラムが、別のファイルを参照する場合
(例えば同じ階層にあるEXEファイルを実行し、その結果を基に動作するプログラム等)、
作業フォルダの設定を行わないと、参照先のファイルが見つけられず、
エラーが発生してしまいます。

作業フォルダの設定は、タスクスケジューラの編集画面の「操作」タブから
実行したいプログラムを選択する画面の、「開始」のテキストボックスに入力します。
(下図参照)

<span class="mt-enclosure mt-enclosure-image" style="display: inline;"><img alt="task.jpg" src="http://www.ilovex.co.jp/blog/system/img/task.jpg" width="458" height="493" class="mt-image-none" style="" /></span>

まさか「開始」が作業フォルダの設定だとは思わず、随分悩みました。
皆さんもタスクスケジューラの設定を行うときには、注意してみてください。]]></description>
         <link>http://www.ilovex.co.jp/blog/system/distributionsystem/post-36.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/distributionsystem/post-36.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">020_流通システム部</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">Windows</category>
        
        
          <category domain="http://www.sixapart.com/ns/types#tag">Windows</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">タスクスケジューラ</category>
        
         <pubDate>Tue, 31 Aug 2010 21:49:50 +0900</pubDate>
      </item>
      
      <item>
         <title>いまさら気付いたこんなExcelショートカットキー</title>
         <description>皆さん、こんにちは。
実は私、恥ずかしながら社会人になるまで、
ショートカットキーをほとんど使ったことがありませんでした。

全く気にせずExcelやWordを使っていましたが、
ある表のデータを日々更新するような作業で、やたらと時間がかかるなと思ったのです。

そこで今回は、もっと早く知っておけばよかったと感じた
ショートカットキーを紹介します。

1.「F2」
セル内を編集する場合に使います。
入力済みのセルに追加入力を行いたい場合、マウスでダブルクリックせずに、
F2だけでセル内を編集出来ます。
これを知っていればExcelでの編集がかなり楽になると思います。

2.「Ctrl + 1」
「セルの書式設定」のダイアログを呼び出せます。
やはりExcelを使っていると、セルに罫線や色をつけることが多いと思います。
マウスで右クリックしなくても一発でダイアログを呼べるので便利です。

3.「Ctrl + +」、「Ctrl + - 」
セルを追加（+）、削除（-）することが出来ます。
押した後にどちら側にシフトするかも表示されますので、
マウスで右クリックした時と同じように使えます。

今回紹介したショートカットを使うようになってから、
Excelの使用中にマウスを触る時間が半分くらいに減りました。

作業時間もマウスをあちこち動かすより短くなったので、
使ったことのなかった方はぜひお試しください。</description>
         <link>http://www.ilovex.co.jp/blog/system/webconsulting/excel-shortcut.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/webconsulting/excel-shortcut.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">051_Webコンサルティング部</category>
        
        
          <category domain="http://www.sixapart.com/ns/types#tag">Excel</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">ショートカットキー</category>
        
         <pubDate>Tue, 31 Aug 2010 12:45:00 +0900</pubDate>
      </item>
      
      <item>
         <title>MTコンテスト2010　9/9まで応募受付中</title>
         <description><![CDATA[Movable Typeで作成されたサイトのコンテスト「Movable Type コンテスト 2010」が現在開催中です。

弊社が<a href="http://www.ilovex.co.jp/info/event/2008/05/post_13.html" target="_blank">アスキー賞を受賞</a>した2007年以来3年ぶりの開催となる今年は、多くのエントリーが集まっているようです。
今年はスポンサーとして弊社も参加させていただいています。

Movable Typeで構築されたサイトならどのサイトでも応募資格があります。
エントリーの締め切りもあとわずかですのでお早めにご応募ください。


■<a href="http://www.mtcontest.jp/" target="_blank">Movable Typeコンテスト 2010</a>
<div style="border:solid 1px #CCCCCC; width:400px;"><a href="http://www.mtcontest.jp/" target="_blank"><img alt="Movable Type コンテスト2010" src="http://www.ilovex.co.jp/blog/system/2010/08/31/img/mtcontest2010.jpg" width="400" height="268" class="mt-image-none" /></a></div>

【エントリー受付】・・・2010年6月9日（水）～2010年9月9日（木）
【応募方法】・・・・・・専用応募フォームより登録（オンラインのみ）
【結果発表】・・・・・・2010年10月下旬に受賞者にメールにて通知、また公式サイトで発表

]]></description>
         <link>http://www.ilovex.co.jp/blog/system/webconsulting/mtcontest2010.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/webconsulting/mtcontest2010.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">051_Webコンサルティング部</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">Movable Type</category>
        
        
          <category domain="http://www.sixapart.com/ns/types#tag">MovableType</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">MT3</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">MT4</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">MT5</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">コンテスト</category>
        
         <pubDate>Tue, 31 Aug 2010 08:06:23 +0900</pubDate>
      </item>
      
      <item>
         <title>保守にやさしいコメントを書く</title>
         <description>プログラミングを行ううえで、プログラムソースにコメントを
記載するのは当たり前だと思います。
先日、過去のソースコードを見る機会があり、
なるほどと思うことがあったのでご紹介したいと思います。

１）使用している技術についての解説、リファレンスマニュアルへのURL等が記載してあった。
　 またそれを使用している理由等についてもコメントで述べられていた。
　
 　 本来であれば、このようなことはドキュメントに記すべきだと思いますが、
 　 ドキュメントが一切ない場合には、まずソースコードを見ることになります。
　
　 開発当初は、開発初期メンバーが絡んでいることが多く、
　 採用した技術を選定したメンバーがいるため、なぜそれが使われているのか？
 　 なぜ他のものを採用しなかったか？
 　 などその人に聞かなければわからないことが多々あります。
　
　 後で保守する身になって考え付く理由は、
 　 「きっとそれが最適だと思ったんだろう」ぐらいしかわかりません。

　 実は、バージョンの組み合わせ、他のミドルウェアとの組み合わせにより
　 問題があったため、いろいろ検証した結果、現在使用しているものだけが
　 最終候補として残ったのかもしれません。
　 そのようなことが、後から保守する担当者が想像しうるでしょうか？

２）ロジックの理由、特別な書き方をしている理由が述べられていた。

　 ソースコードの書き方が、わざと無駄なことをしているように見受けられる場合でも、
　 実は重要な処理、何か問題を回避するための施策を行っていることがあります。
　 それなのに、保守・改善等を求められた際、「ここが無駄な処理しているな～」
　 という安易な考えで、無駄な処理を取ってしまったばかりに、
 　 後々大問題になるといったことがあります。
　
 　 これらを回避するためには、なぜそのような書き方をしているのかの、
 　 理由（言い訳）を書いておくと後で、他の人がソースコードを見た際に、
 　 「○○の問題があるから、仕方なくそうなっているんだな」と納得することができ、
 　 安易に手を加えて大問題ということが避けられます。
　

逆に保守にやさしくないコメントをひとつだけ紹介します。
開発者の方であれば、間違いなく納得してくれると思いますが、
ウソが書いてあるコメントが本当に困ります。
コメントがウソなのか、コメントのとおりに実装しようとしたが
記述ミス、プログラムミスによりバグが混じっているのか、まったく見分けがつきません。

コメントには何をしているかと書くことも重要ですが、
なぜそうなっているのかを書いてくれたほうが開発者にとっては助かります。
何をしているかは、ソースコードを読める開発者であれば（普通読めますよね）
見ればわかることですから、書いてくれれば助かりますが、
ないことが致命的なことを招くわけではありません。


ちなみに弊社では、コメントを書くルールがコーディング規約で決まっており、
ソースチェックなども行っているので、コメントなしのプログラム等はありませんので
ご安心ください。
　</description>
         <link>http://www.ilovex.co.jp/info/ilo_week/2010/08/post-243.html</link>
         <guid>http://www.ilovex.co.jp/info/ilo_week/2010/08/post-243.html</guid>
        
        
         <pubDate>Mon, 30 Aug 2010 12:00:00 +0900</pubDate>
      </item>
      
      <item>
         <title>PEAR::HTTP_Requestのmulti-partについて</title>
         <description>先日、PEAR::HTTP_Requestを用いてリクエストを投げるプログラムを実装したのですが、
Content-Typeをmulti-part/form-data設定した場合に、いろいろとはまったことを書きます。

まずは、リクエストを投げるため、以下のように実装しました。

// HTTP_Requestの初期化
$request = new HTTP_Request(&quot;リクエストを投げるURL&quot;);

// HTTPのヘッダー設定
$request-&gt;setMethod(HTTP_REQUEST_METHOD_POST);
$request-&gt;addHeader(&quot;Content-Type&quot;, &quot;multi-part/form-data&quot;);

// リクエスト送信
$result = $request-&gt;sendRequest();


ひとまず、上記でリクエストを投げることが出来ますが、
これだけだと、Content-Type:multi-part/form-dataになりません。
「Content-Type:multi-part/form-data」と指定しているのにもかかわらず、
multi-part形式で送られないのです。


なぜかというと、Request.phpの969行目のコメントにこのような記述があります。

「multipart request, probably with file uploads」
「multipartのリクエストならば&quot;たぶん&quot;ファイルがあるであろう」というもの。

試しにファイルを添付したところ、multi-partで送られました。
$request-&gt;addFile(&quot;key&quot;, &quot;ファイルパス&quot;);

ファイルが無ければ、Content-Typeを指定していても、
multi-part形式にはならないのです。

今回実装したプログラムは、ファイルが無くても、
multi-partで送る必要がありましたので、
ファイルを添付することで対応しました。
※ファイルを添付していても影響がないことがわかっていたので、そのように対応しました。

ちなみに、ファイルを添付したとしても、
そのファイルが空の場合は、multi-partにならないので、ご注意を！
</description>
         <link>http://www.ilovex.co.jp/blog/system/projectandsystemdevelopment/pearhttp-requestmulti-part.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/projectandsystemdevelopment/pearhttp-requestmulti-part.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">060_企画開発部</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">PHP</category>
        
        
         <pubDate>Fri, 27 Aug 2010 14:00:00 +0900</pubDate>
      </item>
      
      <item>
         <title>VMware ESXi4上のSolaris10環境でVMware Toolsをインストールする</title>
         <description><![CDATA[みなさん、こんにちは。<br/>
<br/>
VMware Toolsをインストールするときは、解凍したファイルにあるvmware-install.plを実行することでインストールできますが、ESXi4上にSolaris10では途中で下記のエラーが発生する場合があります。<br/>
<br/>
<pre name="code" class="ruby" style="color:black;">
bash-3.00# ./vmware-install.pl
Installing VMware Tools.

（省略）

Starting VMware Tools services in the virtual machine:
   Switching to guest configuration:         done
   Guest memory manager:                     done
   Guest operating system daemon:            failed
Unable to start services for VMware Tools

Execution aborted.
</pre>
<br/>
<br/>
この場合は、以下のようにLANG=Cを最初に実行しておくことでエラーを回避することができます。<br/>
<br/>
<pre name="code" class="ruby" style="color:black;">
bash-3.00# LANG=C 
bash-3.00# ./vmware-install.pl
Installing VMware Tools.

（中略）

Starting VMware Tools services in the virtual machine:
   Switching to guest configuration:     done
   Guest memory manager:                 done
   Guest operating system daemon:        done

The configuration of VMware Tools 4.0.0 build-171294 for Solaris for this
running kernel completed successfully.

（中略）

Enjoy,

--the VMware team
</pre>
<br/>
<br/>
どうやら日本語環境ではエンコードに関する問題にひっかかってエラーになってしまうようです。<br/>
なので、LANG=C でロケールを英語モードにしてインストールするという意味になります。<br/>
]]></description>
         <link>http://www.ilovex.co.jp/blog/system/industrysystem/vmware-esxi4solaris10vmware-tools.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/industrysystem/vmware-esxi4solaris10vmware-tools.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">030_産業システム部</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">Linux</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">その他</category>
        
        
         <pubDate>Thu, 26 Aug 2010 13:11:06 +0900</pubDate>
      </item>
      
      <item>
         <title>IISのデータ量制限</title>
         <description>IISには、POSTする際のデータ量、
また、aspでページを描画する際のデータバッファ量に制限がかかっています。

POSTする際のデータ量というのは、
アップロードするファイルだけではなく、
input type=&quot;text&quot;等で入力された文字列のバイトデータ量も含まれます。

そうそうあることではないですが、
動的に件数を変更可能な明細登録画面などでは、
TEXT等のコントロールが数百～数千件になってしまうことがあります。

このような時、各コントロールに入力された文字が
半角で約20万5000文字（200KByte）を超えると、
Post処理を行った際にWebブラウザ上で
エラーコード「500 Internal Server Error」が発生します。

「500 Internal Server Error」だけではアバウトすぎて
完全にエラーを特定できないので、IISのログを確認します。
（C:\WINDOWS\system32\LogFiles\W3SVC1\exyymmdd.log）※yymmddはログの日付
このログに「ASP 0104」のエラーログがあれば、以下の要領で対応ができます。

これは、IISの「AspMaxRequestEntityAllowed」というプロパティが
デフォルトで204800バイトに設定されているため、
この制限を越えてデータ送信をしてしまったために発生するエラーです。

エラーを回避するためには、この制限値を上げる必要があります。

コマンドプロンプトからコマンドで設定変更も可能ですが、
この場合はIISの再起動が必要となってしまうので、
MetaBase.XMLを編集すると簡単に対応ができます。
ただし、必ずMetaBase.XMLのバックアップを必ずとり、
すぐにリカバリーできる状態で行ってください。

手順は以下のとおりです。
1.コントロールパネル→インターネットインフォメーションサービス→ローカルコンピュータ→プロパティ
2.「メタベースの直接編集を有効にする」にチェックを付ける
3.C\Windows\System32\inetsev\MetaBase.XMLを開く
4.AspMaxRequestEntityAllowedの値が&quot;204800&quot;なので、必要に応じて変更する。
  ※最大値は1,073,741,824です。

また、このエラーに遭遇した場合、
aspでページを描画する際のデータバッファ量の制限にも到達する恐れがあります。
こちらは、AspBufferingLimitという設定を変更することで対応できます。

AspMaxRequestEntityAllowedでエラーになった場合は、
AspBufferingLimitの設定も見直しておく方が後々の手間を減らせると思います。

Micrsoftの公式サポート情報は以下のとおりです。
http://support.microsoft.com/kb/327659/ja 
http://support.microsoft.com/kb/925764/ja</description>
         <link>http://www.ilovex.co.jp/blog/system/softwaredevelopment/iis.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/softwaredevelopment/iis.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">040_ソフトウエア開発部</category>
        
        
         <pubDate>Wed, 25 Aug 2010 20:27:08 +0900</pubDate>
      </item>
      
      <item>
         <title>Web SQL Databaseに触れる その2</title>
         <description><![CDATA[みなさん、こんにちは。
流通システム部の古郡です。

<a href='http://www.ilovex.co.jp/blog/system/distributionsystem/web-sql-database.html'>前回の記事</a>でWeb SQL Databaseについて簡単に説明しました。
今回は、実際のコードを使ってもう少し詳しく説明したいと思います。

以下のコードはページのロード時などにWeb SQL Databaseに接続し、
テーブルにデータがあれば取得して画面に表示するJavaScriptのコードです。

<pre name="code" class="JavaScript">
//データベース オープン(データベースに接続する)
var db = window.openDatabase("testDb","","testDb","1024");
// テーブルが存在しなければ作成
db.transaction(
  function(tx) {
    tx.executeSql("create table if not exists testTable (id integer primary key autoincrement, name, val)");
  }
);
// データ取得
db.transaction(
  function(tx) {
    tx.executeSql("select * from testTable", [],
      function(tx, rs) {
        // ここで画面表示初期化の処理を呼ぶ
        initTable(); // 実際のコードは省略
        if(rs.rows.length > 0){
          for(var i = 0; i < rs.rows.length; i++){
          var row = rs.rows.item(i);
           // 画面表示の処理を呼ぶ
          addTable(row.id, row.name, row.val); // 実際のコードは省略
          }
        }
      },
      function(tx, ex) {
        alert('Sql Error CallBack');
      }
    );
  },
  function(ex){
    alert('transaction Error CallBack');
  }
);
</pre>

画面イメージは<a href="http://www.ilovex.co.jp/blog/system/assets_c/2010/08/snap-331.html" onclick="window.open('http://www.ilovex.co.jp/blog/system/assets_c/2010/08/snap-331.html','popup','width=523,height=373,scrollbars=no,resizable=no,toolbar=no,directories=no,location=no,menubar=no,status=no,left=0,top=0'); return false">こちら</a>です。

それでは、詳しいコードの説明に入ります。
まず2行目、ここでは前回紹介したwindow.openDatabaseを使用して、
データベースとの接続を行っています。
今回の例では「testDb」という名前のデータベースに接続しています。
このとき、データベースが存在していない場合は新しく作成されます。

<pre name="code" class="js:firstline[1]">
//データベース オープン(データベースに接続する)
var db = window.openDatabase("testDb","","testDb","1024");
</pre>

戻り値であるオブジェクトはこの後使うので変数に代入します。
本来はこのようなグローバル変数として使用するべきではありませんが、
今回は例ということなので気にしないでください。

4行目では接続したデータベースにテーブルが存在しているか確認し、
テーブルが存在しない場合はテーブルを作成しています。
ここで、前回紹介したtransactionとexecuteSqlを使います。

db.transaction には引数としてトランザクションオブジェクトが渡されます。
このトランザクションオブジェクト(例では変数tx)のexecuteSqlメソッドを使用してSQLを実行します。

<pre name="code" class="js:firstline[3]">
// テーブルが存在しなければ作成
db.transaction(
  function(tx) {
    tx.executeSql("create table if not exists testTable (id integer primary key autoincrement, name, val)");
  }
);
</pre>

10行目以降の処理でテーブルに存在するデータを取得します。
ここで注目すべきは13行目以降の関数です。
これは、実行したSQLが成功したときの処理になります。
この関数には引数として、1つ目の引数にトランザクションオブジェクト、
2つ目の引数に実行結果のオブジェクトが渡されます。

<pre name="code" class="js:firstline[9]">
// データ取得
db.transaction(
  function(tx) {
    tx.executeSql("select * from testTable", [],
      function(tx, rs) {
        // ここで画面表示初期化の処理を呼ぶ
        initTable(); // 実際のコードは省略
        if(rs.rows.length > 0){
          for(var i = 0; i < rs.rows.length; i++){
          var row = rs.rows.item(i);
           // 画面表示の処理を呼ぶ
          addTable(row.id, row.name, row.val); // 実際のコードは省略
          }
        }
      },
      function(tx, ex) {
        alert('Sql Error CallBack');
      }
    );
  },
  function(ex){
    alert('transaction Error CallBack');
  }
);
</pre>

SELECT文の結果は実行結果オブジェクトの「rows」というオブジェクトに格納されます。
「rows」は16行目のようにrows.lengthで結果の件数を取得したり、
18行目のようにrows.item(index)で該当行数の行データを取得することができます。

rows.item(index)で取得した行データは20行目のように、
「行オブジェクト.カラム名」で列データを取得することができます。
<pre name="code" class="js:firstline[20]">          addTable(row.id, row.name, row.val); // 実際のコードは省略</pre>

今回はデータベースとの接続、および選択処理を例にWeb SQL Databaseを見てきました。
実際に触ってみる場合は、Google Chromeのデベロッパーツールを使用すると、
テーブルにどのような値が入っているのかを簡単に確認することができるので便利かと思います。

Web SQL Databaseの欠点としては、作成したデータベースを削除する手段が
実際に使用しているファイルを削除するしかないところでしょうか。

私の環境は Windows7 ですが、データベースの削除には
"ユーザフォルダ\AppData\Local\Google\Chrome\User Data\Default\databases"
内のファイルを削除する必要がありました。

前回も少し触れましたがWeb SQL Databaseは仕様凍結状態になっており、
今後の発展が期待できないAPIです。
ただ、デザイナの方などがSQLを学ぶ材料としては非常によくできていると思いますし、
家で簡単に使えるので駆け出しのプログラマの勉強材料としても十分だと思います。

興味を持った方は是非とも触ってみてはいかがでしょうか？]]></description>
         <link>http://www.ilovex.co.jp/blog/system/distributionsystem/web-sql-database-2.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/distributionsystem/web-sql-database-2.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">020_流通システム部</category>
        
        
         <pubDate>Tue, 24 Aug 2010 16:44:29 +0900</pubDate>
      </item>
      
      <item>
         <title>ソフトだけではなくハードにも強く</title>
         <description><![CDATA[システム開発を行ううえで、ソフトウェアに強いのは当たり前ですが、
それを動かすハードウェアについて、どの程度知識を持っているでしょうか。

今回は、私がハードウェア面の知識を蓄えるために、日々行っていることを紹介します。

<strong>（１）一日一度ニュースサイトでリリース情報を確認</strong>
常に最新のリリース情報を知らなければ、何も始まりません。
自分が普段使わないような機器であったとしても、大手IT系ニュースサイトで
発表されているリリース情報は、全て目を通しておきます。
この時には流し読みで覚える必要はありません。

<strong>（２）特に注目されている商品は発売後3日以内に試す</strong>
最新のパソコンや、iPad、Android携帯など、日々ハードウェアは進化しています。
特に話題になっている製品はお客様が使用される事も多く、
その機器向けのソフトウェア開発を依頼される可能性があります。
相談をうけてから触っていては遅いので、必ず3日以内には軽く触り、
今後必ずユーザが増えると考えられる物は、購入して使うようにしています。

<strong>（３）ベンチマーク情報を集める</strong>
システム開発を行う上で、それを動かすサーバを導入する事があります。
その際にコストとパフォーマンスを最適化するためには、
今市販されている機器の性能と価格を的確に把握する必要があります。
例えばCPUを選ぶ際、IntelかAMDかという選択肢がある場合に、
情報を集めていればコストパフォーマンスの良いものを選べますが、
情報が無いと有名だからIntelで、といった選択しか出来ません。

これらの事を行う上で作業を楽にしてくれる方法に、Twitterがあります。

現在、大手ITサイトやメーカーはこぞってTwitterのアカウントを持っています。
また、メーカーの広報の方のアカウントなどで、Webに載ってない最新情報を呟くこともあります。
その他にも、ハードウェアやソフトウェアの業界で有名な人のアカウントをフォローしておくと、
最新機器の使用感などもいち早く知ることが出来るのでオススメです。

是非、これらの事を1つでも試してソフトウェアだけでなく、
ハードウェアにも強い開発者を目指してはいかがでしょうか。]]></description>
         <link>http://www.ilovex.co.jp/info/ilo_week/2010/08/post-242.html</link>
         <guid>http://www.ilovex.co.jp/info/ilo_week/2010/08/post-242.html</guid>
        
        
         <pubDate>Mon, 23 Aug 2010 12:00:00 +0900</pubDate>
      </item>
      
      <item>
         <title>デスクトップのアイコンを整理する『Fences（フェンス）』</title>
         <description><![CDATA[デスクトップのアイコンを整理する『Fences』

見た目は良くないけど、デスクトップにアイコンを並べるのはやめられない...。<br />
そんな方にオススメの無料アプリケーション、『<a href="http://www.stardock.com/products/fences/index.asp" target="_blank">Fences（フェンス）</a>』を紹介します。<br /><br />

<a href="http://www.stardock.com/products/fences/index.asp" target="_blank">http://www.stardock.com/products/fences/index.asp</a><br /><br />

<span class="mt-enclosure mt-enclosure-image" style="display: inline;"><img alt="img_01.png" src="http://www.ilovex.co.jp/blog/system/2010/08/20/img_01.png" width="500" height="375" class="mt-image-none" style="" /></span><br /><br />

デスクトップの好きな場所に枠を作り、その中にショートカットやフォルダをドラッグ＆ドロップすると、自動でアイコンを整列してくれます。<br /><br /><br />

<span class="mt-enclosure mt-enclosure-image" style="display: inline;"><img alt="img_02.png" src="http://www.ilovex.co.jp/blog/system/2010/08/20/img_02.png" width="325" height="231" class="mt-image-none" style="" /></span><br /><br />

枠に入りきらないアイコンが存在すると、スクロールバーが表示され、枠の大きさに左右されず、アイコンを収納することが出来ます。<br /><br /><br />

<span class="mt-enclosure mt-enclosure-image" style="display: inline;"><img alt="img_03.png" src="http://www.ilovex.co.jp/blog/system/2010/08/20/img_03.png" width="500" height="375" class="mt-image-none" style="" /></span><br /><br />

デスクトップ上の何もない場所をダブルクリックすると全ての枠が不可視状態になり、必要な時だけ『Fences』を表示することが出来ます。<br />
（もう一度ダブルクリックすると可視状態に戻ります）<br /><br /><br />

<span class="mt-enclosure mt-enclosure-image" style="display: inline;"><img alt="img_04.png" src="http://www.ilovex.co.jp/blog/system/2010/08/20/img_04.png" width="500" height="375" class="mt-image-none" style="" /></span><br /><br />

また、枠の色を変更することも可能です。<br />
壁紙に合わせて、見やすくカスタマイズ出来ます。<br /><br /><br />

必要なアイコンをデスクトップに、しかも見やすく配置が可能。<br />
あると無いでは作業スピードにかなりの差が出ます。<br />
デスクトップにファイルを溜め込みがちな方は、一度試してみてはいかがでしょうか。<br />
対応OSはWindows XP、Windows Vista、Windows 7です。<br />
初期設定は英語ですが、日本語にも対応しております。<br /><br /><br />

ダウンロードは以下のページから。<br />
<a href="http://www.stardock.com/products/fences/downloads.asp" target="_blank">http://www.stardock.com/products/fences/downloads.asp</a><br /><br />
]]></description>
         <link>http://www.ilovex.co.jp/blog/system/webconsulting/fences.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/webconsulting/fences.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">051_Webコンサルティング部</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">その他</category>
        
        
          <category domain="http://www.sixapart.com/ns/types#tag">アプリケーション</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">デスクトップ</category>
        
         <pubDate>Mon, 23 Aug 2010 00:00:00 +0900</pubDate>
      </item>
      
      <item>
         <title>ジェネリクス（総称）の仕組み</title>
         <description><![CDATA[みなさん、こんにちは。<br/>
今回は、J2SE5.0から追加された言語仕様ジェネリクス「総称」が<br/>
どのようにして実現されているのか、<br/>
List及び、ArrayListを例にして説明しようと思います。<br/>
<br/>
<br/>
以下に、Listインタフェースのコードの一部を抜粋したものを記載します。
<pre name="code" class="java">
public interface List&lt;E&gt; extends Collection&lt;E&gt; {

    public boolean add(E object);

    public E get(int index);

</pre>
ListおよびCollectionの後ろに&lt;E&gt;と、従来のJava言語には無かった記法がされています。<br/>
まず、この記法について説明をします。<br/>
<br/>
&lt;&gt;で囲まれている部分を「型引数」と呼びます。<br/>
型を引数（パラメータ）として受け取る部分を表しています。<br/>
メソッドの引数に対応するものだと考えてください。<br/>

&lt;&gt;内に記載するEは変数で、「型変数」と呼びます。<br/>
型そのものが格納される変数と考えてください。<br/>
このEがadd()メソッドの引数、およびget()メソッドの返り値として使用されています。<br/>
<br/>
つまり型変数に指定された型のオブジェクトを引数として取り、<br/>
型変数に指定された型のオブジェクトを返り値として返すことを意味しています。 <br/>
<br/>
ListをString型のみを格納できるオブジェクトとして宣言したい場合、
<pre name="code" class="java">
List&lt;String&gt; list;
</pre>
と記載しますが、これは、型変数EにStringを代入していることになります。<br/>
よって、上記のListインタフェースのコードは以下のように置き換えることができます。<br/>
<pre name="code" class="java">
public interface List&lt;String&gt; extends Collection&lt;String&gt; {

    public boolean add(String object);

    public String get(int index);

</pre>
こうして見ると、List&lt;String&gt;型のオブジェクトにはString型しか追加できず、<br/>
また取り出すオブジェクトもString型に限定される仕組みがわかるかと思います。<br/>

ちなみに、Listインタフェースの実装クラスであるArrayListの場合は以下のようになります。<br/>
<pre name="code" class="java">
public class ArrayList&lt;E&gt; extends AbstractList&lt;E&gt;
             implements List&lt;E&gt;
                       , RandomAccess
                       , Cloneable
                       , Serializable {

    public boolean add(E object) {
        ・・・
    }

    public E get(int index) {
        ・・・
    }

</pre>
<br/>
ArrayListをString型のみを格納できるオブジェクトとして宣言したい場合、
<pre name="code" class="java">
List&lt;String&gt; list = new ArrayList&lt;String&gt;();
</pre>
となるので、コードを以下のように置き換えることができます。<br/>
<br/>
<pre name="code" class="java">
public class ArrayList&lt;String&gt; extends AbstractList&lt;String&gt;
             implements List&lt;String&gt;
                       , RandomAccess
                       , Cloneable
                       , Serializable {

    public boolean add(String object) {
        ・・・
    }

    public String get(int index) {
        ・・・
    }

</pre>
<br/>
以上の説明で、ジェネリクスの仕組みが大体わかっていただけたのではないかと思います。<br/>]]></description>
         <link>http://www.ilovex.co.jp/blog/system/industrysystem/no.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/industrysystem/no.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">030_産業システム部</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">JAVA</category>
        
        
          <category domain="http://www.sixapart.com/ns/types#tag">Java ジェネリクス 総称</category>
        
         <pubDate>Thu, 19 Aug 2010 13:49:00 +0900</pubDate>
      </item>
      
      <item>
         <title>MT3（Movable Type 3）で使えるMultiblogマルチブログ</title>
         <description><![CDATA[<p>MT5がリリースされて久しいですが、早くにMTを導入された方は、MT3で複数のブログを構築されています。<br />
	MT3は「if文」が使えないためある程度機能も限られてしまいますが、複数のブログをまとめてサイトのトップページをポータル的に利用することも可能です。<br />
	※MT3の中でも細かいバージョンに分かれています。出来るだけ公開用サイトと同じバージョンでテストをすることをお勧めします。<br />
</p>
<p>プラグインをインストールします。<br />
	Sixapart Movable Type プラグインディレクトリ：<a href="http://www.sixapart.jp/movabletype/plugins/multiblog.html" target="_blank">MultiBlog</a><br />
	残念ながら、ここで紹介されているダウンロードサイトはNot Foundになっているので、自助努力で入手してください。</p>
<p>---------------------------------------------------</p>
<p>ブログID（1,2）のエントリーのタイトル一覧を表示します。<br />
	※ブログごとに表示する画像を変えています。</p>
<p>&lt;dl&gt;<br />
	&lt;MTMultiBlogEntries include_blogs=&quot;1,2&quot; lastn=&quot;30&quot;&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;dt&gt;&lt;img src=&quot;image/image_&lt;$MTBlogID$&gt;.gif&quot;&gt;&lt;a href=&quot;&lt;$MTEntryLink$&gt;&quot;&gt;&lt;$MTEntryDate&quot;$&gt;&lt;/a&gt;&lt;/dt&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;dd&gt;&lt;$MTEntryTitle$&gt;&lt;/dd&gt;<br />
	&lt;/MTMultiBlogEntries&gt;<br />
	&lt;/dl&gt;</p>
<p>各ブログごとのエントリーの一覧を出す場合は下記のようになります。</p>
<p>&lt;MTMultiBlog include_blogs=&quot;1,2&quot;&gt;<br />
	&lt;dl&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;MTEntries lastn=&quot;30&quot;&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;dt&gt;&lt;img src=&quot;image/image_&lt;$MTBlogID$&gt;.gif&quot;&gt;&lt;a href=&quot;&lt;$MTEntryLink$&gt;&quot;&gt;&lt;$MTEntryDate$&gt;&lt;/a&gt;&lt;/dt&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;dd&gt;&lt;$MTEntryTitle$&gt;&lt;/dd&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;/MTEntries&gt;<br />
	&lt;/dl&gt;<br />
	&lt;/MTMultiBlog&gt;</p>
<p>---------------------------------------------------</p>
<p>ブログID（3）のエントリー一覧<br />
	※特定のカテゴリーのエントリーは表示させない</p>
<p>&lt;MTMultiBlog include_blogs=&quot;3&quot;&gt;<br />
	&lt;ul&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;MTEntries category=&quot;NOT カテゴリ名&quot;&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;li&gt;&lt;$MTEntryTitle$&gt;&lt;/li&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;/MTEntries&gt;<br />
	&lt;/ul&gt;<br />
	&lt;/MTMultiBlog&gt;</p>
<p>---------------------------------------------------</p>
<p>ブログID（4）のエントリー一覧<br />
	※カテゴリーごとに表示する画像を変えています。<br />
	&lt;$MTCategoryLabel$&gt;&lt;$MTCategoryDescription$&gt;は画像の名前と説明に使い分けてください。</p>
<p>&lt;MTMultiBlog include_blogs=&quot;4&quot;&gt;<br />
	&lt;ul&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;MTEntries lastn=&quot;20&quot;&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;li&gt;&lt;img src=&quot;image/&lt;MTEntryCategories&gt;&lt;$MTCategoryDescription$&gt;&lt;/MTEntryCategories&gt;&quot; alt=&quot;&lt;MTEntryCategories&gt;&lt;$MTCategoryLabel$&gt;&lt;/MTEntryCategories&gt;&quot; /&gt;&lt;br /&gt;&lt;$MTEntryTitle$&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;/li&gt;<br />
	&nbsp;&nbsp;&nbsp;&nbsp;&lt;/MTEntries&gt;<br />
	&lt;/ul&gt;<br />
	&lt;/MTMultiBlog&gt;</p>
<p>---------------------------------------------------</p>
<p>プラグイン：MultiBlog（再構築トリガーの設定）<br />
	※少々わかりづらい場所にあります。（メインメニュー／ブログ名／設定／プラグイン）</p>
<p><span class="mt-enclosure mt-enclosure-image" style="display: inline;"><img alt="再構築トリガーの設定" src="http://www.ilovex.co.jp/blog/system/2010/08/18/20100818.png" width="460" height="236" class="mt-image-none" style="" /></span></p>
<p>---------------------------------------------------</p>]]></description>
         <link>http://www.ilovex.co.jp/blog/system/webconsulting/mt3multiblog.html</link>
         <guid>http://www.ilovex.co.jp/blog/system/webconsulting/mt3multiblog.html</guid>
        
          <category domain="http://www.sixapart.com/ns/types#category">051_Webコンサルティング部</category>
        
          <category domain="http://www.sixapart.com/ns/types#category">Movable Type</category>
        
        
          <category domain="http://www.sixapart.com/ns/types#tag">MT3</category>
        
          <category domain="http://www.sixapart.com/ns/types#tag">multiblog</category>
        
         <pubDate>Wed, 18 Aug 2010 17:09:25 +0900</pubDate>
      </item>
      
      
   </channel>
</rss>
