当前位置: 首页 > news >正文

SpringBoot代码集

一、获取Spring容器对象
1.1 实现BeanFactoryAware接口

实现BeanFactoryAware接口,然后重写setBeanFactory方法,就能从该方法中获取到Spring容器对象。

@Service public class PersonService implements BeanFactoryAware { private BeanFactory beanFactory; @Override public void setBeanFactory(BeanFactory beanFactory) throws BeansException { this.beanFactory = beanFactory; } public void add() { Person person = (Person) beanFactory.getBean("person"); } }
1.2 实现ApplicationContextAware接口

实现ApplicationContextAware接口,然后重写setApplicationContext方法,也能从该方法中获取到Spring容器对象。

@Service public class PersonService2 implements ApplicationContextAware { private ApplicationContext applicationContext; @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { this.applicationContext = applicationContext; } public void add() { Person person = (Person) applicationContext.getBean("person"); } }
1.3 实现ApplicationListener接口

实现ApplicationListener接口,需要注意的是该接口接收的泛型是ContextRefreshedEvent类,然后重写onApplicationEvent方法,也能从该方法中获取到Spring容器对象。

@Service public class PersonService3 implements ApplicationListener<ContextRefreshedEvent> { private ApplicationContext applicationContext; @Override public void onApplicationEvent(ContextRefreshedEvent event) { applicationContext = event.getApplicationContext(); } public void add() { Person person = (Person) applicationContext.getBean("person"); } }
二、初始化bean

Spring中支持3种初始化bean的方法:

  • xml中指定init-method方法

  • 使用@PostConstruct注解

  • 实现InitializingBean接口

第一种方法太古老了,现在用的人不多,具体用法就不介绍了。

2.1 使用@PostConstruct注解

在需要初始化的方法上增加@PostConstruct注解,这样就有初始化的能力。

@Service public class AService { @PostConstruct public void init() { System.out.println("===初始化==="); } }
@Component public class AlipayUtils { @Resource private AlipayConfigIOS configIOS; @Resource private AlipayConfigAndroid configAndroid; public AlipayClient alipayClientIOS; public AlipayClient alipayClientAndroid; @PostConstruct public void init(){ System.out.println("===初始化==="); //构建IOS alipayClientIOS = new DefaultAlipayClient( configIOS.getGateWay(), configIOS.getAppId(), configIOS.getAppPrivateKey(), configIOS.getFormat(), configIOS.getCharset(), configIOS.getAliPayPublicKey(), configIOS.getSignType()); //构建Android alipayClientAndroid = new DefaultAlipayClient( configAndroid.getGateWay(), configAndroid.getAppId(), configAndroid.getAppPrivateKey(), configAndroid.getFormat(), configAndroid.getCharset(), configAndroid.getAliPayPublicKey(), configAndroid.getSignType()); } }
2.2 实现InitializingBean接口

实现InitializingBean接口,重写afterPropertiesSet方法,该方法中可以完成初始化功能。

@Service public class BService implements InitializingBean { @Override public void afterPropertiesSet() throws Exception { System.out.println("===初始化==="); } }
三、自定义自己的Scope

我们都知道Spring默认支持的Scope只有两种:

  • singleton 单例,每次从spring容器中获取到的bean都是同一个对象。
  • prototype 多例,每次从spring容器中获取到的bean都是不同的对象。

Spring web又对Scope进行了扩展,增加了:

