<?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%2FLog</id>
		<title>Java/Spring/Log - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FSpring%2FLog"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Spring/Log&amp;action=history"/>
		<updated>2026-04-21T10:47:03Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Spring/Log&amp;diff=6643&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Spring/Log&amp;diff=6643&amp;oldid=prev"/>
				<updated>2010-06-01T06:16:59Z</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/Log&amp;diff=6642&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/Log&amp;diff=6642&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;== Spring Aspect Logging ==&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: IBusinessLogic.java&lt;br /&gt;
&lt;br /&gt;
public interface IBusinessLogic&lt;br /&gt;
{&lt;br /&gt;
   public void foo();&lt;br /&gt;
   &lt;br /&gt;
   public void bar() throws BusinessLogicException;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: LoggingThrowsAdvice.java&lt;br /&gt;
import org.springframework.aop.ThrowsAdvice;&lt;br /&gt;
import java.lang.reflect.Method;&lt;br /&gt;
public class LoggingThrowsAdvice implements ThrowsAdvice&lt;br /&gt;
{&lt;br /&gt;
   public void afterThrowing(Method method, Object[] args, Object target, Throwable subclass)&lt;br /&gt;
   {&lt;br /&gt;
      System.out.println(&amp;quot;Logging that a &amp;quot; + subclass + &amp;quot;Exception was thrown.&amp;quot;);&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: MainApplication.java&lt;br /&gt;
&lt;br /&gt;
import org.springframework.context.ApplicationContext;&lt;br /&gt;
import org.springframework.context.support.FileSystemXmlApplicationContext;&lt;br /&gt;
public class MainApplication&lt;br /&gt;
{&lt;br /&gt;
   public static void main(String [] args)&lt;br /&gt;
   {&lt;br /&gt;
      // Read the configuration file&lt;br /&gt;
      ApplicationContext ctx&lt;br /&gt;
          = new FileSystemXmlApplicationContext(&amp;quot;build/springconfig.xml&amp;quot;);&lt;br /&gt;
      //Instantiate an object&lt;br /&gt;
      IBusinessLogic testObject = (IBusinessLogic) ctx.getBean(&amp;quot;businesslogicbean&amp;quot;);&lt;br /&gt;
      //Execute the public methods of the bean&lt;br /&gt;
      testObject.foo();&lt;br /&gt;
      &lt;br /&gt;
      try&lt;br /&gt;
      {&lt;br /&gt;
         testObject.bar();&lt;br /&gt;
      }&lt;br /&gt;
      catch(BusinessLogicException ble)&lt;br /&gt;
      {&lt;br /&gt;
         System.out.println(&amp;quot;Caught BusinessLogicException&amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: springconfig.xml&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE beans PUBLIC  &amp;quot;-//SPRING//DTD BEAN//EN&amp;quot; &amp;quot;http://www.springframework.org/dtd/spring-beans.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;beans&amp;gt;&lt;br /&gt;
  &amp;lt;!--CONFIG--&amp;gt;&lt;br /&gt;
  &amp;lt;bean id=&amp;quot;businesslogicbean&amp;quot;&lt;br /&gt;
  class=&amp;quot;org.springframework.aop.framework.ProxyFactoryBean&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;proxyInterfaces&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;value&amp;gt;IBusinessLogic&amp;lt;/value&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;target&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;ref local=&amp;quot;beanTarget&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;interceptorNames&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;list&amp;gt;&lt;br /&gt;
        &amp;lt;value&amp;gt;tracingBeforeAdvisor&amp;lt;/value&amp;gt;&lt;br /&gt;
        &amp;lt;value&amp;gt;tracingAfterAdvisor&amp;lt;/value&amp;gt;&lt;br /&gt;
        &amp;lt;value&amp;gt;loggingThrowsAdvisor&amp;lt;/value&amp;gt;&lt;br /&gt;
      &amp;lt;/list&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
  &amp;lt;/bean&amp;gt;&lt;br /&gt;
  &amp;lt;!--CLASS--&amp;gt;&lt;br /&gt;
  &amp;lt;bean id=&amp;quot;beanTarget&amp;quot;&lt;br /&gt;
  class=&amp;quot;BusinessLogic&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;!-- Advisor pointcut definition for before advice --&amp;gt;&lt;br /&gt;
  &amp;lt;bean id=&amp;quot;tracingBeforeAdvisor&amp;quot;&lt;br /&gt;
  class=&amp;quot;org.springframework.aop.support.RegexpMethodPointcutAdvisor&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;advice&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;ref local=&amp;quot;theTracingBeforeAdvice&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;pattern&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;value&amp;gt;.*&amp;lt;/value&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
  &amp;lt;/bean&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;!-- Advisor pointcut definition for after advice --&amp;gt;&lt;br /&gt;
  &amp;lt;bean id=&amp;quot;tracingAfterAdvisor&amp;quot;&lt;br /&gt;
  class=&amp;quot;org.springframework.aop.support.RegexpMethodPointcutAdvisor&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;advice&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;ref local=&amp;quot;theTracingAfterAdvice&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;pattern&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;value&amp;gt;.*&amp;lt;/value&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
  &amp;lt;/bean&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;!-- Advisor pointcut definition for throws advice --&amp;gt;&lt;br /&gt;
  &amp;lt;bean id=&amp;quot;loggingThrowsAdvisor&amp;quot;&lt;br /&gt;
  class=&amp;quot;org.springframework.aop.support.RegexpMethodPointcutAdvisor&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;advice&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;ref local=&amp;quot;theLoggingThrowsAdvice&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;pattern&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;value&amp;gt;.*&amp;lt;/value&amp;gt;&lt;br /&gt;
    &amp;lt;/property&amp;gt;&lt;br /&gt;
  &amp;lt;/bean&amp;gt;&lt;br /&gt;
  &amp;lt;!--ADVICE--&amp;gt;&lt;br /&gt;
  &amp;lt;bean id=&amp;quot;theTracingBeforeAdvice&amp;quot;&lt;br /&gt;
  class=&amp;quot;TracingBeforeAdvice&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;bean id=&amp;quot;theTracingAfterAdvice&amp;quot;&lt;br /&gt;
  class=&amp;quot;TracingAfterAdvice&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;bean id=&amp;quot;theLoggingThrowsAdvice&amp;quot;&lt;br /&gt;
  class=&amp;quot;LoggingThrowsAdvice&amp;quot;/&amp;gt;&lt;br /&gt;
&amp;lt;/beans&amp;gt;&lt;br /&gt;
&lt;br /&gt;
File: TracingAfterAdvice.java&lt;br /&gt;
import java.lang.reflect.Method;&lt;br /&gt;
import org.springframework.aop.AfterReturningAdvice;&lt;br /&gt;
public class TracingAfterAdvice implements AfterReturningAdvice&lt;br /&gt;
{&lt;br /&gt;
   public void afterReturning(Object object, Method m, Object[] args, Object target) throws Throwable&lt;br /&gt;
   {&lt;br /&gt;
       System.out.println(&amp;quot;Hello world! (by &amp;quot; + this.getClass().getName() + &amp;quot;)&amp;quot;);&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: TracingBeforeAdvice.java&lt;br /&gt;
import java.lang.reflect.Method;&lt;br /&gt;
import org.springframework.aop.MethodBeforeAdvice;&lt;br /&gt;
public class TracingBeforeAdvice implements MethodBeforeAdvice&lt;br /&gt;
{&lt;br /&gt;
   public void before(Method m, Object[] args, Object target) throws Throwable&lt;br /&gt;
   {&lt;br /&gt;
      System.out.println(&amp;quot;Hello world! (by &amp;quot; + this.getClass().getName() + &amp;quot;)&amp;quot;);&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: BusinessLogic.java&lt;br /&gt;
&lt;br /&gt;
public class BusinessLogic implements IBusinessLogic&lt;br /&gt;
{&lt;br /&gt;
     public void foo() &lt;br /&gt;
     {&lt;br /&gt;
       System.out.println(&amp;quot;Inside BusinessLogic.foo()&amp;quot;);&lt;br /&gt;
     }&lt;br /&gt;
     &lt;br /&gt;
     public void bar() throws BusinessLogicException&lt;br /&gt;
     {&lt;br /&gt;
        System.out.println(&amp;quot;Inside BusinessLogic.bar()&amp;quot;);&lt;br /&gt;
        throw new BusinessLogicException();&lt;br /&gt;
     }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: BusinessLogicException.java&lt;br /&gt;
&lt;br /&gt;
public class BusinessLogicException extends Exception&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>