Develop and Download Open Source Software

Browse CVS Repository

Contents of /modchxj/mod_chxj/doc/modchxj.sdoc

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.24 - (show annotations) (download)
Tue Jul 11 21:49:35 2006 UTC (17 years, 9 months ago) by konn
Branch: MAIN
Changes since 1.23: +16 -0 lines
*** empty log message ***

1 <?xml version='1.0' encoding="EUC-JP" ?>
2
3 <doc xml:lang="ja">
4 <head>
5 <title>mod_chxj</title>
6 <subtitle></subtitle>
7 <author>Atsushi Konno</author>
8 <date>29 Mar 2005</date>
9 </head>
10 <body>
11 <section title="Overview">
12
13 mod_chxjはオープンソースの携帯向けコンテンツ変換Apache2.0用モジュールであり、
14 CHTML(DoCoMo i-Mode用 CHTML3.0)で記述された文書や通常のHTMLで記述された文書を、アクセスに来た端末のUser-Agentヘッダを見て、それぞれの端末にあった形式に変換します。
15 HTML文書に限らず、画像(jpg、gif、png)、絵文字についても、定義ファイルに従ってそれぞれのキャリアにあった絵文字に変換します。
16 Cookie非対応端末、Refer非対応端末のために、Set-Cookie、CookieヘッダやRefererヘッダをシミュレートすることもできます(EXPERIMENTAL)。
17
18
19 </section>
20 <section title="インストール">
21 <subsection title="準備">
22 mod_chxjをインストールする前に、下記のものを用意する必要があります。
23 <ol>
24 <li>Apache2.0のヘッダーファイル群</li>
25 <li>Apache2.0用のapxs</li>
26 <li>apr(Apache Portable Runtime)ライブラリとそのヘッダファイル郡(apu含む)</li>
27 <li>automake、autoconf、libtool1.3.X</li>
28 <li>ImageMagick(MagickWand)</li>
29 <li>libiconvまたはlibiconv_hook</li>
30 <li>Linux</li>
31 </ol>
32 </subsection>
33 <subsection title="mod_chxjの入手">
34 mod_chxjは<a href="http://sourceforge.jp/projects/modchxj/">こちら</a>からダウンロードすることができます。
35 </subsection>
36 <subsection title="インストール">
37 以下にmod_chxjインストール手順を示します。
38 <ol>
39 <li>Configure スクリプトを生成します<program title="Configure スクリプトの生成">
40 $ ./buildconf.sh
41 </program>
42 <note>"$"はプロンプトをあらわします。</note>
43 </li>
44 <li>Configure
45
46 以下は、/usr/include/apache2.0に、Apache2.0のヘッダーファイルが存在する場合です。
47 <program title="Configure">
48 $ ./configure --with-apache-header=/usr/include/apache2.0
49 </program>
50 <note>--with-apache-headerは必須です。</note>
51 <note>FreeBSD等の場合は--with-iconvも必須です。</note>
52 <note>場合によっては--with-aprや--with-apuも必要です。</note>
53 </li>
54 <li>mod_chxj.soを生成します
55 <program title="make">
56 $ make
57 </program>
58 </li>
59 <li>apacheにインストールします
60 <program title="install">
61 $ make install
62 </program>
63 </li>
64 <li>データの設置
65 etcディレクトリは以下のdevice_data.xmlとemoji.xmlをApache
66 からアクセスできるところに配置します。
67
68 以下、/etc/apache2/chxjディレクトリにchxj用設定ファイルを用意する場合
69
70 <program title="データの設置">
71 $ mkdir -p /etc/apache2/chxj
72 $ cp etc/device_data.xml /etc/apache2/chxj
73 $ cp etc/emoji.xml /etc/apache2/chxj
74 </program>
75 </li>
76 </ol>
77 </subsection>
78 </section>
79 <section title="Configuration">
80 以下はmod_chxjが/usr/lib/apache2/modulesディレクトリ配下に設置されたものとしています
81
82 <subsection title="htmlファイルが変換対象の場合">
83
84 例として、Locationが"/chxj"以下のものは全て変換する場合を説明します。
85
86 <ol>
87 <li>httpd.confに以下を追加します。
88
89 <program title="httpd.conf">
90 #====================================================================================
91 # モジュールをApache2.0にロード
92 #====================================================================================
93 LoadModule chxj_module /usr/lib/apache2/modules/mod_chxj.so
94
95 #====================================================================================
96 # デバイスデータファイルの設定
97 #====================================================================================
98 ChxjLoadDeviceData /etc/apache2/chxj/device_data.xml
99
100 #====================================================================================
101 # 絵文字データファイルの設定
102 #====================================================================================
103 ChxjLoadEmojiData /etc/apache2/chxj/emoji.xml
104
105 #====================================================================================
106 # 変換エンジン動作指示命令(下記のSetOutputFilter、SetInputFilterも必須です)
107 # ChxjConvRule ==> ディレクティブ
108 # "^/chxj.+$" ==> Perl互換のURIパターン
109 # EngineOn ==> 変換エンジンを動作させる指示
110 # NONE ==> サーバ側の文字コード。(NONEを指定した場合は文字コード変換しない)
111 #====================================================================================
112 ChxjConvertRule "^/chxj.+$" "EngineOn" "NONE"
113
114 </program>
115 </li>
116 <li>apacheの再起動。</li>
117 </ol>
118 </subsection>
119 <subsection title="php等の出力結果が変換対象の場合">
120 <ol>
121 <li>httpd.confに以下を追加します
122
123 <program title="httpd.conf">
124 #====================================================================================
125 # モジュールをApache2.0にロード
126 #====================================================================================
127 LoadModule chxj_module /usr/lib/apache2/modules/mod_chxj.so
128
129 #====================================================================================
130 # デバイスデータの設定
131 #====================================================================================
132 ChxjLoadDeviceData /etc/apache2/chxj/device_data.xml
133
134 #====================================================================================
135 # 絵文字データの設定
136 #====================================================================================
137 ChxjLoadEmojiData /etc/apache2/chxj/emoji.xml
138
139 #====================================================================================
140 # 変換エンジン動作指示命令(下記のSetOutputFilter、SetInputFilterも必須です)
141 # ChxjConvRule ==> ディレクティブ
142 # "^/chxj.+$" ==> Perl互換のURIパターン
143 # EngineOn ==> 変換エンジンを動作させる指示。動作させたく無い場合は"EngineOff"
144 # EUC-JP ==> サーバ側の文字コード。(NONEを指定した場合は文字コード変換しない)
145 # EUC-JPからCP932に文字コード変換します。
146 #====================================================================================
147 ChxjConvertRule "^/chxj.+$" "EngineOn" "EUC-JP"
148
149 </program>
150 </li>
151 <li>apacheの再起動。</li>
152 </ol>
153 </subsection>
154
155 <subsection title="xoopsを使用し、且つwordpress、bwikiを使用している場合">
156 <ol>
157 <li>httpd.confに以下を追加します
158
159 <program title="httpd.conf">
160 #====================================================================================
161 # モジュールをApache2.0にロード
162 #====================================================================================
163 LoadModule chxj_module /usr/lib/apache2/modules/mod_chxj.so
164
165 #====================================================================================
166 # デバイスデータの設定
167 #====================================================================================
168 ChxjLoadDeviceData /etc/apache2/chxj/device_data.xml
169
170 #====================================================================================
171 # 絵文字データの設定
172 #====================================================================================
173 ChxjLoadEmojiData /etc/apache2/chxj/emoji.xml
174
175 #====================================================================================
176 # 変換エンジン動作指示命令(下記のSetOutputFilter、SetInputFilterも必須です)
177 #====================================================================================
178 #====================================================================================
179 # bwikiの設定をします。bwikiではどうもxoopsヘッダの文字コードとbwiki内での携帯スキン
180 # の文字コードが一致していないようなので、bwiki内で文字コードを変換させないように
181 # 修正後、以下のルールを記述します。
182 #
183 # ChxjConvRule ディレクティブ
184 # "^/modules/bwiki.+$" このルールを適用したいURIパターン
185 # "EngineOn" 変換エンジンを有効にします。
186 # "EUC-JP" 出力時にEUC-JPからCP932に変換させます。
187 # "PC" 変換元HTMLはPCサイト用HTMLです。
188 # "DoCoMo/1.0/D501i" DoCoMo端末としてbwikiにアクセスさせます。
189 #
190 #====================================================================================
191 ChxjConvertRule "^/modules/bwiki.+$" "EngineOn" "EUC-JP" "PC" "DoCoMo/1.0/D501i"
192
193 #====================================================================================
194 # wordpressの設定をします。
195 #
196 # ChxjConvRule ディレクティブ
197 # "^/modules/wordpress.+$" このルールを適用したいURIパターン
198 # "EngineOn" 変換エンジンを有効にします。
199 # "NONE" 出力時に文字コード変換をさせません。
200 # "NONE" 変換元HTMLはPCサイト用HTMLではありません。
201 # "DoCoMo/1.0/D501i" DoCoMo端末としてwordpressにアクセスさせます。
202 #
203 #====================================================================================
204 ChxjConvertRule "^/modules/wordpress/.*$" "EngineOn" "NONE" "PC" "DoCoMo/1.0/D501i"
205
206 #====================================================================================
207 # その他の設定をします。
208 #
209 # ChxjConvRule ディレクティブ
210 # "^/.+$" このルールを適用したいURIパターン
211 # "EngineOn" 変換エンジンを有効にします。
212 # "EUC-JP" 出力時にEUC-JPからCP932に文字コード変換をさせます。
213 #
214 #====================================================================================
215 ChxjConvertRule "^/.+$" "EngineOn" "EUC-JP"
216
217
218 &lt;Location /&gt;
219 ChxjImageEngine On
220 AllowOverride All
221 &lt;/Location&gt;
222 </program>
223 </li>
224 <li>apacheの再起動。</li>
225 </ol>
226 </subsection>
227
228
229
230
231 <subsection title="画像自動変換機能を使用する場合">
232 <ol>
233 <li>httpd.confに以下を追加します。
234 下記は、URIが/imgで始まる全ての画像に対して動作するようmod_chxjに指示しています。
235
236 <program title="httpd.conf">
237 &lt;Location /img&gt;
238 ChxjImageEngine On
239 ChxjImageCacheDir /tmp
240 ChxjImageCopyright "A.Konno"
241 &lt;/Location&gt;
242 </program>
243
244 上記の説明を以下に示します。
245
246 <ol>
247 <li>ChxjImageEngine<br />
248 mod_chxjの画像変換ハンドラを起動するよう指示しています。
249 DefaultはOff
250
251 <br />
252 <br />
253 </li>
254
255
256 <li>ChxjImageCacheDir<br />
257 mod_chxj画像変換ハンドラが使用する変換後の画像をおいておくディレクトリを指定します。
258 デフォルトは/tmp。
259
260 <program title="ChxjImageCacheDir">
261 ChxjImageCacheDir /tmp
262 </program>
263
264 mod_chxjに画像変換キャッシュとして/tmpを使用するよう指示します。
265 <br />
266 <br />
267 </li>
268
269
270 <li>ChxjImageCopyright<br />
271 mod_chxjの画像変換ハンドラに、転送禁止設定を行うよう指示します。
272 パラメータとして任意の文字列をとります。
273 ChxjImageCopyrightディレクティブで指定された文字列は、それぞれのイメージの
274 コメント部に埋め込まれます。
275
276 <program title="ChxjImageCopyright">
277 ChxjImageCopyright "A.Konno"
278 </program>
279
280 mod_chxjに転送禁止設定を行うよう指示しています。
281 変換後イメージのコメント部分には、キャリア毎に以下の文字列を埋め込みます。
282
283 <b>AU の場合</b>
284 <program title="AU">
285 kddi_copyright=on,A.Konno
286 </program>
287
288 <b>DoCoMoの場合</b>
289 <program title="DoCoMo">copy="NO",A.Konno</program>
290
291 <b>Vodafone</b>の場合は、レスポンスヘッダに
292
293 <program title="Vodafone/J-PHONE">
294 x-jphone-copyright:no-transfer
295 </program>
296
297 を埋め込みます。
298 <note>Vodafoneの場合は、リクエストURLの最後が.pnzか、.jpzで終わるようにダミーを付けなければなりません。</note>
299 </li>
300 </ol>
301 </li>
302 </ol>
303 </subsection>
304
305 <subsection title="文字コードを変換したい場合(EXPERIMENTAL)">
306 <ol>
307 <li>httpd.confに以下を追加します。
308 下記は、URIが/chxjで始まる全てのコンテンツに対して動作するようmod_chxjに指示しています。
309 サーバ側はEUC-JPであった場合の例です。mod_chxjによってSJISに変換するように指示しています。
310
311 <program title="httpd.conf">
312 ChxjConvRule "^/chxj.+$" "EngineOn" "EUC-JP"
313 </program>
314
315 上記の説明を以下に示します。
316
317 <ol>
318 <li>ChxjConvertRule<br />
319 サーバサイドの文字コードを指定します。ここに、EUC-JPと指定してあった場合は、
320 EUC-JPからCP932に変換後、クライアントに出力されます。
321 省略した場合はNONE
322 <ol>
323 <li>変換エンジン動作指示命令(下記のSetOutputFilter、SetInputFilterも必須です)<br />
324 ChxjConvertRule ==> ディレクティブ<br />
325 "^/chxj.+$" ==> Perl互換のURIパターン<br />
326 EngineOn ==> 変換エンジンを動作させる指示。動作させたく無い場合は"EngineOff"<br />
327 EUC-JP ==> サーバ側の文字コード。(NONEを指定した場合は文字コード変換しない)<br />
328 <br />
329 EUC-JPからCP932に文字コード変換します。(libiconvに依存します)<br/>
330 </li>
331 </ol>
332
333 <br />
334 <br />
335 </li>
336 </ol>
337 </li>
338 </ol>
339 </subsection>
340 <subsection title="ディレクティブ">
341 <ol>
342 <li>ChxjLoadDeviceData<br />
343 デバイス定義ファイルを指定します。
344 <program title="ex)">
345 ChxjLoadDeviceData /etc/apache2/device.xml
346 </program>
347 </li>
348 <li>ChxjLoadEmojiData<br />
349 絵文字変換定義ファイルを指定します。
350 <program title="ex)">
351 ChxjLoadEmojiData /etc/apache2/chxj/emoji.xml
352 </program>
353 </li>
354 <li>ChxjImageEngine<br />
355 画像変換エンジンを有効にします。
356 パラメータとしてOnとOffを指定できます。
357 DefaultはOffです。
358 <program title="ex)">
359 ChxjImageEngine On
360 </program>
361 </li>
362 <li>ChxjImageCacheDir<br />
363 イメージの一時ファイル保存場所を指定します。
364 <program title="ex)">
365 ChxjImageCacheDir /tmp
366 </program>
367 </li>
368 <li>ChxjImageCopyright<br />
369 イメージに著作権情報を付与します。
370 <program title="ex)">
371 ChxjImageCacheDir "chosakuken jyoho"
372 </program>
373 </li>
374 <li>ChxjConvertRule<br />
375 HTML変換エンジンの適用ルールを記述します。
376 本ディレクティブを使用し、変換エンジンのOn|Offを指定します。
377 DefaultはOFFです。
378 また、ルールは記述された順番に評価し、マッチするものがあれば、その時点で対象ルールを適用します。
379 パラメータは3つ必要です。下記にパラメータを記します。
380 <table title="パラメータ">
381 <tbody>
382 <tr>
383 <td>第1パラメータ</td><td>URIを評価するPerl互換の正規表現を指定します</td>
384 </tr>
385
386 <tr>
387 <td>第2パラメータ</td><td>HTML変換エンジンのOn|Offを指定します。Onの場合は"EngineOn"。Offの場合は"EngineOff"を指定します。"EngineOn|EngineOff"の他に"CookieOn|CookieOff"を指定することもできます。複数指定する場合は","で区切って指定します。</td>
388 </tr>
389 <tr>
390 <td>第3パラメータ</td><td>文字コードを指定します。ここで指定した文字コードから"CP932"に変換します。指定できる文字コードはiconv -lコマンドによって確認することができます。変換しなくて良い場合はNONEを指定してください。</td>
391 </tr>
392 <tr>
393 <td>第4パラメータ</td><td>省略した場合は、携帯ページからの変換を意味します。PC用ページからの変換を行う場合は"PC"を第四パラメータに指定します。</td>
394 </tr>
395 <tr>
396 <td>第5パラメータ</td><td>サーバサイドアプリケーションに渡すUser-Agentを指定します。
397 例えば、wordpress等のようにCHTMLを出力するアプリケーションがある場合は、"DoCoMo/1.0/N501i"等適当なUser-Agentを指定することによって、アプリケーションにCHTMLを出力するように指示することができます。
398 ここで指定したUser-AgentはHTML出力時には評価されません。</td>
399 </tr>
400 </tbody>
401 </table>
402 <program title="ex)">
403 ChxjConvertRule "^/chxj.+$/" EngineOn EUC-JP
404 </program>
405 </li>
406 <li>ChxjCookieDir<br />
407 クッキーを使用する場合に指定します。クッキーの内容を保存するディレクトリを指定します。
408 指定しない場合は/tmpに保存されます。
409 <program title="ex)">
410 ChxjCookieDir /tmp
411 </program>
412 詳細は「Cookieシミュレート機能」の項を参照ください。
413 </li>
414 <li>ChxjCookieTimeout<br />
415 クッキーを使用する場合に指定します。クッキーの保持期間を秒単位で指定します。
416 指定しない場合は、1800秒でクッキーデータを破棄します。
417 <program title="ex)">
418 ChxjCookieTimeout 10
419 </program>
420 詳細は「Cookieシミュレート機能」の項を参照ください。
421 </li>
422 </ol>
423 </subsection>
424 </section>
425 <section title="対応するCHTMLタグ">
426 変換可能なCHTMLタグは以下のとおりです。
427
428 <table title="対応タグ一覧">
429 <thead>
430 <tr>
431 <td>タグ</td>
432 <td>属性</td>
433 <td>CHTML</td>
434 <td>HDML</td>
435 <td>XHTML</td>
436 <td>JHTML</td>
437 <td>備考</td>
438 </tr>
439 </thead>
440 <tbody>
441 <tr>
442 <td>&lt;HTML&gt;</td>
443 <td align="center"> </td>
444 <td align="center"></td>
445 <td align="center"></td>
446 <td align="center"></td>
447 <td align="center"></td>
448 <td align="left">属性を指定した場合は無視します</td>
449 </tr>
450 <tr>
451 <td>&lt;META&gt;</td>
452 <td align="center">http-equiv</td>
453 <td align="center"></td>
454 <td align="center">×</td>
455 <td align="center"></td>
456 <td align="center"></td>
457 <td align="left">CHTML1.0、HDMLでは無視します</td>
458 </tr>
459 <tr>
460 <td> </td>
461 <td align="center">content</td>
462 <td align="center"></td>
463 <td align="center">×</td>
464 <td align="center"></td>
465 <td align="center"></td>
466 <td align="left">CHTML1.0、HDMLでは無視します</td>
467 </tr>
468 <tr>
469 <td>&lt;HEAD&gt;</td>
470 <td align="center"> </td>
471 <td align="center"></td>
472 <td align="center"></td>
473 <td align="center"></td>
474 <td align="center"></td>
475 <td align="left">属性を指定した場合は無視します</td>
476 </tr>
477 <tr>
478 <td>&lt;TITLE&gt;</td>
479 <td align="center"> </td>
480 <td align="center"></td>
481 <td align="center"></td>
482 <td align="center"></td>
483 <td align="center"></td>
484 <td align="left">属性を指定した場合は無視します</td>
485 </tr>
486 <tr>
487 <td>&lt;BASE&gt;</td>
488 <td align="center"> </td>
489 <td align="center"></td>
490 <td align="center">×</td>
491 <td align="center"></td>
492 <td align="center"></td>
493 <td align="left">HDMLでは無視します</td>
494 </tr>
495 <tr>
496 <td>&lt;BODY&gt;</td>
497 <td align="center">bgcolor</td>
498 <td align="center"></td>
499 <td align="center">×</td>
500 <td align="center"></td>
501 <td align="center"></td>
502 <td align="left">HDML、CHTML1.0、CHTML2.0では無視します</td>
503 </tr>
504 <tr>
505 <td> </td>
506 <td align="center">text</td>
507 <td align="center"></td>
508 <td align="center">×</td>
509 <td align="center"></td>
510 <td align="center"></td>
511 <td align="left">HDML、CHTML1.0、CHTML2.0では無視します</td>
512 </tr>
513 <tr>
514 <td> </td>
515 <td align="center">link</td>
516 <td align="center"></td>
517 <td align="center">×</td>
518 <td align="center"></td>
519 <td align="center"></td>
520 <td align="left">HDML、CHTML1.0、CHTML2.0では無視します</td>
521 </tr>
522 <tr>
523 <td>&lt;A&gt;</td>
524 <td align="center">href</td>
525 <td align="center"></td>
526 <td align="center"></td>
527 <td align="center"></td>
528 <td align="center"></td>
529 <td align="left"> </td>
530 </tr>
531 <tr>
532 <td> </td>
533 <td align="center">accesskey</td>
534 <td align="center"></td>
535 <td align="center"></td>
536 <td align="center"></td>
537 <td align="center"></td>
538 <td align="left"> </td>
539 </tr>
540 <tr>
541 <td>&lt;BR&gt;</td>
542 <td align="center"> </td>
543 <td align="center"></td>
544 <td align="center"></td>
545 <td align="center"></td>
546 <td align="center"></td>
547 <td align="left"> </td>
548 </tr>
549 <tr>
550 <td>&lt;FONT&gt;</td>
551 <td align="center">color</td>
552 <td align="center"></td>
553 <td align="center">×</td>
554 <td align="center"></td>
555 <td align="center"></td>
556 <td align="left">HDML,CHTML1.0では無視します</td>
557 </tr>
558 <tr>
559 <td>&lt;FORM&gt;</td>
560 <td align="center">action</td>
561 <td align="center"></td>
562 <td align="center"></td>
563 <td align="center"></td>
564 <td align="center"></td>
565 <td align="left"> </td>
566 </tr>
567 <tr>
568 <td> </td>
569 <td align="center">method</td>
570 <td align="center"></td>
571 <td align="center">×</td>
572 <td align="center"></td>
573 <td align="center"></td>
574 <td align="left">HDMLでは無視します</td>
575 </tr>
576 <tr>
577 <td>&lt;INPUT&gt;</td>
578 <td align="center">name</td>
579 <td align="center"></td>
580 <td align="center"></td>
581 <td align="center"></td>
582 <td align="center"></td>
583 <td align="left"> </td>
584 </tr>
585 <tr>
586 <td> </td>
587 <td align="center">type</td>
588 <td align="center"></td>
589 <td align="center"></td>
590 <td align="center"></td>
591 <td align="center"></td>
592 <td align="left">text,password,hidden,radio,checkbox,submitに対応</td>
593 </tr>
594 <tr>
595 <td> </td>
596 <td align="center">value</td>
597 <td align="center"></td>
598 <td align="center"></td>
599 <td align="center"></td>
600 <td align="center"></td>
601 <td align="left"></td>
602 </tr>
603 <tr>
604 <td> </td>
605 <td align="center">istyle</td>
606 <td align="center"></td>
607 <td align="center"></td>
608 <td align="center"></td>
609 <td align="center"></td>
610 <td align="left"> </td>
611 </tr>
612 <tr>
613 <td>&lt;SELECT&lt;</td>
614 <td align="center">name</td>
615 <td align="center"></td>
616 <td align="center"></td>
617 <td align="center"></td>
618 <td align="center"></td>
619 <td align="left"> </td>
620 </tr>
621 <tr>
622 <td> </td>
623 <td align="center">size</td>
624 <td align="center"></td>
625 <td align="center">×</td>
626 <td align="center"></td>
627 <td align="center"></td>
628 <td align="left">HDMLでは無視します</td>
629 </tr>
630 <tr>
631 <td>&lt;OPTION&gt;</td>
632 <td align="center">value</td>
633 <td align="center"></td>
634 <td align="center"></td>
635 <td align="center"></td>
636 <td align="center"></td>
637 <td align="left"><note>必ず閉じてください。そのうち対応します。</note></td>
638 </tr>
639 <tr>
640 <td> </td>
641 <td align="center">checked</td>
642 <td align="center"></td>
643 <td align="center"></td>
644 <td align="center"></td>
645 <td align="center"></td>
646 <td align="left"> </td>
647 </tr>
648 <tr>
649 <td>&lt;DIV&gt;</td>
650 <td align="center">align</td>
651 <td align="center"></td>
652 <td align="center"></td>
653 <td align="center"></td>
654 <td align="center"></td>
655 <td align="left"> </td>
656 </tr>
657 <tr>
658 <td>&lt;HR&gt;</td>
659 <td align="center"> </td>
660 <td align="center"></td>
661 <td align="center"></td>
662 <td align="center"></td>
663 <td align="center"></td>
664 <td align="left"> </td>
665 </tr>
666 <tr>
667 <td>&lt;CENTER&gt;</td>
668 <td align="center"> </td>
669 <td align="center"></td>
670 <td align="center"></td>
671 <td align="center"></td>
672 <td align="center"></td>
673 <td align="left"> </td>
674 </tr>
675 <tr>
676 <td>&lt;IMG&gt;</td>
677 <td align="center">src</td>
678 <td align="center"></td>
679 <td align="center"></td>
680 <td align="center"></td>
681 <td align="center"></td>
682 <td align="left"> </td>
683 </tr>
684 <tr>
685 <td>&lt;CHXJ:IF&gt;</td>
686 <td align="center">lang</td>
687 <td align="center"></td>
688 <td align="center"></td>
689 <td align="center"></td>
690 <td align="center"></td>
691 <td align="left">lang="chtml" lang="xhtml" lang="hdml" lang="jhtml"が指定できます</td>
692 </tr>
693 </tbody>
694
695 上記以外のタグは全て無視されます。
696
697 </table>
698
699 </section>
700 <section title="独自拡張タグ">
701 <ol>
702 <li>&lt;CHXJ:IF&gt;<br />
703
704 &lt;CHXJ:IF&gt;タグと&lt;/CHXJ:IF&gt;タグではさまれたタグやテキストは、
705 変換せずに<b>そのまま</b><note>変換しませんので注意が必要です</note>出力します。必須の属性としてlangがあります。lang属性を指定することによって、
706 例えば、<b>「HDML機の場合のみ出力させる」</b>といったことを可能にします。<br />
707 <br />
708 ex)
709 <program title="HTML文書中にHDML機の場合のみ有効にしたいタグ、または文書がある場合">
710 &lt;CHXJ:IF lang="HDML" &gt;
711 &lt;NODISPLAY&gt;
712 &lt;ACTION TYPE=ACCEPT TASK=GOSUB DEST='device:data/dnld?url=abc&amp;name=abc.jpg&amp;size=100&amp;disposition=devjaww&amp;title=test'&gt;
713 &lt;/NODISPLAY&gt;
714 &lt;/CHXJ:IF&gt;
715 </program><br />
716
717 ex)
718 <program title="i-Modeのみ出力したい文書がある場合">
719 &lt;CHXJ:IF lang="chtml" &gt;
720 シークレットコードがどーのこーの。
721 &lt;/CHXJ:IF&gt;
722 </program><br />
723
724 また、lang属性は、複数指定することも可能です。<br />
725
726 <program title="HDML機,J-PHONE機は以下を出力します">
727 &lt;CHXJ:IF lang="chtml" lang="jhtml"&gt;
728 あなたの携帯は、HDML機かJ-HTML機です。
729 &lt;/CHXJ:IF&gt;
730 </program><br />
731
732 </li>
733 </ol>
734 </section>
735
736
737
738 <section title="文字コード">
739 文字コードは、絵文字の入出力がある関係上、Shift_JISのみとしています。
740 </section>
741
742
743 <section title="絵文字について">
744 i-Mode用の絵文字を書いておけば、アクセスしたキャリアによって、mod_chxjが対応の絵文字に自動変換します。
745 ソースに2byteのバイナリコードを直接書いても、10進参照文字列<note>16進参照文字列には対応していません</note>&amp;#XXX;の形)で書いても、どちらでも変換対象になります。
746 10進参照文字列で書いた場合は、mod_chxjにより、自動で2バイトコードに変換します。
747 <subsection title="絵文字変換定義">
748 絵文字の変換に関する動作を変えたい場合(例えば「ハートがあったら、AUの場合はスペードに」とか、「変換定義がおかしい」といった場合)は、
749 emoji.xmlファイルを直接編集することによって定義を変更することが可能です。emoji.xmlはXMLファイルとなっていますので、vi等で簡単に定義を
750 変更することができます<note>厳密にはXMLになっていないので、日本語の記述はSJISでお願いします。</note>
751
752 <br />
753 以下に、emoji.xmlファイルの一部を記します。
754 <program title="emoji.xml">
755 &lt;?xml encoding="Shift_JIS" &gt;
756
757 &lt;emoji&gt;
758 &lt;set&gt;
759 &lt;no&gt;1&lt;/no&gt;
760 &lt;imode&gt;
761 &lt;hex1&gt;f8&lt;/hex1&gt;
762 &lt;hex2&gt;9f&lt;/hex2&gt;
763 &lt;string&gt;&amp;#63647;&lt;/string&gt;
764 &lt;description&gt;&lt;/description&gt;
765 &lt;/imode&gt;
766 &lt;ezweb&gt;
767 &lt;A&gt;44&lt;/A&gt;
768 &lt;B&gt;44&lt;/B&gt;
769 &lt;C&gt;44&lt;/C&gt;
770 &lt;D&gt;44&lt;/D&gt;
771 &lt;/ezweb&gt;
772 &lt;jphone&gt;
773 &lt;string&gt;$Gj&lt;/string&gt;
774 &lt;/jphone&gt;
775 &lt;/set&gt;
776 </program>
777
778 絵文字の定義は、&lt;emoji&gt;タグから&lt;/emoji&gt;タグまでの間にあります。その中の要素を説明します。
779 1つの絵文字につき、1つのセット(&lt;set&gt;タグから&lt;/set&gt;タグまで)とし、キャリア毎の絵文字を定義しています。
780
781 <ol>
782 <li>&lt;imode&gt;要素<br />
783 まず、元となるi-Mode用の絵文字は、&lt;imode&gt;タグにはさまれた間に定義されています。
784 &lt;imode&gt;要素は、2バイトコード要素(&lt;hex1&gt;&lt;hex2&gt;)と、
785 10進参照文字列要素(&lt;string&gt;)を保持していて、この2つの要素を変換元の値として使用します。
786 アクセスしてきた端末が、i-Mode機であった場合で、かつCHTML中に10進参照文字列が絵文字として書かれている場合には、
787 &lt;hex1&gt;&lt;hex2&gt;要素に定義されている値に置換します。
788 </li>
789 <br />
790 <br />
791 <li>&lt;ezweb&gt;要素<br />
792 アクセスしてきた端末が、AU機であった場合、&lt;ezweb&gt;要素に定義されている値に変換します。
793 &lt;ezweb&gt;要素は、&lt;A&gt;&lt;D&gt;要素を持っていて、それぞれAUの絵文字タイプA〜Dに対応していますので、
794 もし、Dタイプの絵文字端末であったなら、&lt;D&gt;要素に定義されている値に変換します。ここで定義されている値は、
795 HDML機の場合は、<b>&lt;IMG ICON="XX"&gt;</b>の"XX"の部分に当てはめられて、置換されます。
796 XHTML機の場合は、<b>&lt;IMG LOCALSRC="XX"&gt;</b>の"XX"の部分に当てはめられて、置換されます。
797 </li>
798 <br />
799 <br />
800 <li>&lt;jphone&gt;要素<br />
801 アクセスしてきた端末が、Vodafone/J-Phone端末であった場合、&lt;jphone&gt;要素に定義されている値に変換します。
802 &lt;jphone&gt;要素は、&lt;string&gt;要素を保持していて、ここで定義されている値を直接使用します。
803 </li>
804 </ol><br />
805 emoji.xmlに定義されていない絵文字で、変換したい絵文字がある場合には、このファイルに新たな定義を足せば、
806 変換するようになります。
807 </subsection>
808 </section>
809
810
811 <section title="デバイス定義 device_data.xml">
812 mod_chxjの動作を決定付ける重要な定義です。変換対象の端末は全て、device_data.xmlファイルに定義される必要があります。
813 定義されていない端末は、mod_chxjとしては、認識することができません。認識できない場合には、変換せずにそのまま出力します。ただし、Perl互換の正規表現によって定義できるため、正規表現の書き方によっては全ての機種に対応させることも可能です。
814 </section>
815
816
817 <section title="イメージ画像変換機能">
818 mod_chxjには、JPEG、GIF、PNG、BMPファイルを置いておくだけで、デバイス定義に従って、それぞれのキャリア対応のフォーマットに変換する機能があります。
819 画像のサイズ(縦X横)も、端末の画面サイズに合わせて変換します。
820 画像のサイズ(バイト数)については、デバイス定義中のキャッシュサイズを見て、その値よりも小さくなるように<b>努力</b>しますが、元の画像が
821 大きすぎる場合や、複雑な画像の場合には、キャッシュサイズよりも小さくできずに表示できない場合があります。
822 <br />
823 それぞれのタグで指定する場合には、ファイル名の拡張子(.jpgや.gif等)をはずした形で指定します。<br />
824 本機能には3つのモードが存在します。そのモードを以下に記します。
825
826 <subsection title="サムネイルモード">
827 端末側画面サイズの約3分の1程度のサイズ(縦X横)に画像を縮小表示します。
828 <program title="サムネイルモード 使用例">
829 &lt;IMG SRC="/img/logo?Mode=Thumbnail"&gt;
830 </program>
831 </subsection>
832 <subsection title="壁紙モード">
833 端末側画面のサイズにマッチするサイズに拡大・縮小します。横長の画像の場合には、縦幅を合わせた後に左右をトリミングします。
834 <program title="壁紙モード 使用例">
835 &lt;IMG SRC="/img/logo?Mode=WP"&gt;
836 </program>
837 </subsection>
838 <subsection title="EzGetモード">
839 壁紙ダウンロードを行いたい場合に使用します。EzGETモードは、壁紙モードで出力される画像サイズと同一サイズの画像が使用されます。
840 <program title="EzGetモード 使用例">
841 &lt;A HREF="/img/logo?Mode=EzGet"&gt;
842 </program>
843 </subsection>
844 <subsection title="その他の機能">
845 モードの他に、画像サイズ(縦X横)を直接指定することも可能です。
846 <b>w</b>パラメータ、<b>h</b>パラメータを使用して指定します。
847 <ol>
848 <li>wパラメータ<br />
849 横幅を指定します。
850 </li>
851 <li>hパラメータ<br />
852 縦幅を指定します。
853 </li>
854 <program title="w/hパラメータ 使用例">
855 &lt;IMG SRC="/img/logo?w=100&amp;h=200"&gt;
856 </program>
857 <li>User-Agentパラメータ(uaパラメータ)<br />
858 User-Agentを指定します。指定した場合は、リクエストヘッダ中のUser-Agentを本パラメータの値で上書きします。
859 このパラメータに"IGN"を指定した場合は、User-Agentを無視します。Thumbnailモード、壁紙モードと併用時は、
860 640x480を元に画像サイズを算出します。
861 </li>
862 </ol>
863 </subsection>
864 上記全てのモード、パラメータはGETリクエストとしてのみ使用できます。
865 </section>
866
867 <section title="QRコード出力機能">
868 <subsection title="QRコード出力ハンドラの登録">
869 QRコード出力機能を使用するには、QRコードハンドラを登録します。
870 httpd.confに以下の記述を追加します。
871 <program title="httpd.conf">
872 AddHandler chxj-qrcode .qrc
873 </program>
874 なお、ハンドラを登録しないでも、出力フィルターを経由させることで、QRコードを出力させることも可能です。(※QRコードの動的出力を参照)
875 </subsection>
876 <subsection title="QRコードソースファイルの設置">
877 ハンドラを登録したら、その登録した拡張子を持つファイルを用意します。
878 <program title="例:a.qrc">
879 &lt;?xml version=1.0 ?&gt;
880
881 &lt;qrcode&gt;
882 &lt;version&gt;13&lt;/version&gt;
883 &lt;level&gt;H&lt;/level&gt;
884 &lt;mode&gt;8bit&lt;/mode&gt;
885 &lt;size&gt;1&lt;/size&gt;
886 &lt;data&gt;テストデータです&lt;/data&gt;
887 &lt;/qrcode&gt;
888 </program>
889 .qrcファイルは、qrcode要素、version要素、level要素、mode要素、size要素、data要素から成り立ちます。
890 <ol>
891 <li>versionタグ
892 versionタグは出力するQRコードの生成に利用するバージョンを指定します。
893 使用できるバージョンは、1〜40までの40種類です。
894 </li>
895 <li>levelタグ
896 levelタグは出力するQRコードの生成に利用する誤り検出レベルを指定します。
897  使用できるレベルは、L、Q、M、Hの4つです。
898 </li>
899 <li>modeタグ
900 modeタグは出力するQRコードの生成に利用するモードを指定します。
901 使用できるモードは、NUM(数字モード)ALPHA(英数字モード)8BIT(8ビットバイトモード)KANJI(漢字モード)です。
902 </li>
903 <li>sizeタグ
904 sizeタグは1モジュールを何ピクセルであらわすかを指定します。
905 0を指定した場合は、4を指定した場合と同じ動作をします。
906  使用できるサイズは、0〜20までです。
907 </li>
908 <li>dataタグ
909 dataタグは、QRコードに出力するデータを指定します。改行した場合は、改行文字もQRコード内に符号化されます。
910 </li>
911 </ol>
912 </subsection>
913 <subsection title="QRコードの動的出力機能">
914 プログラム等を使用し、動的にQRコードを出力したい場合は、上記の.qrcファイルの内容をそのままOutputFilterに通してあげればOKです。つまり、ChxjConvertRuleディレクティブで"EngineOn"と指定したURIが指すディレクトリに設置すれば良いということです。mod_chxj内部で、Content-Typeがtext/xmlの場合、QRCode用のファイルであるかどうかを一度読み込んで判断するので、Content-Typeには、text/xmlを設定してください。
915
916 <program title="phpでQRコードを動的に出力する例">
917 &lt;php
918 $version = $_POST["version"];
919 $level = $_POST["level"];
920 $mode = $_POST["mode"];
921 $size = $_POST["size"];
922 $data = $_POST["data"];
923
924 header("Content-Type: text/xml; charset=Shift_JIS");
925
926 echo "&lt;qrcode&gt;\n";
927 echo "&lt;version&gt;".$version."&lt;/version&gt;\n";
928 echo "&lt;level&gt;".$level."&lt;/level&gt;\n";
929 echo "&lt;mode&gt;".$mode."&lt;/mode&gt;\n";
930 echo "&lt;size&gt;".$size."&lt;/size&gt;\n";
931 echo "&lt;data&gt;".$data."&lt;/data&gt;\n";
932 echo "&lt;/qrcode&gt;\n";
933 &gt;
934 </program>
935 そして、上記のコードを、mod_chxj変換エンジンが処理するはずであるところに設置すれば完了です。
936
937 </subsection>
938 </section>
939 <section title="Cookieシミュレート機能(EXPERIMENTAL)">
940 <subsection title="Cookieシミュレート機能(EXPERIMENTAL)">
941 Cookieを受け付けない(無視する)端末のためにCookieをシミュレートします。本機能を有効にするためにはChxjConvertRuleディレクティブを使用する必要があります。ChxjConvertRuleディレクティブの第2パラメータにCookieOnを指定します。
942
943 <program title="Cookieシミュレート機能を有効にする例">
944 ChxjConvertRule "^/chxj.+$" "EngineOn,CookieOn" "NONE"
945 </program>
946
947 </subsection>
948 <subsection title="One-Time ID">
949 Cookieシミュレートでは、aタグ、imgタグ、formタグのURL部にOne-Time IDを埋め込むことで実現します。
950 そのため、ユーザがブラウザの戻るボタン等で戻った場合はCookieを取得できなくなります。
951 </subsection>
952 <subsection title="Cookieの保存場所">
953 Cookieの内容は、サーバ側に保存されます。保存ディレクトリはChxjCookieDirディレクティブを使用することで指定することができます。指定しなかった場合は、/tmpに保存されます。
954 <program title="ChxjCookieDirの例">
955 ChxjCookieDir /var/abc
956 </program>
957 </subsection>
958 <subsection title="Cookieの保持期間">
959 ChxjCookieTimeoutディレクティブで保持期間を指定することができます。指定しなかった場合は1800秒でサーバに保存されているCookieは削除されます。
960 <program title="ChxjCookieTimeoutの例">
961 &lt;Location /&gt;
962 ChxjCookieTimeout 10
963 &lt;/Location&gt;
964 </program>
965 上記の例は、10秒でタイムアウト(サーバから削除)するように指定しています。
966 </subsection>
967 </section>
968
969
970
971 <section title="Refererシミュレート機能(EXPERIMENTAL)">
972 <subsection title="Refererシミュレート機能(EXPERIMENTAL)">
973 DoCoMo端末などのRefererに対応していない機種のためにRefererシミュレート機能を提供します。
974 本機能は、Cookieシミュレート機能を有効にすると、自動で有効になります(将来的には変更予定)。
975 </subsection>
976 </section>
977 </body>
978 </doc>

Back to OSDN">Back to OSDN
ViewVC Help
Powered by ViewVC 1.1.26