  • RequestScope 同一次请求从spring容器中获取到的bean都是同一个对象。
  • SessionScope 同一个会话从spring容器中获取到的bean都是同一个对象。

即便如此,有些场景还是无法满足我们的要求。比如,我们想在同一个线程中从spring容器获取到的bean都是同一个对象,该怎么办?这就需要自定义Scope了。

3.1 第一步实现Scope接口
public class ThreadLocalScope implements Scope { private static final ThreadLocal THREAD_LOCAL_SCOPE = new ThreadLocal(); @Override public Object get(String name, ObjectFactory<?> objectFactory) { Object value = THREAD_LOCAL_SCOPE.get(); if (value != null) { return value; } Object object = objectFactory.getObject(); THREAD_LOCAL_SCOPE.set(object); return object; } @Override public Object remove(String name) { THREAD_LOCAL_SCOPE.remove(); return null; } @Override public void registerDestructionCallback(String name, Runnable callback) { } @Override public Object resolveContextualObject(String key) { return null; } @Override public String getConversationId() { return null; } }
3.2 第二步将新定义的Scope注入到Spring容器中
@Component public class ThreadLocalBeanFactoryPostProcessor implements BeanFactoryPostProcessor { @Override public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException { beanFactory.registerScope("threadLocalScope", new ThreadLocalScope()); } }
3.3 第三步使用新定义的Scope
@Scope("threadLocalScope") @Service public class CService { public void add() { } }
四、自定义类型转换

Spring目前支持3种类型转换器:

  • Converter<S,T>:将 S 类型对象转为 T 类型对象

  • ConverterFactory<S, R>:将 S 类型对象转为 R 类型及子类对象

  • GenericConverter:它支持多个source和目标类型的转化,同时还提供了source和目标类型的上下文,这个上下文能让你实现基于属性上的注解或信息来进行类型转换。

这3种类型转换器使用的场景不一样,我们以Converter<S,T>为例。假如:接口中接收参数的实体对象中,有个字段的类型是Date,但是实际传参的是字符串类型:2021-01-03 10:20:15,要如何处理呢?

4.1 第一步,定义一个实体User
@Data public class User { private Long id; private String name; private Date registerDate; }
4.2 第二步,实现Converter接口
public class DateConverter implements Converter<String, Date> { private static final String dateFormat = "yyyy-MM-dd HH:mm:ss"; private static final String shortDateFormat = "yyyy-MM-dd"; @Override public Date convert(String source) { if(StringUtils.isEmpty(value)) { return null; } value = value.trim(); try { if(value.contains("-")) { SimpleDateFormat formatter; if(value.contains(":")) { formatter = new SimpleDateFormat(dateFormat); }else { formatter = new SimpleDateFormat(shortDateFormat); } Date dtDate = formatter.parse(value); return dtDate; }else if(value.matches("^\\d+$")) { Long lDate = new Long(value); return new Date(lDate); } } catch (Exception e) { throw new RuntimeException(String.format("parser %s to Date fail", value)); } throw new RuntimeException(String.format("parser %s to Date fail", value)); } }
4.3 第三步,将新定义的类型转换器注入到Spring容器中
@Configuration public class WebConfig extends WebMvcConfigurerAdapter { @Override public void addFormatters(FormatterRegistry registry) { registry.addConverter(new DateConverter()); } }
4.4 第四步,调用接口
@RequestMapping("/user") @RestController public class UserController { @RequestMapping("/save") public String save(@RequestBody User user) { return "success"; } }

请求接口时User对象中registerDate字段会被自动转换成Date类型。

五、Enable开关

不知道你有没有用过Enable开头的注解,比如:EnableAsyncEnableCachingEnableAspectJAutoProxy等,这类注解就像开关一样,只要在@Configuration定义的配置类上加上这类注解,就能开启相关的功能,让我们一起实现一个自己的开关。

5.1 第一步,定义一个LogFilter
public class LogFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { System.out.println("记录请求日志"); chain.doFilter(request, response); System.out.println("记录响应日志"); } @Override public void destroy() { } }
5.2 第二步,注册LogFilter
@ConditionalOnWebApplication public class LogFilterWebConfig { @Bean public LogFilter timeFilter() { return new LogFilter(); } }

注意,这里用了@ConditionalOnWebApplication注解,没有直接使用@Configuration注解。

5.3 第三步,定义开关@EnableLog注解
@Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) @Documented @Import(LogFilterWebConfig.class) public @interface EnableLog { }
5.4 第四步,启动类加上@EnableLog注解

