Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
爱吃血肠
spring-framework
提交
cb54f201
S
spring-framework
项目概览
爱吃血肠
/
spring-framework
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
spring-framework
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
cb54f201
编写于
2月 25, 2019
作者:
J
Juergen Hoeller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Break out of loop once an AspectJ advice has been found
Closes gh-22449
上级
f07014ad
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
8 deletion
+12
-8
spring-aop/src/main/java/org/springframework/aop/aspectj/AspectJProxyUtils.java
...va/org/springframework/aop/aspectj/AspectJProxyUtils.java
+12
-8
未找到文件。
spring-aop/src/main/java/org/springframework/aop/aspectj/AspectJProxyUtils.java
浏览文件 @
cb54f201
/*
* Copyright 2002-201
8
the original author or authors.
* Copyright 2002-201
9
the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
...
...
@@ -27,27 +27,31 @@ import org.springframework.aop.interceptor.ExposeInvocationInterceptor;
*
* @author Rod Johnson
* @author Ramnivas Laddad
* @author Juergen Hoeller
* @since 2.0
*/
public
abstract
class
AspectJProxyUtils
{
/**
* Add special advisors if necessary to work with a proxy chain that contains AspectJ advisors.
* This will expose the current Spring AOP invocation (necessary for some AspectJ pointcut matching)
* and make available the current AspectJ JoinPoint. The call will have no effect if there are no
* AspectJ advisors in the advisor chain.
* Add special advisors if necessary to work with a proxy chain that contains AspectJ advisors:
* concretely, {@link ExposeInvocationInterceptor} at the beginning of the list.
* <p>This will expose the current Spring AOP invocation (necessary for some AspectJ pointcut
* matching) and make available the current AspectJ JoinPoint. The call will have no effect
* if there are no AspectJ advisors in the advisor chain.
* @param advisors the advisors available
* @return {@code true} if any special {@link Advisor Advisors} were added, otherwise {@code false}
* @return {@code true} if an {@link ExposeInvocationInterceptor} was added to the list,
* otherwise {@code false}
*/
public
static
boolean
makeAdvisorChainAspectJCapableIfNecessary
(
List
<
Advisor
>
advisors
)
{
// Don't add advisors to an empty list; may indicate that proxying is just not required
if
(!
advisors
.
isEmpty
())
{
boolean
foundAspectJAdvice
=
false
;
for
(
Advisor
advisor
:
advisors
)
{
// Be careful not to get the Advice without a guard, as
//
this might eagerly instantiate a non-singleton AspectJ aspect
// Be careful not to get the Advice without a guard, as
this might eagerly
//
instantiate a non-singleton AspectJ aspect...
if
(
isAspectJAdvice
(
advisor
))
{
foundAspectJAdvice
=
true
;
break
;
}
}
if
(
foundAspectJAdvice
&&
!
advisors
.
contains
(
ExposeInvocationInterceptor
.
ADVISOR
))
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录