29

Im using Jersey Rest and want a Jersey filter to have access to some spring beans.

however as I've discovered from other threads, Jersey does not obtain Spring beans if they are Java proxies as opposed to generated java proxies. I want to add the proxy-target-class="true"

What are the impacts of doing so and also can this just be set on a single bean or does it need to be set on all referenced beans?

cdugga
  • 3,849
  • 17
  • 81
  • 127

4 Answers4

44

By setting proxy-target-class="true" you will be using CGLIB2 for your proxies, instead of jdk proxys.

The implications are the following, as described in the documentation:

  • final methods cannot be advised, as they cannot be overriden.

  • You will need the CGLIB 2 binaries on your classpath, whereas dynamic proxies are available with the JDK. Spring will automatically warn you when it needs CGLIB and the CGLIB library classes are not found on the classpath.

  • The constructor of your proxied object will be called twice. This is a natural consequence of the CGLIB proxy model whereby a subclass is generated for each proxied object. For each proxied instance, two objects are created: the actual proxied object and an instance of the subclass that implements the advice. This behavior is not exhibited when using JDK proxies. Usually, calling the constructor of the proxied type twice, is not an issue, as there are usually only assignments taking place and no real logic is implemented in the constructor.

Also, you should be able to make a "target-proxy" for a specific component by using

proxyMode=ScopedProxyMode.TARGET_CLASS
MikaelF
  • 3,518
  • 4
  • 20
  • 33
garst
  • 6,042
  • 1
  • 29
  • 24
  • 1
    Note that is an error to create a aop-scoped proxy for a singleton bean. – Jose Luis Martin Mar 22 '13 at 11:00
  • It was an example. Edited to avoid confusion. – garst Mar 22 '13 at 11:19
  • but how exactly do i set it on a bean? For example this will fail complaining about the occurance of the proxy-target reference – cdugga Mar 22 '13 at 11:45
  • 1
    and further do i need to set it on all referenced beans? – cdugga Mar 22 '13 at 11:46
  • Hi @gargc Please Help!! I am facing following exception:org.springframework.aop.framework.AopConfigException: Could not generate CGLIB subclass of class [class com.mchange.v2.c3p0.ComboPooledDataSource]: Common causes of this problem include using a final class or a non-visible class; nested exception is java.lang.IllegalArgumentException: Cannot subclass final class class com.mchange.v2.c3p0.ComboPooledDataSource – Navdeep Singh Jul 05 '13 at 07:34
  • 2
    @NavdeepSingh the error message is clear: Cannot subclass final class class com.mchange.v2.c3p0.ComboPooledDataSource. That class is a final class, final class cannot subclassed. – Chrisma Andhika Oct 03 '13 at 07:37
  • @cdugga you can set it on a bean by putting this inside the xml element: – Dasmowenator Oct 30 '14 at 00:27
24

Forcing a CGLib-Proxy although the controller formally implements an interface (SpringBoot 1.2.3.RELEASE with Spring 4.1.6.RELEASE):

@Controller
@Scope( proxyMode = ScopedProxyMode.TARGET_CLASS )
public class ServiceImpl implements ServiceIntf
{ .... }

This enables valid and working @RequestMapping and @Transactional annotations

Heri
  • 4,368
  • 1
  • 31
  • 51
8

Use the following annotation in Java Spring Config class:

@EnableAspectJAutoProxy(proxyTargetClass = true)

rcde0
  • 4,192
  • 3
  • 21
  • 31
0

This is the way I made my test working:

MyTarget target = new MyTarget();
AspectJProxyFactory factory = new AspectJProxyFactory(target);
factory.setProxyTargetClass(true);
Enrico Giurin
  • 2,183
  • 32
  • 30