当前位置:   article > 正文

Springboot和SpringMVC

Springboot和SpringMVC

1.搭建maven

Spring直译就是春天的意思,那就是说,有了框架之后就有了春天,是咱们程序员的春天,在以前想要做一个程序,可能需要半年的周期,但是有了框架之后,可能只需要两三个月的时间,大大缩短了开发周期,所以很好用,但是刚开始的时候,想要建立框架就要配置xml文件,但是配置xml文件非常的严格需要有严格的程序,很麻烦,所以现在有了springboot,springboot想要建立框架,需要有jar包,但是还有一个问题是,jar包版本会影响搭建框架,所以要有maven来帮助我们,这样就可以并帮助我们快速的建立一个框架。

 下面我们开始建立启动类

直接新建项目,新建项目的时候左边选择new project,右边起好项目名字,语言选择java,Build system选择Maven就可以了,

建好项目之后找settings,在settings里面搜索maven ,路径path选择到bin目录之前的文件夹(这个文件是maven文件,需要下载),第一个需要override覆盖,点一下对号之后选择settings配置文件,直接apply然后ok这样就搭建好了环境

在pom.xml文件中加上jar包,可以从网上找然后刷新一下maven就可以了

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-web</artifactId>
  4. <version>2.6.6</version>
  5. </dependency>

这里用的是下面这个,可以从里面挑选一个使用人多的版本 

在java文件夹下面建包,在包下建立一个Application 类,这个类就是启动类,但是需要在类前面加上注解:@SpringBootApplication,在main方法里面写上SpringApplication.run(EasySpringBootAAppliction.class,args);

现在这个Application类就是启动类,只要启动这个类,整个项目就会启动

2.IOC控制反转

java类的对象
//在项目运行阶段,项目需要很多对象完成整体业务
// Springboot提供了很多注解(@Repository(数据访问层),@Controller,@Bean,@Component(其他功能类),@Service(业务类),@RestController(访问层)),让Spring管理这些类的对象的生命周期
//Spring提供了ioc(控制反转)的方式方便获取该对象,
//容器和代码之间的控制权反转了,代码中不需要明文获取或者调用方法来得到对象,只需要声明该类需要什么类型的对象即可(标注注解)

@Service和RestController不同不能替代,想要进入浏览器只能用后者,前者不可以

@Autowired

在框架之前,如果我们想要获取一个对象,那我们需要手动获取,而且只有在执行到我们的代码的时候才会获取到,但是SpringbootICO就可以完成反转,只要你声明好了需要获取什么类型的对象就可以了,Springboot会给予这个类型的对象,只需要下面这样声明一下就可以了需要有一个@Autowired注解,就会给予这个类型的easys对象,

  1. @Autowired
  2. EasyService easys;

@ RequestMapping

@RequestMapping这个注解是要与前台进行交互,有了这个注解之后在注解后边加上("名称"),就可以在浏览器使用http://localhost/8080/名称就可以看到执行的结果;

  1. @RestController
  2. public class EasyController {
  3. //该类中需要EasyService类的对象
  4. //就可以在这个类中只需要声明依赖EasyService这个类就可以,不需要通过代码主动获取EasyService类的对象
  5. //然后只需要一个注解aotuwired
  6. //通过识别依赖关系,依赖注入(DI)对应的对象
  7. @Autowired
  8. EasyService easys;
  9. @Autowired
  10. TestA testa;
  11. @RequestMapping("testb")
  12. public String testB(){
  13. testa.test();
  14. return "Easy method";
  15. }}
  16. 另外一个类: @Component
  17. public class TestA {
  18. public void test(){
  19. System.out.println(this);
  20. System.out.println("test method");
  21. }
  22. }

 在浏览器上会有Easy method,在控制台上会有这个对象,和输出了test method

@Bean

不能单独使用,要和@Configuration一起使用,这样可以把返回的对象加入到Springbean容器里面,方法名就是bean对象的名字

  1. @Configuration
  2. public class EasyConfig {
  3. @Bean(initMethod = "init") //里面会有一个方法,
  4. //@Scope("prototype")
  5. public EasyBean easyBean(){
  6. return new EasyBean();
  7. }
  8. }

