当前位置: 代码网 > it编程>编程语言>Java > SpringBoot常用注解,thymeleaf,数据提交的实现

SpringBoot常用注解,thymeleaf,数据提交的实现

2026年01月15日 Java 我要评论
前言spring boot主要解决的是在微服务的架构下简化配置(快速有效),前后端分离,快速开发。提供了快速启动,内嵌容器化web项目,开箱即用提供了默认配置,没有繁琐的xml配置和冗余代码。本文见简

前言

spring boot主要解决的是在微服务的架构下简化配置(快速有效),前后端分离,快速开发。提供了快速启动,内嵌容器化web项目,开箱即用提供了默认配置,没有繁琐的xml配置和冗余代码。

本文见简单聊一下常用注解,thymeleaf和数据提交时需要注意的小问题。

1 快速配置

主要是通过了maven对包进行管理,需要那些插件的时候直接在pom文件中引入即可。

spring boot starter 中提供了 spring, spring mvc , spring boot,tomcat等框架。

而每一个框架都有自己的配置文件,在没有spring boot框架的时候,我们每次创建一个项目时,都需要对这些框架的配置文件进行一次调整。

而spring boot给我们提供了默认的配置,也就是我们创建完成之后就可以直接启动。那么对于简单的运行使用默认配置就足够了,对于真实的项目来说,默认配置往往是不够的。

spring boot提供了全局的一个配置文件来对所有的框架参数进行配置,application.yaml或application.propertis。

快速启动对开发和运维来说都减轻了负担。

比如以往可能对于上线的项目,如果想要修改一下tomcat中的配置文件,可能需要跨部门去操作,还需要发邮件等,而spring boot中内嵌了tomcat,这个tomcat只运行这一个项目,想要怎么调整我们程序员都可以直接操作,而且不会对其它的项目造成影响。

同时启动的时候也只需要依赖服务器上的jdk,一行java -jar xxx.jar即可启动。对于微服务来说是非常友好的。

2 常用注解

@component注解

是一个比较通用的注解,用来标识这个类是一个组件,交给我们springboot容器来管理。默认是singleton单例的。

可以用在我们的controller,service,dao层,但是为了便于区分。

出现了@controller,@service,@dao注解。

@controller注解

但是底层还是调用了@component注解

在spring boot中还有一个注解,@restcontroller注解。

这个注解在底层调用了@controller注解就是调用了@component,同时调用了一个@responsebody注解,其实在我们controller层之上还有一个ui层,我们返回的数据会通过ui渲染,如果添加了@responsebody注解绕过ui层,直接以一种文本的形式传输到前端。

3 thymeleaf

thymeleaf是渲染前端页面的一个引擎,特别的轻量级,并且在web不启动的情况下,也可以正确展示浏览页,(这个thymeleaf字面意思好像是什么树叶,寓意这它特别的轻量级吧,具体我不记得了,但是不重要哈哈)。

用maven引入thymeleaf

        <!--前端交互插件-->
        <dependency>
            <groupid>org.thymeleaf</groupid>
            <artifactid>thymeleaf</artifactid>
            <version>3.1.1.release</version>
        </dependency>

如果不生效或者出现其它问题解决起来比较棘手,可以删除掉thymeleaf的pom文件

通过下面配置找到html文件

spring:
  mvc:
    view:
      prefix: /
      suffix: .html

当我们controller层返回的是string类型的时候,就会去查找指定名称的页面,返回指定的页面

@controller
@restcontroller
@requestmapping("/whx")
public class maincontroller {

    @requestmapping("/html")
    public string openhtml(){
        system.out.println("hello,word");
        return "list";
    }
}


假如我们添加了@responsebody注解,就不会走ui的渲染,而是直接以文本的形式展示出来

@controller
@requestmapping("/whx")
public class maincontroller {

    @requestmapping("/html")
    @responsebody
    public string openhtml(){
        system.out.println("hello,word");
        return "list";
    }



}

交互流程

controller层和web页面都在我们的context(上下文)中,controller层返回数据的时候会返回到上下文context中,页面需要数据的时候通过thymeleaf从context中获取解析。

4 数据提交

使用的时候发现,如果我们以在请求体里面以json的格式提交数据,后台必须使用@requestbody来标注参数才可以取到。

使用httpservletrequest也获取不到 请求体里面以json格式提交的数据

演示代码

    @postmapping("/register")
    public string registerp(httpservletrequest request,@requestbody account account){
        system.out.println(request.getparameter("loginname"));
        system.out.println(tostringbuilder.reflectiontostring(request));
        system.out.println(tostringbuilder.reflectiontostring(account));
        return  "register";
    }

运行结果

1234
org.apache.catalina.connector.requestfacade@12517783[request=org.apache.catalina.connector.request@7e49b0d1]
cn.wanghaixin.solution.dto.account@3ec7283[id=<null>,loginname=1,2,3,password=1,2,3,nickname=1,2,3,age=1,location=1]

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2026  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com