<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FSpring%2FAfterReturningAdvice</id>
		<title>Java/Spring/AfterReturningAdvice - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FSpring%2FAfterReturningAdvice"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Spring/AfterReturningAdvice&amp;action=history"/>
		<updated>2026-04-24T23:39:13Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Spring/AfterReturningAdvice&amp;diff=6545&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Spring/AfterReturningAdvice&amp;diff=6545&amp;oldid=prev"/>
				<updated>2010-06-01T06:16:21Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 06:16, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Spring/AfterReturningAdvice&amp;diff=6544&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Spring/AfterReturningAdvice&amp;diff=6544&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:44Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== AfterReturningAdvice Demo ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
File: Main.java&lt;br /&gt;
import org.springframework.aop.Advisor;&lt;br /&gt;
import org.springframework.aop.aspectj.AspectJExpressionPointcut;&lt;br /&gt;
import org.springframework.aop.framework.ProxyFactory;&lt;br /&gt;
import org.springframework.aop.support.DefaultPointcutAdvisor;&lt;br /&gt;
import bean.MyClass;&lt;br /&gt;
import bean.SimpleAfterAdvice;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    MyClass target = new MyClass();&lt;br /&gt;
    AspectJExpressionPointcut pc = new AspectJExpressionPointcut();&lt;br /&gt;
    pc.setExpression(&amp;quot;execution(* bean..*.get*(..))&amp;quot;);&lt;br /&gt;
    Advisor advisor = new DefaultPointcutAdvisor(pc, new SimpleAfterAdvice());&lt;br /&gt;
    ProxyFactory pf = new ProxyFactory();&lt;br /&gt;
    pf.setTarget(target);&lt;br /&gt;
    pf.addAdvisor(advisor);&lt;br /&gt;
    MyClass proxy = (MyClass) pf.getProxy();&lt;br /&gt;
    System.out.println(proxy.getName());&lt;br /&gt;
    proxy.setName(&amp;quot;New Name&amp;quot;);&lt;br /&gt;
    System.out.println(proxy.getHeight());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