@Configuration

表示这个类就是一个配置类

spring bean的周期

Bean生命周期
    1)根据配置情况调用 Bean 构造方法或工厂方法实例化 Bean。
    2)利用依赖注入完成 Bean 中所有属性值的配置注入。
    3) 如果 Bean 实现了 BeanNameAware 接口,则 Spring 调用 Bean 的 setBeanName() 方法传入当前 Bean 的 id 值。
    4)如果 Bean 实现了 BeanFactoryAware 接口,则 Spring 调用 setBeanFactory() 方法传入当前工厂实例的引用。
    5) 当一个 Bean 实现了 ApplicationContextAware 接口并在 Spring 容器中被实例化时,Spring 容器会自动调用该 Bean 的 setApplicationContext 方法,并将应用程序上下文ApplicationContext作为参数传递进来
    6)BeanPostProcessor 是 Spring 框架中的一个重要接口,它允许开发者在 Spring 容器创建和初始化 bean 的过程中,对 bean 进行自定义处理。这包括在 bean 实例化之后、属性设置之前(postProcessBeforeInitialization 方法),以及在 bean 初始化之后(postProcessAfterInitialization 方法)执行自定义逻辑

Spring 容器在创建和初始化每一个 bean 时,都会调用 CustomBeanPostProcessor 中的这两个方法,允许你进行自定义处理
        在这一步执行的是postProcessBeforeInitialization方法 
    7)InitializingBean 是 Spring 框架中的一个接口,它定义了一个 afterPropertiesSet 方法。当 Spring 容器创建 bean 的所有属性都被设置完成后,会调用这个方法。
    8)如果在配置文件中通过 init-method 属性指定了初始化方法,则调用该初始化方法。
        initMethod指定的方法必须是void类型,并且不接受任何参数
    9)如果 BeanPostProcessor 和 Bean 关联,则 Spring 将调用该接口的初始化方法 postProcessAfterInitialization()。此时,Bean 已经可以被应用系统使用了。
    10)如果在 <bean> 中指定了该 Bean 的作用范围为 scope="singleton",则将该 Bean 放入 Spring IoC 的缓存池中,将触发 Spring 对该 Bean 的生命周期管理;如果在 <bean> 中指定了该 Bean 的作用范围为 scope="prototype",则将该 Bean 交给调用者,调用者管理该 Bean 的生命周期,Spring 不再管理该 Bean。
        @Scope(scopeName =ConfigurableBeanFactory.SCOPE_PROTOTYPE )
        @Scope(scopeName =ConfigurableBeanFactory.SCOPE_SINGLETON)
    11)如果 Bean 实现了 DisposableBean 接口,则 Spring 会调用 destory() 方法将 Spring 中的 Bean 销毁;如果在配置文件中通过 destory-method 属性指定了 Bean 的销毁方法,则 Spring 将调用该方法对 Bean 进行销毁。

  1. @Component("easybean")
  2. public class EasyBean implements BeanNameAware, BeanFactoryAware, ApplicationContextAware, InitializingBean, DisposableBean {
  3. public void init(){
  4. System.out.println("init method");
  5. }
  6. public EasyBean(){
  7. System.out.println("构造方法");
  8. }
  9. TestA testa;
  10. @Autowired
  11. public void setTesta(TestA testa){
  12. System.out.println("注入属性");
  13. this.testa=testa;
  14. }
  15. public void setBeanName(String name) {
  16. System.out.println("bean 接口的 beanname方法"+name);
  17. }
  18. public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
  19. System.out.println("5.-------ApplicationContext接口的setApplicationContext方法"+applicationContext);
  20. }
  21. //分别在创建对象
  22. public void afterPropertiesSet() throws Exception {
  23. System.out.println("10. 属性设置完毕");
  24. }
  25. public void destroy() throws Exception {
  26. System.out.println("11 回收销毁");
  27. }
  28. public void setBeanFactory(BeanFactory beanFactory) throws BeansException {
  29. System.out.println("4.工厂"+beanFactory);
  30. }
  31. }
  32. @Component
  33. public class Easy implements BeanPostProcessor {
  34. // public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
  35. //
  36. //
  37. // return BeanPostProcessor.super.postProcessBeforeInitialization(bean, beanName);
  38. // }
  39. //
  40. // public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
  41. //
  42. //
  43. // return BeanPostProcessor.super.postProcessAfterInitialization(bean, beanName);
  44. // }
  45. }


    了解springbean生命周期的必要性


        pring Bean的生命周期定义了从bean的创建、初始化到销毁的一系列过程,以及在这些过程中Spring容器如何与bean进行交互
            自定义初始化逻辑:
                通过了解Spring Bean的生命周期,你可以知道何时是执行自定义初始化逻辑的最佳时机。例如,你可能需要在bean的依赖项注入之后立即进行某些设置或启动某些服务。通过使用@PostConstruct注解或者init-method属性,你可以确保这些初始化逻辑在bean的依赖项注入之后执行。
            自定义销毁逻辑:
                同样地,当bean不再需要时,你可能需要执行一些清理操作,如关闭资源连接、释放内存等。通过了解Spring Bean的生命周期,你可以知道何时是执行这些销毁逻辑的最佳时机。你可以通过实现DisposableBean接口或使用@PreDestroy注解来定义自定义的销毁方法。
            集成第三方库:
                当与第三方库集成时,这些库可能需要在特定的生命周期阶段执行特定的操作。了解Spring Bean的生命周期可以帮助你确定在何处集成这些库,以确保它们能够正常工作。
            性能优化:
                通过了解Spring Bean的生命周期,你可以更好地优化你的应用程序的性能。例如,如果你知道某个bean只在特定的请求期间需要,你可以考虑将其声明为作用域为request的bean,这样Spring就不会在整个应用程序的生命周期内都持有它的实例。
            调试和排错:
                当应用程序出现问题时,了解Spring Bean的生命周期可以帮助你更快地定位问题。例如,如果你知道某个bean的初始化方法总是被调用,但某些属性没有被正确设置,那么你可以检查这个初始化方法是否有问题,或者检查是否有其他bean在初始化方法之后修改了这些属性。
            更好的设计决策:
                了解Spring Bean的生命周期可以帮助你做出更好的设计决策。例如,你可能需要考虑是否将某个功能拆分为多个bean,以及这些bean应该如何相互协作。通过了解生命周期,你可以确定哪些bean应该在其他bean之前或之后创建和销毁。

