2017-06-06 11 views
0

私が作成した注釈でマークするメソッドの実行時間を測るのにAOPの概念を使いたいです。しかし、私の問題は、同じクラス内から注釈付きのメソッドを内部的に参照することです。たとえば:AspectJを使うためにSpring AOPを設定するには

public void login(params) { 
    some logic ... 
    performLogin(); 
    some logic ... 
} 

@Measured 
public void performLogin() { 
    some logic ... 
} 

これは春AOPは、同じクラス内の内線通話を「見ない」プロキシベースのアプローチを使用しているという事実によって引き起こされる既知の問題です。どうやら、私はSpring AOPの代わりにAspectJを使ってこの状況を解決することができます。私が正しく理解していれば、それはSpring自体から構成することができます。私が見つけたことから、@EnableAspectJAutoProxy注釈を含めて、独自のAOPではなくAspectJを使用するようにSpringを設定する必要があります。残念なことに、それは助けにならず、注釈を追加した後、注釈付き方法の傍受は起こりませんでした。

このトピックについては、Springの参考資料にはたくさんのinformationがあり、少し失われてしまいました。 AspectJが使われるようにするために何か他にはありますか?

P.S.私はクラス全体をリファクタリングすることはできませんし、呼び出し元のメソッドを外部に移動することはできません。

P.P.S.ポイントカットの設定も確認しました。私は外部から呼び出される呼び出しメソッドに注釈を付け、うまくいきました。

答えて

0

プロキシは、実際にはAspectJシステムの完全な機能のサブセット、つまり基本的にメソッドをラップするアドバイスを得ることができます。唯一の公共のメンバーに

  • のみ外部コールの傍受(プロキシ境界を破るながら)
  • 傍受(保護/プライベートを傍受することはできません)、ローカル電話へ 無自覚を(:その性質プロキシが制限を以下ましたまたは十分ではありません

<aop:aspectj-autoproxy />)このまたはスーパーで呼び出す - それが唯一の方法をラップし、あなたはこのようなものが必要です。あなたの場合は<context:load-time-weaver/>

をたとえば、フィールドにアドバイスできるようにするには、Native AspectJの使用を有効にする必要があります。

+0

こんにちは、お返事ありがとうございます。これはまさに私がやろうとしていることです。ちょうど設定と苦労している。 –

+0

Java設定を使用している場合は、コンフィグレーションのために '@ EnableLoadTimeWeaving'を追加してください。 –

+1

のネイティブAspectJへのリンクもチェックしてください。また、 – JEY

関連する問題