只需在Springboot启动类加上@EnableLog注解即可开启LogFilter记录请求和响应日志的功能。

AI大模型学习福利

作为一名热心肠的互联网老兵,我决定把宝贵的AI知识分享给大家。 至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

一、全套AGI大模型学习路线

AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能!

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获取

二、640套AI大模型报告合集

这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

三、AI大模型经典PDF籍

随着人工智能技术的飞速发展,AI大模型已经成为了当今科技领域的一大热点。这些大型预训练模型,如GPT-3、BERT、XLNet等,以其强大的语言理解和生成能力,正在改变我们对人工智能的认识。 那以下这些PDF籍就是非常不错的学习资源。


因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

四、AI大模型商业化落地方案

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

作为普通人,入局大模型时代需要持续学习和实践,不断提高自己的技能和认知水平,同时也需要有责任感和伦理意识,为人工智能的健康发展贡献力量

http://www.jsqmd.com/news/166309/

相关文章:

  • Qt QPointer 快速入门
  • Miniconda-Python3.9环境下实现PyTorch模型安全沙箱运行
  • Miniconda-Python3.9环境下实现PyTorch模型公平性检测流程
  • 口碑好的气密性测试仪生产企业,国产气密性测试仪哪家强? - 品牌推荐大师
  • 强软弱虚引用如何理解
  • Miniconda-Python3.9环境下实现PyTorch模型A/B测试架构
  • 2025年工程塑料回收大揭秘:如何选对靠谱回收厂家?,工程塑料回收有哪些技术领航者深度解析 - 品牌推荐师
  • Miniconda-Python3.9环境下实现PyTorch模型蓝绿部署流程
  • Miniconda-Python3.9环境下运行PyTorch官方示例代码全记录
  • 2025年度苗木批发基地优质供应商排行榜新鲜出炉,油松/丝棉木/樱花/金叶女贞/青叶复叶槭/苗木/栾树/紫薇/国槐苗木批发基地批发商选哪家 - 品牌推荐师
  • PyTorch模型回滚机制设计:基于Miniconda-Python3.9环境备份
  • PyTorch可信执行环境(TEE)实验:Miniconda-Python3.9准备
  • Miniconda-Python3.9如何支持PyTorch与Airflow工作流集成
  • 2025Q4 天津南开区装修公司 TOP5 推荐 全业态装修需求精准适配 - 品牌智鉴榜
  • PyTorch官方安装命令在Miniconda-Python3.9中的实际应用
  • 【博客之星 2025】我不是在写博客,就是在写博客的路上,这是我今年第575篇
  • Miniconda-Python3.9环境下实现PyTorch模型灰度发布流程
  • Miniconda-Python3.9环境下实现PyTorch模型混沌工程实验
  • Miniconda-Python3.9环境下监控PyTorch GPU显存使用情况
  • 从LangGraph到PydanticAI:AI Agent开发框架全方位解析与选择指南!
  • 远程服务器上使用SSH连接Miniconda-Python3.9开发PyTorch应用
  • Windows10/11右键-超级菜单-MCU(动态菜单)
  • COMSOL 使用-后续测试
  • Miniconda-Python3.9镜像显著提升AI开发效率的5大理由
  • Miniconda-Python3.9如何支持PyTorch与Redis高速缓存集成
  • 硬核对决:TruthfulRAG如何运用知识图谱化解RAG知识冲突?
  • 基于MC9S12XEP100的整车控制器(VCU)设计
  • 天地为幕,人文作笔 ——一汽丰田普拉多×演员赵秦 甘孜文化纪录片行记
  • 学长亲荐8个AI论文工具,专科生毕业论文轻松搞定!
  • 算法题 爱吃香蕉的珂珂