<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <meta http-equiv="Content-Script-Type" content="text/javascript" />
    <meta http-equiv="Content-Style-Type" content="text/css" />
    <title>オブジェクトスコープ</title>
    <link rel="stylesheet" href="/css/style.css" type="text/css" media="all" />
    
    
  </head>
  <body>
    <div class="header">
      <div id="pane.left-header" class="pane left">
        <div id="org.seasar.kvasir.cms.toolbox.customPop-2" class="pop org.seasar.kvasir.cms.toolbox.customPop">
          <div class="body"><div class="wiki">
<ul>
<li><a href="/" class="pageNotFound">（サイトトップ）</a></li>
<li><a href="/download">ダウンロード</a></li>
<li><a href="/news/" class="pageNotFound">新着情報</a></li>
<li><a href="/docs/" class="pageNotFound">ドキュメント</a></li>
</ul>
</div>
</div>
        </div>
      </div>
      <div id="pane.right-header" class="pane right">
        <div id="org.seasar.kvasir.cms.toolbox.loginPop-1" class="pop org.seasar.kvasir.cms.toolbox.loginPop">
          <div class="body">
<form method="post" action="/plugins/toolbox/login.do/docs/1.0.x/ref/objectScope">
    <div class="row">
      <span class="label">Name</span>
      <span class="textinput"><input type="text" name="name" size="12" value="" /></span>
    </div>
    <div class="row">
      <span class="label">Password</span>
      <span class="textinput"><input type="password" name="password" size="12" value="" /></span>
    </div>
    <div class="row">
      <span class="submit"><input type="submit" value="Login" /></span>
    </div>
</form>
</div>
        </div><div id="org.seasar.kvasir.cms.pop.loginUserPop-1" class="pop org.seasar.kvasir.cms.pop.loginUserPop">
          <div class="body"></div>
        </div>
      </div>
    </div>
    <div class="page-frame">
      <div id="pane.left-sidebar" class="pane sidebar-frame sidebar subcontent">
        <div id="org.seasar.kvasir.cms.toolbox.searchPop-1" class="pop org.seasar.kvasir.cms.toolbox.searchPop">
          <h2 class="title">Search</h2>
          <div class="body"><form class="simple" method="get" action="/plugins/toolbox/search.do">
  <input type="text" name="query" size="12" />
  <input type="submit" value="Go!" />
</form>
</div>
        </div><div id="org.seasar.kvasir.cms.toolbox.customPop-1" class="pop org.seasar.kvasir.cms.toolbox.customPop">
          <h2 class="title">メニュー</h2>
          <div class="body"><ul>
  <li><a href="/" class="pageNotFound">（サイトトップ）</a></li>
  <li><a href="/download">ダウンロード</a></li>
  <li><a href="/news">新着情報</a></li>
  
    
    
      <li>
        <a href="/docs/1.0.x/user">ユーザマニュアル</a>
        <ul>
          <li>
            <a href="/docs/1.0.x/user/description">Ymirとは</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/processFlow">Ymirの処理フロー</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/projectStatus">動作ステータス</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/generator">自動生成機能</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/vili">Eclipseプラグイン「Vili（ヴィリ）」</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/ve">Eclipseプラグイン「Ve（ヴェー）」</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/setUp">セットアップ</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/skeleton">空のアプリケーション</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/example">サンプルアプリケーションの作成</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/development">開発における注意点</a>
            
          </li><li>
            <a href="/docs/1.0.x/user/faq">FAQ</a>
            
          </li>
        </ul>
      </li><li>
        <a href="/docs/1.0.x/ref">リファレンスマニュアル</a>
        <ul>
          <li>
            <a href="/docs/1.0.x/ref/pageClass">Pageクラス</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/pathMapping">リクエストパスとPageクラスのマッピング</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/response">レスポンス</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/fileupload">ファイルアップロード</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/typeConversion">型の自動変換</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/zptTemplate">ZPTテンプレート</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/constraintCheck">制約チェック</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/validation">バリデーション</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/transactionToken">トランザクショントークン</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/permissionCheck">権限チェック</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/objectScope">オブジェクトスコープ</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/i18n">国際化</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/exceptionHandler">例外処理</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/include">インクルード</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/conversation">カンバセーション</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/appProperties">アプリケーションの設定</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/dicon">diconファイルの扱い</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/standardArchitecture">アプリケーションアーキテクチャ標準</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/ymirJson">JSON連携</a>
            
          </li><li>
            <a href="/docs/1.0.x/ref/batch">バッチプログラムの作成</a>
            
          </li>
        </ul>
      </li><li>
        <a href="/docs/1.0.x/dev">Ymir開発者マニュアル</a>
        <ul>
          <li>
            <a href="/docs/1.0.x/dev/build">Ymirのビルド</a>
            
          </li><li>
            <a href="/docs/1.0.x/dev/release">Ymirのリリース</a>
            
          </li><li>
            <a href="/docs/1.0.x/dev/update-ymir-fragment-dbflute">DBFluteフラグメントの更新</a>
            
          </li>
        </ul>
      </li><li>
        <a href="/docs/1.0.x/etc">その他</a>
        
      </li><li>
        <a href="/docs/1.0.x/glossary">用語集</a>
        <ul>
          <li>
            <a href="/docs/1.0.x/glossary/Vili">Vili</a>
            
          </li><li>
            <a href="/docs/1.0.x/glossary/ve">Ve</a>
            
          </li>
        </ul>
      </li>
    
  
  <li><a href="/roadmap">ロードマップ</a></li>
  <li><a href="https://www.seasar.org/issues/browse/YMIR">既知の不具合を閲覧する・不具合を報告する</a></li>
  <li><a href="https://www.seasar.org/svn/ymir/">SVNリポジトリ</a></li>
  <li><a href="http://svn.seasar.org/browse/?root=ymir">SVNリポジトリを閲覧</a></li>
