@ComponentScan在spring中无效的原因分析以及解决方法

技术@ComponentScan在spring中无效的原因分析以及解决方法这篇文章将为大家详细讲解有关@ComponentScan在spring中无效的原因分析以及解决方法,文章内容质量较高,因此小编分享给大家做个参考,

这篇文章将为大家详细讲解有关@组件扫描在春天中无效的原因分析以及解决方法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

@ComponentScan在spring中无效

在我实现第一个弹簧面向切面编程程序的时候,我按照主流的推荐,采用注解@组件扫描@方面@之前来实现一个切面。

让我十分纳闷的是。我的程序始终无法正确调用到通知。而且我的通知和主流的毫无差别。代码如下:

通知类,其中定义了切面:

打包。bfytech。spring _ 8 _ bean 3;

导入组织。AspectJ。朗。注释。之后;

导入组织。AspectJ。朗。注释。方面;

导入组织。AspectJ。朗。注释。之前;

导入组织。弹簧框架。刻板印象。组件;

@Aspect

@组件

publicclassAdvice(

@ Before(' execution(* com。bfytech。春天豆3 .Person.getName(.))')

publicativtlogbeforeffect(){ 0

系统。出去。println('函数开始');

}

@After('执行(* com。bfytech。spring _ 8 _ bean 3。人。*(.))')

publicativtlogafterfunction(){ 0

系统。出去。println('函数结束');

}

}业务类:

打包。bfytech。spring _ 8 _ bean 3;

导入组织。弹簧框架。刻板印象。组件;

@组件

publicclassPerson{

私有字符串名称

私人占有;

public stringgetname(){ 0

System.out.println('getName . ');

returnname

}

public void set name(Stringname){ 0

this.name=name

System.out.println('setName . ');

}

publiintgetage(){ 0

System.out.println('getAge . ');

返回;

}

公共void setage(intage){ 0

System.out.println('setAge . ');

this.age=年龄;

}

}豆配置类:

打包。bfytech。spring _ 8 _ bean 3;

导入组织。弹簧框架。语境。注释。豆子;

导入组织。弹簧框架。语境。注释。组件可以;

导入组织。弹簧框架。语境。注释。配置;

导入组织。弹簧框架。语境。注释。enableaspectjautproxy

@配置

@EnableAspectJAutoProxy
@ComponentScan
public class BeanConfig { 
 @Bean
 public Advice advice() {
  return new Advice();
 }
}

AppicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:util="http://www.springframework.org/schema/util"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.3.xsd">
</beans>

最后的调用类App

package com.bfytech.spring_8_bean3; 
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
 
/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args )
    {
        System.out.println( "Hello World!" );        
        ApplicationContext context = new FileSystemXmlApplicationContext("ApplicationContext.xml");
        Person person = (Person) context.getBean(Person.class);
          person.setName("Tony");
          person.setAge(88);
          System.out.println(person.getName());
          System.out.println(person.getAge());
    }
}

郁闷之余。做了大量尝试,后来发现在ApplicationContext.xml中添加如下行:

<context:component-scan base-package="com.bfytech.spring_8_bean3"></context:component-scan>

之后可以正常把AOP启动起来。

查了大量资料之后,找到了原因

原来很多资料中把xml配置和注解配置混淆在一起了!

当你采用xml配置的时候,则ApplicationContext.xml的内容会生效。但是前提是你需要采用FileSystemXmlApplicationContext或者ClassPathXmlApplicationContext去读取这个xml,配置才会生效!同时@ComponentScan会被忽略!

而当你采用注解配置的时候,则你应该使用AnnotationConfigApplicationContext来加载,这时配置类的中的@ComponentScan就会生效。

修改代码App.java为

package com.bfytech.spring_8_bean3; 
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
 
/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args )
    {
        System.out.println( "Hello World!" );     
        ApplicationContext context = new AnnotationConfigApplicationContext(BeanConfig.class);
        Person person = (Person) context.getBean(Person.class);         
          person.setName("Tony");
          person.setAge(88);
          System.out.println(person.getName());
          System.out.println(person.getAge());
    }
}

运行结果正常了!

顺便说,还有一个坑。execution表达式因为没有编译时检查,任何标点符号的错误也会在运行时忽略(??我很纳闷,为什么不抛异常),所以需要反复检查。比如说下面的表达式,你觉得有错么?

@Before("execution(* com.bfytech.spring_8_bean3.*.*(**))")

这个表达式是错误的,因为(**)应该是(..).而运行时这个不会报任何错误。但是切片的代码不会运行.....

@Component和@ComponentScan常规理解

@Component和@ComponentScan的联系

@Component 这个注解的作用是把我们写的bean注入到容器中,以供使用。

@ComponentScan 注解的作用则是扫描包中的bean(比如:Spring不知道你定义了某个bean除非它知道从哪里可以找到这个bean,ComponentScan做的事情就是告诉Spring从哪里找到bean),由你来定义哪些包需要被扫描。

一旦你指定了,Spring将会将在被指定的包及其下级包中寻找bean,这两个注解进行配合使用。

@SpringBootApplication和@ComponentScan,扫描包的区别

如果你的其他包都在使用了@SpringBootApplication注解的main app所在的包及其下级包,则你什么都不用做,SpringBoot会自动帮你把其他包都扫描了如果你有一些bean所在的包,不在main app的包及其下级包,那么你需要手动加上@ComponentScan注解并指定那个bean所在的包。

关于@ComponentScan在spring中无效的原因分析以及解决方法就分享到这里了,希望

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/71905.html

(0)

相关推荐

  • oracle11g dataguard如何切换

    技术oracle11g dataguard如何切换这篇文章主要介绍“oracle11g dataguard如何切换”,在日常操作中,相信很多人在oracle11g dataguard如何切换问题上存在疑惑,小编查阅了各式

    攻略 2021年11月11日
  • Spring使用tx标签配置的拦截器

    技术Spring使用tx标签配置的拦截器 Spring使用tx标签配置的拦截器xml version="1.0" encoding="UTF-8" beans xmlns ="http://www.s

    礼包 2021年10月19日
  • SQL优化limit分页的方法是什么

    技术SQL优化limit分页的方法是什么本篇内容介绍了“SQL优化limit分页的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅

    攻略 2021年11月5日
  • 形容坏人的成语,形容和坏人一伙的的成语

    技术形容坏人的成语,形容和坏人一伙的的成语鱼龙混杂【拼音】形容坏人的成语:yú lóng hùn zá【解释】:比喻坏人和好人混在一起。
    【出处】:唐·张志和《和渔夫词》十三:“风搅长空浪搅风,鱼龙混杂一川中。”
    【示例

    生活 2021年10月29日
  • 11.9

    技术11.9 11.9属性1.attr(name|properties|key,value|fn)概述设置或返回被选元素的属性值。参数name String属性名称properties Map
    参数

    礼包 2021年11月9日
  • 没有sa密码无法集成windows身份验证登录的解决方法

    技术没有sa密码无法集成windows身份验证登录的解决方法今天就跟大家聊聊有关没有sa密码无法集成windows身份验证登录的解决方法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这

    攻略 2021年12月1日