File: MyClass.java&lt;br /&gt;
package bean;&lt;br /&gt;
&lt;br /&gt;
public class MyClass {&lt;br /&gt;
    public String getName() {&lt;br /&gt;
        return &amp;quot;AAA&amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    public void setName(String name) {&lt;br /&gt;
    }&lt;br /&gt;
    public int getHeight() {&lt;br /&gt;
        return 201;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: SimpleAfterAdvice.java&lt;br /&gt;
package bean;&lt;br /&gt;
import org.springframework.aop.AfterReturningAdvice;&lt;br /&gt;
import java.lang.reflect.Method;&lt;br /&gt;
&lt;br /&gt;
public class SimpleAfterAdvice implements AfterReturningAdvice{&lt;br /&gt;
    public void afterReturning(Object returnValue, Method method, Object[] args, Object target) throws Throwable {&lt;br /&gt;
        System.out.println(&amp;quot;After method: &amp;quot; + method);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
       &lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Check Logic In AfterReturningAdvice ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
       &lt;br /&gt;
File: Main.java&lt;br /&gt;
import java.lang.reflect.Method;&lt;br /&gt;
import org.springframework.aop.AfterReturningAdvice;&lt;br /&gt;
import org.springframework.aop.framework.ProxyFactory;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    KeyGenerator target = new KeyGenerator();&lt;br /&gt;
    ProxyFactory factory = new ProxyFactory();&lt;br /&gt;
    factory.setTarget(target);&lt;br /&gt;
    factory.addAdvice(new WeakKeyCheckAdvice());&lt;br /&gt;
    KeyGenerator keyGen = (KeyGenerator) factory.getProxy();&lt;br /&gt;
    System.out.println(&amp;quot;Key: &amp;quot; + keyGen.getKey());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class KeyGenerator {&lt;br /&gt;
  public static final long WEAK_KEY = 1L;&lt;br /&gt;
  public static final long STRONG_KEY = 2L;&lt;br /&gt;
  public long getKey() {&lt;br /&gt;
    return WEAK_KEY;&lt;br /&gt;
    // return STRONG_KEY;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class WeakKeyCheckAdvice implements AfterReturningAdvice {&lt;br /&gt;
  public void afterReturning(Object returnValue, Method method, Object[] args, Object target)&lt;br /&gt;
      throws Throwable {&lt;br /&gt;
    if ((target instanceof KeyGenerator) &amp;amp;&amp;amp; (&amp;quot;getKey&amp;quot;.equals(method.getName()))) {&lt;br /&gt;
      long key = (Long) returnValue;&lt;br /&gt;
      if (key == KeyGenerator.WEAK_KEY) {&lt;br /&gt;
        System.out.println(&amp;quot;a weak key&amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== DefaultPointcutAdvisor and AfterReturningAdvice ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
File: Main.java&lt;br /&gt;
import org.springframework.aop.Advisor;&lt;br /&gt;
import org.springframework.aop.aspectj.AspectJExpressionPointcut;&lt;br /&gt;
import org.springframework.aop.framework.ProxyFactory;&lt;br /&gt;
import org.springframework.aop.support.DefaultPointcutAdvisor;&lt;br /&gt;
import bean.MyClass;&lt;br /&gt;
import bean.SimpleAfterAdvice;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    MyClass target = new MyClass();&lt;br /&gt;
    AspectJExpressionPointcut pc = new AspectJExpressionPointcut();&lt;br /&gt;
    pc.setExpression(&amp;quot;execution(* bean..*.get*(..))&amp;quot;);&lt;br /&gt;
    Advisor advisor = new DefaultPointcutAdvisor(pc, new SimpleAfterAdvice());&lt;br /&gt;
    ProxyFactory pf = new ProxyFactory();&lt;br /&gt;
    pf.setTarget(target);&lt;br /&gt;
    pf.addAdvisor(advisor);&lt;br /&gt;
    MyClass proxy = (MyClass) pf.getProxy();&lt;br /&gt;
    System.out.println(proxy.getName());&lt;br /&gt;
    proxy.setName(&amp;quot;New Name&amp;quot;);&lt;br /&gt;
    System.out.println(proxy.getHeight());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
File: MyClass.java&lt;br /&gt;
package bean;&lt;br /&gt;
&lt;br /&gt;
public class MyClass {&lt;br /&gt;
    public String getName() {&lt;br /&gt;
        return &amp;quot;AAA&amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    public void setName(String name) {&lt;br /&gt;
    }&lt;br /&gt;
    public int getHeight() {&lt;br /&gt;
        return 201;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: SimpleAfterAdvice.java&lt;br /&gt;
package bean;&lt;br /&gt;
import org.springframework.aop.AfterReturningAdvice;&lt;br /&gt;
import java.lang.reflect.Method;&lt;br /&gt;
&lt;br /&gt;
public class SimpleAfterAdvice implements AfterReturningAdvice{&lt;br /&gt;
    public void afterReturning(Object returnValue, Method method, Object[] args, Object target) throws Throwable {&lt;br /&gt;
        System.out.println(&amp;quot;After method: &amp;quot; + method);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== implements AfterReturningAdvice ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
       &lt;br /&gt;
File: Main.java&lt;br /&gt;
import java.lang.reflect.Method;&lt;br /&gt;
import org.springframework.aop.AfterReturningAdvice;&lt;br /&gt;
import org.springframework.aop.framework.ProxyFactory;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    MessageWriter target = new MessageWriter();&lt;br /&gt;
    // create the proxy&lt;br /&gt;
    ProxyFactory pf = new ProxyFactory();&lt;br /&gt;
    pf.addAdvice(new SimpleAfterReturningAdvice());&lt;br /&gt;
    pf.setTarget(target);&lt;br /&gt;
    MessageWriter proxy = (MessageWriter) pf.getProxy();&lt;br /&gt;
    // write the messages&lt;br /&gt;
    proxy.writeMessage();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class MessageWriter {&lt;br /&gt;
  public void writeMessage() {&lt;br /&gt;
      System.out.println(&amp;quot;A&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class SimpleAfterReturningAdvice implements AfterReturningAdvice {&lt;br /&gt;
  public void afterReturning(Object returnValue, Method method, Object[] args,&lt;br /&gt;
          Object target) throws Throwable {&lt;br /&gt;
      System.out.println(&amp;quot;After method: &amp;quot; + method.getName());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>