GAE開発の落とし穴
Googleのクラウド環境をつかったGoogle App Engineによる開発するにあたり、初めての試みで苦悩する開発者達の経験をもとに、各開発フェーズにあわせて問題点やどう解決したかをご紹介します
ブックマークされました!
ブックマークがエラーになりました。もう一度お願いします。
作者 Srini Penchikala , 翻訳者 南 伸二 投稿日 2010年2月22日
JavaEE 6リリースはRestful Webサービス(JAX-RS)サポートを含んでいる。これは、Representational State Transfer (REST)スタイルのソフトウェアアーキテクチャに従う軽量のWebサービスの構築をPOJOベースのフレームワークを提供する。JAX-RS APIはJSR 311の一部であり、JavaクラスメソッドをWebサービスとして外部に提供するために使われる行くつかのアノテーションを提供する。
JAX-RSは自動的にJavaの型をMIMEメディアタイプに変換する。例えば、クラスメソッドに"@Produces (MediaType.TEXT_PLAIN)"というアノテーションをつけたら、JAX-RSはそのJavaの型をプレーンテキストをあらわす"text/plain"MIMEタイプに変換し、クライアントへのHTTPレスポンスの中にそのタイプの内容を返すだろう。
Java EE 6はこの技術の最新のリリースJAX-RS 1.1に含まれている。このバージョンはメンテナンスリリースであり、JAX-RSをJava 6 EEの新しい機能に合わせるためのものだ。Jerseyは、そのJAX-RS仕様のオープンソースリファレンス実装である。Jersey 1.1.5はJAX-RS 1.1を実装している。
アノテーションはリソースを識別しHTTPリクエストを扱うために必要とされる情報を付与する。JAX-RSでサポートされているアノテーションをいくつかあげると次のようなものがある:
Path: このアノテーションはリソースの相対パスを指示する。@Pathはリソースクラスまたはクラスメソッドがリクエストを扱うことになるURIパスを特定する。
GET: @GETアノテーションはアノテーションのついたメソッドがHTTP GETリクエストを扱うものであるということを示す。クライアントがウェブリソースのURIにリクエストを行った時、JAX-RSランタイムはそのGETリクエストを扱うためにこのアノテーションのついたjavaメソッドを起動する。
POST: @POSTアノテーションはアノテーションのついたメソッドがHTTP POSTリクエストに応答するものであることを示す。
Produces: このアノテーションはリソースのメソッドが生成し、クライアントに返却することができるMIMEメディアタイプを示す。
Consumes: @Consumesアノテーションはリソースのメソッドがクライアントから受け入れられるMIMEメディアタイプを示す。@Producesアノテーションの場合と同じように、@Consumesがあるクラスに対して指示されたら、そのクラスのすべてのメソッドに適用される。@Consumesがメソッドに対して指示されたら、クラスに対して指示したいかなる@ConsumesアノテーションもそのMIMEタイプで上書きされる。
JAX-RSはまた、リクエストから情報を取り出すのに使われるパラメータベースのアノテーションのような便利な機能を他にも持っている。これらのアノテーションの一つが@QueryParamであり、これはリクエストURLのクエリ構成要素からクエリパラメータを取り出すために使われる。他にもパラメータベースのアノテーションがあり、@MatrixParamはURLパスの断片から情報を取り出すために、@HeaderParamはHTTPヘッダから情報を取り出すために、そして@CookieParamはcookieに関連したHTTPヘッダに宣言されたcookieから情報を取り出すために利用される。
他にも、JavaでRESTfulWebサービスを構築し利用することに関する作業をずっと簡単にするかなりの数のユーティリティクラスやインターフェースがある。これらのクラスには以下のようなものがある:
JBoss由来のRESTEasyフレームワークはJAX-RS仕様のもう一つの実装である。ApacheのオープンソースサービスフレームワークCXFもそのバージョン2.3リリースの一部としてJAX-RS 1.1のサポートを提供するだろう。
【豆蔵】「オブジェクト指向を現場で活かすリファクタリング入門」新規講座キャンペーン中
【豆蔵】大好評のため、Jenkins講座を追加開催致します!Jenkins作者の川口氏が講師です。
Googleのクラウド環境をつかったGoogle App Engineによる開発するにあたり、初めての試みで苦悩する開発者達の経験をもとに、各開発フェーズにあわせて問題点やどう解決したかをご紹介します
去る1月12日、定理証明支援系ツールCoqの初心者向けチュートリアルが開催さ れた(http://kokucheese.com/event/index/23667/)。今後も2月2日 (http://kokucheese.com/event/index/23744/)、2月9日、2月16日と引き続き開 催されていく予定である。本記事では、開催の様子をレポートする。
Neal Gafter氏はOracleによるJava買収の影響に関する議論、Javaにセグメンテッドスタックやメタオブジェクトプロトコルを追加することについての主張、そしてJavaとC#との比較について話をしてくれた。
GoogleはVMをともなう新しい言語であり、JSコンパイラでもあるDartをプレビューした。 InfoQはDartのアプリの構築に貢献する文法の裏側を探った:スナップショット、Isolate、モジュール方式
本記事ではCSPベースの「マルチドメイン・モデル検査ツール」である、PAT(Process Analysis Toolkit)について紹介する。モデル検査は、形式手法(Formal Method)という方法論を基礎とする技術であり、複雑さが増大しながらも安全性を求められる、現在のソフトウェア開発の状況に対する処方箋の1つとして注目されている手法である。
前回まで、Jenkinsの幾つかの側面に注目して解説をしてきました。シリーズ最後の今回は、Jenkinsをサービスとして使う方法を紹介します。
Alloyは、MITにて開発された仕様記述言語であり、ツールによる自動解析を使い、インクリメンタルに形式仕様が書けることが特長である。筆者らはAlloy開発者による、Alloyを使った形式手法入門書を翻訳、今夏にオーム社より刊行した。本記事では、Alloyの簡単な概要と、翻訳書『抽象によるソフトウェア設計』(「Alloy本」)を紹介する。
スマートフォンを中心としたマルチデバイスにおけるタッチユーザーインターフェイスへの対応は、既に必須の項目となりつつある。本記事では、Windows デバイスにおける UX のベースとなっている「メトロ」というデザイン言語を掘り下げながら、既存環境を意識しつつもどのようにタッチユーザーインターフェイス開発に取り組んでいくべきであるかについて解説していく。
No comments
スレッド表示 返信