<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:游ゴシック;
panose-1:2 11 4 0 0 0 0 0 0 0;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
{font-family:"MS Pゴシック";
panose-1:2 11 6 0 7 2 5 8 2 4;}
@font-face
{font-family:"\@MS Pゴシック";}
@font-face
{font-family:"\@游ゴシック";
panose-1:2 11 4 0 0 0 0 0 0 0;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0mm;
font-size:12.0pt;
font-family:"MS Pゴシック";}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:#0563C1;
text-decoration:underline;}
span.18
{mso-style-type:personal-reply;
font-family:游ゴシック;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-family:游ゴシック;}
@page WordSection1
{size:612.0pt 792.0pt;
margin:99.25pt 30.0mm 30.0mm 30.0mm;}
div.WordSection1
{page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026">
<v:textbox inset="5.85pt,.7pt,5.85pt,.7pt" />
</o:shapedefaults></xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="JA" link="#0563C1" vlink="#954F72" style="word-wrap:break-word">
<div class="WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:游ゴシック">中村です。<span lang="EN-US"><o:p></o:p></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:游ゴシック"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:游ゴシック">OGNL</span><span style="font-size:11.0pt;font-family:游ゴシック">のバージョンは何を使っていますか?<span lang="EN-US"><o:p></o:p></span></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:游ゴシック">随分昔ですが似たような問題に遭遇したことがあります。<span lang="EN-US"><o:p></o:p></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:游ゴシック"><a href="https://www.seasar.org/issues/browse/CONTAINER-45">https://www.seasar.org/issues/browse/CONTAINER-45</a><o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:游ゴシック"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:游ゴシック">もし<span lang="EN-US">ognl-2.6.9</span>以下を使っているならば<span lang="EN-US"><o:p></o:p></span></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:游ゴシック">リンク先のコメントに書いてある<span lang="EN-US">ognl-2.6.9-patch-20070624.jar</span>を使ってみてください。<span lang="EN-US"><o:p></o:p></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:游ゴシック">Seasar2</span><span style="font-size:11.0pt;font-family:游ゴシック">の配布ファイルに同梱されていると思います。<span lang="EN-US"><o:p></o:p></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:游ゴシック"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:游ゴシック">なお、どのバージョンか忘れましたが<span lang="EN-US">OGNL</span>本体にも修正を取り込んでもらっています。<span lang="EN-US"><o:p></o:p></span></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:游ゴシック">そちらのバージョンを使うでもよいかもしれません。<span lang="EN-US"><o:p></o:p></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11.0pt;font-family:游ゴシック"><o:p> </o:p></span></p>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0mm 0mm 0mm">
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:11.0pt;font-family:"Calibri",sans-serif">From:</span></b><span lang="EN-US" style="font-size:11.0pt;font-family:"Calibri",sans-serif"> Seasar-user <seasar-user-bounces@ml.seasar.org>
<b>On Behalf Of </b>Isao SASAKI<br>
<b>Sent:</b> Monday, November 8, 2021 5:16 PM<br>
<b>To:</b> seasar-user@ml.seasar.org<br>
<b>Subject:</b> [Seasar-user:22169] </span><span style="font-size:11.0pt">インジェクションしたインスタンスが参照できなくなる事象について</span><span lang="EN-US" style="font-size:11.0pt;font-family:"Calibri",sans-serif"><o:p></o:p></span></p>
</div>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
<div>
<div>
<p class="MsoNormal">佐々木ともうします<span lang="EN-US"><o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal">以下事象について経験がある方がいましたらなにかアドバイスを頂ければと思います。<span lang="EN-US"><o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal">レスポンス頂けるかわかりませんが一読いただければと思います。<span lang="EN-US"><o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal">よろしくお願いいたします。<span lang="EN-US"><o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><span lang="EN-US"><br>
</span>【事象】<span lang="EN-US"><br>
</span>セッター・インジェクションで取得したインスタンスが<span lang="EN-US">null</span>になってしまいます。<span lang="EN-US"><br>
</span>必ず<span lang="EN-US">null</span>になる訳ではなく、システム起動からずっと取得出来ていたものが突然<span lang="EN-US">null</span>しか取得できなくなり事があります。<span lang="EN-US"><br>
</span>一度<span lang="EN-US">null</span>になると、以降はアプリケーションサーバー(<span lang="EN-US">Tomcat</span>)の再起動するまで<span lang="EN-US">null</span>になってしまいます。<span lang="EN-US"><br>
</span>何がトリガーとなって<span lang="EN-US">null</span>になってしまうのかが分からない状態です。<span lang="EN-US"><br>
<br>
</span>インジェクションが外れてしまうのは<span lang="EN-US">Dao</span>(<span lang="EN-US">S2Dao</span>)のインスタンスです。<span lang="EN-US"><br>
</span>コード、<span lang="EN-US">dicon</span>の内容を抜粋添付します。<span lang="EN-US"><br>
<br>
</span>【ご教授頂きたい内容】<span lang="EN-US"><br>
</span>インジェクションで<span lang="EN-US">null</span>が発生しないようにする方法<span lang="EN-US"> <br>
</span>または<span lang="EN-US"><br>
null</span>になった場合に再度インジェクションするための対応方法<span lang="EN-US"><br>
<br>
Seasar</span>バージョン<span lang="EN-US"> 2.3.23<br>
S2Dao</span>バージョン<span lang="EN-US"> 1.0.51<br>
java</span>バージョン<span lang="EN-US"> jdk1.7.0_79<br>
Tomcat</span>バージョン<span lang="EN-US"> Apache Tomcat/7.0.75<br>
</span>稼働<span lang="EN-US">OS CentOS7<br>
<br>
※</span>インジェクションが<span lang="EN-US">NULL</span>になってしまう<span lang="EN-US">setTmUserDao</span>での<span lang="EN-US">tmUserDao</span>というインスタンス<span lang="EN-US"><br>
<br>
</span>・実装の抜粋<span lang="EN-US"><br>
java</span>ファイル(<span lang="EN-US">tmUserDao</span>をインジェクションしている)<span lang="EN-US"><br>
1: public void setTmUserDao(TmUserDao tmUserDao) {<br>
2: this.tmUserDao = tmUserDao;<br>
3: }<br>
4:<br>
5: @Aspect("j2ee.requiredTx")<br>
6: public BcmLoginServiceDto doLogin(String userId, String password,<br>
7: String ipAddress, Long storecd) {<br>
8:<br>
9: BcmLoginServiceDto bcmLoginServiceDto = new BcmLoginServiceDto();<br>
10: List<TmUserEntity> list = null;<br>
11: //</span>障害のためのログ入れ<span lang="EN-US"> start<br>
12: if (this.tmUserDao!=null) {<br>
13: System.out.println("BcmLoginService doLogin : TmUserDao is not null");<br>
14: } else {<br>
15: System.out.println("BcmLoginService doLogin : TmUserDao is null");<br>
16: }<br>
17: //</span>障害のためのログ入れ<span lang="EN-US"> end<br>
18: if(storecd != null && Constants.MORU_STORE_CD == storecd) {<br>
19: list = this.tmUserDao.selectByUserIdPasswordPermission(userId,password);<br>
10: } else {<br>
21: list = this.tmUserDao.selectByUserIdPassword(userId,password);<br>
22: }<br>
<br>
※11</span>~<span lang="EN-US">17</span>行目は確認のためのログ<span lang="EN-US"><br>
※19,21</span>行目で、<span lang="EN-US">NullPointerException</span>が発生<span lang="EN-US"><br>
※NullPointerException</span>発生時には<span lang="EN-US">15</span>行目のログが出力されている(<span lang="EN-US">TmUserDao</span>が<span lang="EN-US">null</span>になっている)<span lang="EN-US">
<br>
<br>
dicon</span>ファイル<span lang="EN-US"><br>
<component class="org.seasar.framework.container.autoregister.FileSystemComponentAutoRegister"><br>
<property name="instanceDef"><br>
@org.seasar.framework.container.deployer.InstanceDefFactory@SINGLETON<br>
</property><br>
<property name="autoNaming"><br>
<component class="org.seasar.framework.container.autoregister.DefaultAutoNaming"/><br>
</property><br>
<initMethod name="addClassPattern"><br>
<arg>"jp.co.itfor.itforec"</arg><br>
<arg>".*ServiceImpl,.*Dao,.*DAO,.*DxoImpl"</arg><br>
</initMethod><br>
<initMethod name="addIgnoreClassPattern"><br>
<arg>"jp.co.itfor.itforec.service.settlement.gmo"</arg><arg>"GmoServiceImpl"</arg><br>
</initMethod><br>
<initMethod name="addIgnoreClassPattern"><br>
<arg>"jp.co.itfor.itforec.service.settlement.wellnet"</arg><arg>"WellnetServiceImpl"</arg><br>
</initMethod><br>
</component><br>
<br>
<component class="org.seasar.framework.container.autoregister.FileSystemComponentAutoRegister"><br>
<property name="instanceDef"><br>
@org.seasar.framework.container.deployer.InstanceDefFactory@PROTOTYPE<br>
</property><br>
<property name="autoNaming"><br>
<component class="org.seasar.framework.container.autoregister.DefaultAutoNaming"/><br>
</property><br>
<initMethod name="addClassPattern"><br>
<arg>"jp.co.itfor.itforec"</arg><br>
<arg>".*LogicImpl"</arg><br>
</initMethod><br>
</component><br>
<br>
<!-- </span>アスペクトの自動登録<span lang="EN-US"> --><br>
<!-- Dao --><br>
<component class="org.seasar.framework.container.autoregister.AspectAutoRegister"><br>
<property name="interceptor"><br>
dao.interceptor<br>
</property><br>
<initMethod name="addClassPattern"><br>
<arg>"jp.co.itfor.itforec.dao"</arg><br>
<arg>".*Dao,.*DAO"</arg><br>
</initMethod><br>
</component><o:p></o:p></span></p>
</div>
</div>
</div>
</body>
</html>