<div dir="ltr">佐々木です<div><br></div><div>中村様 ひが様 有益な状況ありがとうございます。</div><div><br></div><div>OGNLの利用バージョンは、ognl-2.6.9-patch-20070624.jar でしたのでsetterの実行調査から<br></div><div>調べたたいと思います。</div><div>ありがとうございました。</div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">2021年11月9日(火) 10:56 Yasuo Higa <<a href="mailto:higa@isid.co.jp">higa@isid.co.jp</a>>:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">





<div lang="JA" style="overflow-wrap: break-word;">
<div>
<p class="MsoNormal"><span style="font-family:"Yu Gothic",sans-serif">佐々木さん<span lang="EN-US"><u></u><u></u></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-family:"Yu Gothic",sans-serif"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-family:"Yu Gothic",sans-serif">Singleton</span><span style="font-family:"Yu Gothic",sans-serif">のコンポーネントは、システムの起動時にしかセットされないので、<span lang="EN-US"><u></u><u></u></span></span></p>
<p class="MsoNormal"><span style="font-family:"Yu Gothic",sans-serif">途中で<span lang="EN-US">null</span>になってしまうのは、誰かが<span lang="EN-US">null</span>を設定しているのだと思います。<span lang="EN-US"><u></u><u></u></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-family:"Yu Gothic",sans-serif"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-family:"Yu Gothic",sans-serif">Setter</span><span style="font-family:"Yu Gothic",sans-serif">で<span lang="EN-US">null</span>が渡ってきたら、例外を<span lang="EN-US">throw</span>するようにすれば、<span lang="EN-US"><u></u><u></u></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-family:"Yu Gothic",sans-serif">StackTrace</span><span style="font-family:"Yu Gothic",sans-serif">を見て、誰が<span lang="EN-US">null</span>を設定しているのか、<span lang="EN-US"><u></u><u></u></span></span></p>
<p class="MsoNormal"><span style="font-family:"Yu Gothic",sans-serif">ヒントがわかるかもしれません。<span lang="EN-US"><u></u><u></u></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-family:"Yu Gothic",sans-serif"><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-family:"Yu Gothic",sans-serif">ひが<span lang="EN-US"><u></u><u></u></span></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:11pt;font-family:"Yu Gothic",sans-serif"><u></u> <u></u></span></p>
<div style="border-right:none;border-bottom:none;border-left:none;border-top:1pt solid rgb(181,196,223);padding:3pt 0mm 0mm">
<p class="MsoNormal" style="margin-bottom:12pt"><b><span style="color:black">差出人</span></b><b><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">:
</span></b><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">Seasar-user <<a href="mailto:seasar-user-bounces@ml.seasar.org" target="_blank">seasar-user-bounces@ml.seasar.org</a>>
</span><span style="color:black">が代理で送信</span><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">: Isao SASAKI <<a href="mailto:sasaki.isao@gmail.com" target="_blank">sasaki.isao@gmail.com</a>><br>
</span><b><span style="color:black">日付</span></b><b><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">:
</span></b><span style="color:black">月曜日</span><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">, 2021</span><span style="color:black">年</span><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">11</span><span style="color:black">月</span><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">8</span><span style="color:black">日</span><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">
 17:16<br>
</span><b><span style="color:black">宛先</span></b><b><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">:
</span></b><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black"><a href="mailto:seasar-user@ml.seasar.org" target="_blank">seasar-user@ml.seasar.org</a> <<a href="mailto:seasar-user@ml.seasar.org" target="_blank">seasar-user@ml.seasar.org</a>><br>
</span><b><span style="color:black">件名</span></b><b><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">:
</span></b><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black">[Seasar-user:22169]
</span><span style="color:black">インジェクションしたインスタンスが参照できなくなる事象について</span><span lang="EN-US" style="font-family:Calibri,sans-serif;color:black"><u></u><u></u></span></p>
</div>
<div>
<div>
<p class="MsoNormal">佐々木ともうします<span lang="EN-US"><u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal"><span lang="EN-US"><u></u> <u></u></span></p>
</div>
<div>
<p class="MsoNormal">以下事象について経験がある方がいましたらなにかアドバイスを頂ければと思います。<span lang="EN-US"><u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal">レスポンス頂けるかわかりませんが一読いただければと思います。<span lang="EN-US"><u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal">よろしくお願いいたします。<span lang="EN-US"><u></u><u></u></span></p>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12pt"><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><u></u><u></u></span></p>
</div>
</div>
</div>
</div>

_______________________________________________<br>
Seasar-user mailing list<br>
<a href="mailto:Seasar-user@ml.seasar.org" target="_blank">Seasar-user@ml.seasar.org</a><br>
<a href="https://ml.seasar.org/mailman/listinfo/seasar-user" rel="noreferrer" target="_blank">https://ml.seasar.org/mailman/listinfo/seasar-user</a><br>
</blockquote></div><br clear="all"><div><br></div>-- <br><div dir="ltr" class="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div style="font-family:arial;font-size:small">------------</div><span style="font-family:arial;font-size:small"><Isao SASAKI/佐々木功 /></span><div style="font-family:arial;font-size:small"><br></div></div></div></div></div>