spring
程序员文章站
2022-06-10 23:21:44
...
对于spring的看法觉得spring就相当于一个容器似的,可以装很多bean,然后对那些bean进行管理,首先是配置bean,我们可以这样写<bean id="xxx" class="xxx.xxx.xxx"/>其中id是唯一的。我们还可以给bean指定别名:<alias name="xxxx" alis="xx"/>,配置好了bean,我们就要先初始化他们,然后去调用它们,初始化呢,我们有三种方法,第一:构造器,第二:静态工厂,第三:实例工厂。然后我们调用bean,Resoruce resource = new FileSystemResource("bean.xml") BeanFactory beanFactory=new XmlBeanFactory(resource);
这样我们就可以获取到在xml文件中配置的bean了。或者用applicationContent来获取:
ApplicationContent content = new ClassPathXmlApplicationContent("applicationContent.xml");
BeanFactory beanFactory = content;
得到了beanFactory以后就可以获取到你想到得到的bean。
在实例化bean的时候,如果要用到static工厂方法那么在<bean factory-method="createInstance"/>bean标签中中一定要使用factory-method属性。
在bean中要有一个static方法例如:
class ExampleBean(){
private ExampleBean(Abean abean,Bbean bbean){
this.abean = abean;
this.bbean = bbean;
};
public static ExampleBean createInstance(Abean abean,Bbean bbean){
ExampleBean bean = new ExampleBean(abean,bbean);
return bean;
}
}
以上就是static工厂实例化bean方法。在配置文件中配置bean的时候我们可以在bean中加一个属性<idref = "beanId"/>这个属性可以验证在调用这个bean的时候这个bean是否存在。
关于注入有几种:set,get注入(同时配置文件要有bean注入配置),构造器注入(同上)。
<ref>标签是用来引用其他bean,内部bean则用<bean><property><bean/></property></bean>标签。注入list,map,set。后来出现自动注入@Autowired.
bean的作用域包括(singleton,prototype,request,session,global session)
如果你打算用一个作用域为request的baen注入到其他bean中,那么需要注入一个aop代理来替代被注入的作用域bean,也就是说,你需要注入一个代理对象,该对象具有与被代理对象一样的公共接口,而容器则可以足够智能的从相关作用域中(比如一个HTTP request)获取到真实的目标对象,并把方法调用委派给实际的对象。(这个理解不是很透彻)。
我们经常用ApplicationContext,但是ApplicationContext到底是什么?
beans包是对bean的管理,ApplicationContext则是以一种更加面向框架的方式增强了BeanFactory的功能。context包核心是ApplicatonContext接口由于ApplicationContext是由BeanFactory派生而来的所以ApplictionContext具有BeanFactory所有的功能。
spring国际化消息,可以自定义MessageSource或者是spring中的org.springframework.context.support.ResourceBundleMessageSource那么必须有属性文件在可以为list集合多个属性文件。获取国际化消息有三种方式:
String getMessage(String code, Object[] args, String default, Locale loc):用来从MessageSource获取消息的基本方法。如果在指定的locale中没有找到消息,则使用默认的消息。args中的参数将使用标准类库中的MessageFormat来作消息中替换值。
String getMessage(String code, Object[] args, Locale loc):本质上和上一个方法相同,其区别在:没有指定默认值,如果没找到消息,会抛出一个NoSuchMessageException异常。
String getMessage(MessageSourceResolvable resolvable, Locale locale):上面方法中所使用的属性都封装到一个MessageSourceResolvable实现中,而本方法可以指定MessageSourceResolvable实现。
注解:
@Autowired可以注解属性,方法,set,map(key为String类型,values为已知类型),构造器字段.
对于spring对classpath的扫描,我们可以用@component注解,@Repository,@service,@controller是对@component的细化,@Scope可以注解bean的作用域,如果要自定义检测bean名称策略,那么就要实现beanNameGenerator,自定义作用域那么要实现scopeMetadataResolver,注解元数据那么要用到@qualifiter("")等。
spring Validator :
实现validator接口,然后用rejectValue();来返回错误,然后用<spring:bind>来显示错误。
自定义转化,要继承PropertyEditorSupport或者实现PropertyEditorRegistrar ,然后在配置文件中注册这个转化<bean class="org.springframework.beans.factory.config.CustomEditorConfigurer">
<property name="customEditors">
<map>
<entry key="example.ExoticType">
<bean class="example.ExoticTypeEditor">
<property name="format" value="upperCase"/>
</bean>
</entry>
</map>
</property>
</bean>
面向切面:
spring aop 两种代理机制,一个是jdk代理,一个是cglib代理
启动@AspectJ支持,<aop:aspectj-autoproxy/>然后就可以自定义aopbean
并且切入点表达式使用@Pointcut注解来表示(作为切入点签名的方法必须返回void 类型)。
关于切面注解匹配:@execution,@within,@target(目标bean),@annotation,@args,this
(代理bean)声明通知:@before,@afterReturnning(可以有返回值参数),@afterReturnningThrowing(可以有抛出什么异常的参数),@after,@around,@agrs("")(传递参数),
这样我们就可以获取到在xml文件中配置的bean了。或者用applicationContent来获取:
ApplicationContent content = new ClassPathXmlApplicationContent("applicationContent.xml");
BeanFactory beanFactory = content;
得到了beanFactory以后就可以获取到你想到得到的bean。
在实例化bean的时候,如果要用到static工厂方法那么在<bean factory-method="createInstance"/>bean标签中中一定要使用factory-method属性。
在bean中要有一个static方法例如:
class ExampleBean(){
private ExampleBean(Abean abean,Bbean bbean){
this.abean = abean;
this.bbean = bbean;
};
public static ExampleBean createInstance(Abean abean,Bbean bbean){
ExampleBean bean = new ExampleBean(abean,bbean);
return bean;
}
}
以上就是static工厂实例化bean方法。在配置文件中配置bean的时候我们可以在bean中加一个属性<idref = "beanId"/>这个属性可以验证在调用这个bean的时候这个bean是否存在。
关于注入有几种:set,get注入(同时配置文件要有bean注入配置),构造器注入(同上)。
<ref>标签是用来引用其他bean,内部bean则用<bean><property><bean/></property></bean>标签。注入list,map,set。后来出现自动注入@Autowired.
bean的作用域包括(singleton,prototype,request,session,global session)
如果你打算用一个作用域为request的baen注入到其他bean中,那么需要注入一个aop代理来替代被注入的作用域bean,也就是说,你需要注入一个代理对象,该对象具有与被代理对象一样的公共接口,而容器则可以足够智能的从相关作用域中(比如一个HTTP request)获取到真实的目标对象,并把方法调用委派给实际的对象。(这个理解不是很透彻)。
我们经常用ApplicationContext,但是ApplicationContext到底是什么?
beans包是对bean的管理,ApplicationContext则是以一种更加面向框架的方式增强了BeanFactory的功能。context包核心是ApplicatonContext接口由于ApplicationContext是由BeanFactory派生而来的所以ApplictionContext具有BeanFactory所有的功能。
spring国际化消息,可以自定义MessageSource或者是spring中的org.springframework.context.support.ResourceBundleMessageSource那么必须有属性文件在可以为list集合多个属性文件。获取国际化消息有三种方式:
String getMessage(String code, Object[] args, String default, Locale loc):用来从MessageSource获取消息的基本方法。如果在指定的locale中没有找到消息,则使用默认的消息。args中的参数将使用标准类库中的MessageFormat来作消息中替换值。
String getMessage(String code, Object[] args, Locale loc):本质上和上一个方法相同,其区别在:没有指定默认值,如果没找到消息,会抛出一个NoSuchMessageException异常。
String getMessage(MessageSourceResolvable resolvable, Locale locale):上面方法中所使用的属性都封装到一个MessageSourceResolvable实现中,而本方法可以指定MessageSourceResolvable实现。
注解:
@Autowired可以注解属性,方法,set,map(key为String类型,values为已知类型),构造器字段.
对于spring对classpath的扫描,我们可以用@component注解,@Repository,@service,@controller是对@component的细化,@Scope可以注解bean的作用域,如果要自定义检测bean名称策略,那么就要实现beanNameGenerator,自定义作用域那么要实现scopeMetadataResolver,注解元数据那么要用到@qualifiter("")等。
spring Validator :
实现validator接口,然后用rejectValue();来返回错误,然后用<spring:bind>来显示错误。
自定义转化,要继承PropertyEditorSupport或者实现PropertyEditorRegistrar ,然后在配置文件中注册这个转化<bean class="org.springframework.beans.factory.config.CustomEditorConfigurer">
<property name="customEditors">
<map>
<entry key="example.ExoticType">
<bean class="example.ExoticTypeEditor">
<property name="format" value="upperCase"/>
</bean>
</entry>
</map>
</property>
</bean>
面向切面:
spring aop 两种代理机制,一个是jdk代理,一个是cglib代理
启动@AspectJ支持,<aop:aspectj-autoproxy/>然后就可以自定义aopbean
并且切入点表达式使用@Pointcut注解来表示(作为切入点签名的方法必须返回void 类型)。
关于切面注解匹配:@execution,@within,@target(目标bean),@annotation,@args,this
(代理bean)声明通知:@before,@afterReturnning(可以有返回值参数),@afterReturnningThrowing(可以有抛出什么异常的参数),@after,@around,@agrs("")(传递参数),
推荐阅读
-
十、Spring boot 简单优雅的整合 Swagger2
-
使用Spring Boot和AspectJ实现方法跟踪基础结构
-
spring boot 一个项目启动多个实例
-
Mybatis整合spring(适合小白)
-
spring boot 2 集成JWT实现api接口认证
-
Spring Cloud系列-Zuul网关集成JWT身份验证
-
Jenkins + Docker + dockerfile-maven-plugin + Harbor CI/CD spring-boot项目的最轻量级配置
-
面试必问:Spring循环依赖的三种方式
-
Spring Boot 的静态资源处理
-
Spring Boot2 系列教程(一) | 如何使用 IDEA 构建 Spring Boot 工程