</ul>
</div>
        </div>
      </div>
      <div id="pane.main" class="pane main">
      
        <div id="org.seasar.kvasir.cms.toolbox.breadcrumbsPop-1" class="pop org.seasar.kvasir.cms.toolbox.breadcrumbsPop">
          
          <div class="body"><ul>
  <li class="first"><a href="/">(TOP)</a></li><li><a href="/docs">ドキュメント</a></li><li><a href="/docs/1.0.x">ドキュメント（1.0.x系）</a></li><li><a href="/docs/1.0.x/ref">リファレンスマニュアル</a></li><li>オブジェクトスコープ</li>
</ul>
</div>
        </div><div id="org.seasar.kvasir.cms.pop.contentPop-1" class="pop org.seasar.kvasir.cms.pop.contentPop">
          <h2 class="title">オブジェクトスコープ</h2>
          <div class="body">
<ul class="information">
  
  <li>2008-10-30 23:44:11</li>
</ul>
<div class="content"><div class="document">
<p>Webアプリケーションを作成する場合は、オブジェクトの有効範囲（スコープ）を上手に扱うことが重要になってきます。</p>
<p>サーブレットの世界にはスコープとしてrequestスコープ、sessionスコープ、applicationスコープなどがあります。Ymirでもこれらのスコープにオブジェクトをバインドしたりスコープからオブジェクトを取り出したりすることができますが、サーブレットAPIを直接使わずにスコープに関する操作が行なえるようになっています。</p>
<div class="section" id="e382b9e382b3e383bce38397e3818be38289e381aee382aae38396e382b8e382a7e382afe38388e381aee382a4e383b3e382b8e382a7e382afe382b7e383a7e383b3">
<h3><a name="e382b9e382b3e383bce38397e3818be38289e381aee382aae38396e382b8e382a7e382afe38388e381aee382a4e383b3e382b8e382a7e382afe382b7e383a7e383b3">スコープからのオブジェクトのインジェクション</a></h3>
<p>スコープからオブジェクトを取り出すことをインジェクションと言います。</p>
<p>オブジェクトをインジェクトしたい場合はorg.seasar.ymir.scope.annotation.Inアノテーションを付与したSetterメソッドを用意します。</p>
<p>Setterメソッドに対応するプロパティの名前がオブジェクトをスコープにインジェクトする際のキーになります。違うキーを指定したい場合は@Inアノテーションのnameプロパティでキー文字列を指定して下さい。</p>
<p>以下の例は、sessionスコープに「value」というキーでバインドされているオブジェクトをインジェクトするためのコードです。</p>
<pre class="literal-block">
@In(SessionScope.class)
public void setValue(Object value)
{
    value_ = value;
}
</pre>
<p>対応するキーでバインドされているオブジェクトが存在しない場合は通常Setterメソッドは呼び出されません。オブジェクトが存在しない場合にもSetterメソッドを呼び出したい場合は@Inアノテーションに「injectWhereNull=true」というプロパティを追加して下さい。</p>
<p>インジェクション処理は制約チェックの前に行なわれます。</p>
<p>インジェクションはどのアクション呼び出しに関しても常に行なわれますが、@Inアノテーションに「actionName」プロパティを指定することで、特定のアクションの時だけ行なわせることもできます。</p>
<pre class="literal-block">
@In(scopeClass = SessionScope.class, actionName = { &quot;_post&quot;, &quot;_post_done&quot; })
public void setValue(Object value)
{
    value_ = value;
}
</pre>
<p>上の例では、リクエストが<tt class="docutils literal"><span class="pre">_post</span></tt>アクションまたは<tt class="docutils literal"><span class="pre">_post_done</span></tt>アクションを呼び出すケースのみセッションスコープからオブジェクトがインジェクトされます。</p>
</div>
<div class="section" id="e382b9e382b3e383bce38397e381b8e381aee382aae38396e382b8e382a7e382afe38388e381aee382a2e382a6e38388e382b8e382a7e382afe382b7e383a7e383b3">
<h3><a name="e382b9e382b3e383bce38397e381b8e381aee382aae38396e382b8e382a7e382afe38388e381aee382a2e382a6e38388e382b8e382a7e382afe382b7e383a7e383b3">スコープへのオブジェクトのアウトジェクション</a></h3>
<p>スコープにオブジェクトをバインドすることをアウトジェクションと言います。</p>
<p>オブジェクトをアウトジェクトしたい場合はorg.seasar.ymir.annotation.Outアノテーションを付与したGetterメソッドをPageクラスに用意します。</p>
<p>Getterメソッドに対応するプロパティの名前がオブジェクトをスコープからアウトジェクトする際のキーになります。違うキーを指定したい場合は@Outアノテーションのnameプロパティでキー文字列を指定して下さい。</p>
<p>以下の例は、sessionスコープに「value」という名前でGetterメソッドの返り値をアウトジェクトするためのコードです。</p>
<pre class="literal-block">
@Out(SessionScope.class)
public Object getValue()
{
    return value_;
}
</pre>
<p>オブジェクトをスコープからアンバインドしたい場合はGetterメソッドがnullを返すようにして下さい。Getterメソッドがnullを返す場合にオブジェクトをスコープからアンバインドしたくない場合は@Outアノテーションに「outjectWhereNull=false」というプロパティを追加して下さい。</p>
<p>アウトジェクション処理はアクションの呼び出しの後（<tt class="docutils literal"><span class="pre">_prerender</span></tt>メソッドの呼び出しがあればその後）に行なわれます。</p>
<p>アウトジェクションはどのアクション呼び出しに関しても常に行なわれますが、@Outアノテーションに「actionName」プロパティを指定することで、特定のアクションの時だけ行なわせることもできます。</p>
<pre class="literal-block">
@Out(scopeClass = SessionScope.class, actionName = { &quot;_post&quot;, &quot;_post_done&quot; })
public Object getValue()
{
    return value_;
}
</pre>
<p>上の例では、リクエストが<tt class="docutils literal"><span class="pre">_post</span></tt>アクションまたは<tt class="docutils literal"><span class="pre">_post_done</span></tt>アクションを呼び出すケースのみgetValue()の値がセッションスコープにアウトジェクトされます。</p>
</div>
<div class="section" id="e5ae9ae7bea9e6b888e381bfe381aee382b9e382b3e383bce38397">
<h3><a name="e5ae9ae7bea9e6b888e381bfe381aee382b9e382b3e383bce38397">定義済みのスコープ</a></h3>
<p>定義済みのスコープには以下のものがあります。</p>
<dl class="docutils">
<dt>request</dt>
<dd>
<p>現在のリクエストの間だけ有効なスコープです。</p>
<p>オブジェクトの操作はHttpServletRequest#getAttribute()、HttpServletRequest#setAttribute()によって行なわれます。</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.RequestScopeです。</p>
</dd>
<dt>session</dt>
<dd>
<p>現在のHTTPセッションの間だけ有効なスコープです。</p>
<p>オブジェクトの操作はHttpSession#getAttribute()、HttpSession#setAttribute()によって行なわれます。</p>
<p>オブジェクトをバインドする際にセッションが存在しない場合はセッションを生成してからバインドします。オブジェクトを取り出す際にセッションが存在しない場合は取り出した結果はnullになります。</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.SessionScopeです。</p>
</dd>
<dt>application</dt>
<dd>
<p>Webアプリケーションが起動している間有効なスコープです。</p>
<p>オブジェクトの操作はServletContext#getAttribute()、ServletContext#setAttribute()</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.ApplicationScopeです。</p>
</dd>
<dt>cookie</dt>
<dd>
<p>HTTP Cookieに対応するスコープです。</p>
<p>スコープからのインジェクションはリクエストからCookieの値を取り出す操作に対応します。スコープへのアウトジェクションはレスポンスにCookieを設定する操作に対応します。</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.CookieScopeです。</p>
</dd>
<dt>requestParameter</dt>
<dd>
<p>リクエストパラメータ及びURLパラメータを読み出すためのスコープです。</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.RequestParameterScopeです。</p>
</dd>
<dt>extendedRequestParameter</dt>
<dd>
<p>拡張されたリクエストパラメータを読み出すためのスコープです。</p>
<p>例えばYmirのJSONモジュールを使ってJSON通信を行なう場合のJSONリクエストの内容といった、通常のリクエストパラメータとは別の拡張されたリクエストパラメータを読み出すためのスコープです。</p>
<p>ymir-coreモジュールだけを使用している場合はこのスコープの内容は空です。このスコープが保持するオブジェクトはYmirのモジュール毎に定義されます。</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.ExtendedRequestParameterScopeです。</p>
</dd>
<dt>requestHeader</dt>
<dd>
<p>HTTPリクエストヘッダを読み出すためのスコープです。</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.RequestHeaderScopeです。</p>
</dd>
<dt>responseHeader</dt>
<dd>
<p>HTTPレスポンスヘッダを設定するためのアウトジェクト専用のスコープです。</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.ResponseHeaderScopeです。</p>
</dd>
<dt>component</dt>
<dd>
<p>DIコンテナからオブジェクトを取り出すためのスコープです。</p>
<p>スコープを表すクラスはorg.seasar.ymir.scope.impl.ComponentScopeです。</p>
</dd>
<dt>conversation</dt>
<dd>
<p>conversationスコープです。</p>
<p>conversationスコープについては「<a class="reference pageNotFound" href="/docs/1.0.x/ref/conversation#conversatione382b9e382b3e383bce38397">conversationスコープ</a>」を参照して下さい。</p>
<p>スコープを表すクラスはorg.seasar.ymir.conversation.impl.ConversationScopeです。</p>
</dd>
<dt>redirection</dt>
<dd>
<p>リダイレクトをまたがって存在するスコープです。このスコープに保存されたオブジェクトは一度限りのリダイレクトをまたがって保持されます。</p>
<p>フレーム等を使った、一画面を表示するために複数リクエストを発行するタイプのアプリケーションや、複数ウィンドウを同時に開いたりするタイプのアプリケーションではこの機能が正しく働かないことがあります。その場合は以下の内容のymir-component+redirectionManager.diconファイルを作ってsrc/main/resourcesに置くようにして下さい:</p>
<pre class="literal-block">
&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;
&lt;!DOCTYPE components PUBLIC &quot;-//SEASAR//DTD S2Container 2.4//EN&quot;
  &quot;http://www.seasar.org/dtd/components24.dtd&quot;&gt;
&lt;components&gt;
  &lt;component name=&quot;redirectionManager&quot;
  class=&quot;org.seasar.ymir.redirection.impl.RedirectionManagerImpl&quot;&gt;
    &lt;property name=&quot;addScopeIdAsRequestParameter&quot;&gt;true&lt;/property&gt;
  &lt;/component&gt;
&lt;/components&gt;
</pre>
<p>スコープを表すクラスはorg.seasar.ymir.redirection.impl.RedirectionScopeです。</p>
</dd>
</dl>
</div>
</div>
</div>
</div>
        </div>
      
    </div>
    </div>
    <div class="footer-delimiter"></div>
    <div id="pane.footer" class="pane footer">
      <div id="org.seasar.kvasir.cms.pop.poweredByPop-1" class="pop org.seasar.kvasir.cms.pop.poweredByPop">
        <div class="body">Powered by Kvasir/Sora</div>
      </div>
    </div>
  </body>
</html>
