IDEA2024创建SpringMVC项目_idea2024创建spring项目(1)

        <servlet-name>springmvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

DispatcherServlet是SpringMVC框架为我们提供的最核心的类,它是整个SpringMVC框架的前端控制器,负责接收HTTP请求、将请求路由到处理程序、处理响应信息,最终将响应返回给客户端。DispatcherServlet是Web应用程序的主要入口点之一,它的职责包括:


1. **接收客户端的HTTP请求:** DispatcherServlet监听来自Web浏览器的HTTP请求,然后根据请求的URL将请求数据解析为Request对象。
2. **处理请求的URL:** DispatcherServlet将请求的URL(Uniform Resource Locator)与处理程序进行匹配,确定要调用哪个控制器(Controller)来处理此请求。
3. **调用相应的控制器:** DispatcherServlet将请求发送给找到的控制器处理,控制器将执行业务逻辑,然后返回一个模型对象(Model)。
4. **渲染视图:** DispatcherServlet将调用视图引擎,将模型对象呈现为用户可以查看的HTML页面。
5. **返回响应给客户端:** DispatcherServlet将为用户生成的响应发送回浏览器,响应可以包括表单、JSON、XML、HTML以及其它类型的数据


#### 5.2 编写springmvc.xml


SpringMVC框架有它自己的配置文件,该配置文件的名字默认为:-servlet.xml,默认存放的位置是WEB-INF 目录下:


但是我们正常我们的配置文件都是放在resources文件夹下面的,所以我们这里需要做出一点改动。


手动配置我们的springmvc的路径。



contextConfigLocation classpath:springmvc.xml

然后我们就可以直接在resources添加一个springmvc.xml文件了。



<?xml version="1.0" encoding="UTF-8"?>

<context:component-scan base-package="org.javatop.springmvc.controller"/>
<!--视图解析器-->
<bean id="thymeleafViewResolver" class="org.thymeleaf.spring6.view.ThymeleafViewResolver">
    <!--作用于视图渲染的过程中,可以设置视图渲染后输出时采用的编码字符集-->
    <property name="characterEncoding" value="UTF-8"/>
    <!--如果配置多个视图解析器,它来决定优先使用哪个视图解析器,它的值越小优先级越高-->
    <property name="order" value="1"/>
    <!--当 ThymeleafViewResolver 渲染模板时,会使用该模板引擎来解析、编译和渲染模板-->
    <property name="templateEngine">
        <bean class="org.thymeleaf.spring6.SpringTemplateEngine">
            <!--用于指定 Thymeleaf 模板引擎使用的模板解析器。模板解析器负责根据模板位置、模板资源名称、文件编码等信息,加载模板并对其进行解析-->
            <property name="templateResolver">
                <bean class="org.thymeleaf.spring6.templateresolver.SpringResourceTemplateResolver">
                    <!--设置模板文件的位置(前缀)-->
                    <property name="prefix" value="/WEB-INF/templates/"/>
                    <!--设置模板文件后缀(后缀),Thymeleaf文件扩展名不一定是html,也可以是其他,例如txt,大部分都是html-->
                    <property name="suffix" value=".html"/>
                    <!--设置模板类型,例如:HTML,TEXT,JAVASCRIPT,CSS等-->
                    <property name="templateMode" value="HTML"/>
                    <!--用于模板文件在读取和解析过程中采用的编码字符集-->
                    <property name="characterEncoding" value="UTF-8"/>
                </bean>
            </property>
        </bean>
    </property>
</bean>

![image-20240406203036105](https://img-blog.csdnimg.cn/img_convert/fafbc9faac055f153a65b408fcc06936.png)


以上配置主要两项:


* 第一项:组件扫描。spring扫描这个包中的类,将这个包中的类实例化并纳入IoC容器的管理。
* 第二项:视图解析器。`视图解析器(View Resolver)`的作用主要是将Controller方法返回的逻辑视图名称解析成实际的视图对象。视图解析器将解析出的视图对象返回给DispatcherServlet,并最终由DispatcherServlet将该视图对象转化为响应结果,呈现给用户。


注意:如果采用了其它视图,请配置对应的视图解析器,例如:


* JSP的视图解析器:InternalResourceViewResolver
* FreeMarker视图解析器:FreeMarkerViewResolver
* Velocity视图解析器:VelocityViewResolver


#### 5.3 提供视图


在WEB-INF目录下新建templates目录,在templates目录中新建html文件,例如:test.html,并提供以下代码:



Test

TEST OK!!! Hello SpringMVC


#### 5.4 编写Controller


返回逻辑视图名称(决定跳转到哪个页面)



@Controller
public class HelloController {

@RequestMapping("/test")
public String test(){
    return "test";
}

}


### 6. 配置Tomcat


第一步:配置Tomcat服务器


![image-20240406203450085](https://img-blog.csdnimg.cn/img_convert/d0ca295363f9f406104e25ac972cee34.png)


第二步:部署web模块到Tomcat服务器


注意:我们这里 /springmvc 就是我们的Web应用的根目录。


![image-20240406203518858](https://img-blog.csdnimg.cn/img_convert/43cbeab244ca642363543c50132ef774.png)


### 7. 测试


开浏览器,在浏览器地址栏上输入地址:http://localhost:8080/springmvc/haha


![image-20240406203756336](https://img-blog.csdnimg.cn/img_convert/acbebd7dc809ec89d5332fa5ff2198a4.png)


大功告成!!!


### 8. 执行流程总结


1. 浏览器发送请求:http://localhost:8080/springmvc/test
2. SpringMVC的前端控制器DispatcherServlet接收到请求,
3. DispatcherServlet根据请求路径 `/test` 映射到 HelloController#名字随意(),调用该方法。
4. HelloController#名字随意() 处理请求。
5. HellController#名字随意() 返回逻辑视图名称 test给视图解析器.
6. 视图解析器找到 /WEB-INF/templates/test.html 文件,并进行解析,生成视图解析对象返回给前端控制器DispatcherServlet。
7. 前端控制器DispatcherServlet响应结果到浏览器。


### 9. 总结


以上便是本文的全部内容,本人才疏学浅,文章有什么错误的地方,欢迎大佬们批评指正!我是**Leo**,一个在互联网行业的小白,立志成为更好的自己。


如果你想了解更多关于**Leo**,可以关注公众号-程序员Leo,后面文章会首先同步至公众号。








### 最后

这份文档从构建一个键值数据库的关键架构入手,不仅带你建立起全局观,还帮你迅速抓住核心主线。除此之外,还会具体讲解数据结构、线程模型、网络框架、持久化、主从同步和切片集群等,帮你搞懂底层原理。相信这对于所有层次的Redis使用者都是一份非常完美的教程了。

![image](https://img-blog.csdnimg.cn/img_convert/6571aa55ddaa9a22936836a2dc54ed4a.webp?x-oss-process=image/format,png)

**整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~**

**你的支持,我的动力;祝各位前程似锦,offer不断!!!**

核心主线。除此之外,还会具体讲解数据结构、线程模型、网络框架、持久化、主从同步和切片集群等,帮你搞懂底层原理。相信这对于所有层次的Redis使用者都是一份非常完美的教程了。

[外链图片转存中...(img-tK2sZ47p-1714299434367)]

**整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~**

**你的支持,我的动力;祝各位前程似锦,offer不断!!!**

> **本文已被[CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/topics/618154847)收录**
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值