作用域

使用方法:scope(value="某一作用域")

 //Spring  Bean(Spring管理的对象)的作用域
//singleton  单例模式(默认)
    //prototype   每次需要都会来一个新对象
    //两次打印对象的结果:
//    com.easy.common.TestA@1620b463
//test method
//com.easy.common.TestA@64655594
//test method
    //request   meb项目中请求作用域,每次请求都会创建一个新对象
//    session会话,一次会话有效时间是30分钟,30分钟之内没请求会自动断开会话,安全退出也会断开会话,一次会话都会创建一个新的对象,管理员让用户下线
    //GlobalSession   全局的
 

3.SpringMVC

SpringMVC是基于mvc概念写好一个框架,我们来用,并不是写mvc

@RestController和@Controller不一样,后者如果返回的是一个字符串,会把字符串解析成地址,前者不会

做mvc的时候需要thymeleaf(前端架构)依赖(spring-boot-starter-thymeleaf),也是从网络上下载,在resourse文件下创建文件夹templates,在这个文件夹下面创建html文件然后加上引入

要记住刷新maven!!!!

然后再编写HTML文件 

  1. @Controller
  2. public class EasyBController {
  3. @RequestMapping("testM")
  4. public ModelAndView testM(){
  5. ModelAndView mav=new ModelAndView();
  6. mav.setViewName("index");
  7. mav.addObject("username","张三");
  8. return mav;
  9. }
  10. }

html文件:

  1. <!DOCTYPE html>
  2. <html lang="en" xmlns:th="http://www.thymeleaf.org">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. index page
  9. <h1 th:text="${username}">Hello, World!</h1>
  10. </body>
  11. </html>
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/煮酒与君饮/article/detail/920216?site
推荐阅读
相关标签
  

闽ICP备14008679号