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

安全协议书 网站开发公司网站推广哪家好

安全协议书 网站开发公司,网站推广哪家好,新网站seo,网站栏目合理性Spring_MVC 快速入门指南 一、Spring_MVC 简介 1. 什么是 Spring_MVC? Spring_MVC 是 Spring 框架的一个模块,用于构建 Web 应用程序。它基于 MVC(Model-View-Controller)设计模式,将应用程序分为模型(M…

Spring_MVC 快速入门指南

一、Spring_MVC 简介

1. 什么是 Spring_MVC?

Spring_MVC 是 Spring 框架的一个模块,用于构建 Web 应用程序。它基于 MVC(Model-View-Controller)设计模式,将应用程序分为模型(Model)、视图(View)和控制器(Controller)三个部分,使代码结构更加清晰,便于维护和扩展。

2. Spring_MVC 的优势

清晰的分离:将业务逻辑、数据和视图分离,使代码更易于管理和测试。

灵活的配置:支持多种配置方式,包括 XML 和注解。

丰富的功能:提供了许多内置功能,如数据绑定、类型转换、国际化等。

与其他 Spring 模块集成:可以无缝地与其他 Spring 模块(如 Spring Data、Spring Security)集成。

二、创建 Spring_MVC 应用

1. 依赖导入

在项目的 pom.xml 文件中添加以下依赖:

<dependency><groupId>jakarta.servlet</groupId><artifactId>jakarta.servlet-api</artifactId><version>6.1.0</version><scope>provided</scope>
</dependency>
<dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>6.1.12</version>
</dependency>

2. 创建配置类

创建一个配置类 SpringMvcConfig.java,用于替代传统的 XML 配置:

package com.itheima.config;import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;@Configuration
@ComponentScan("com.itheima.Controller") // 指定要扫描的包
@EnableWebMvc // 启用 Spring_MVC 的功能
public class SpringMvcConfig {
}

3. 创建启动类

创建一个继承自 AbstractDispatcherServletInitializer 的类 ServletConfig.java,用于配置和启动 Spring_MVC 应用:

package com.itheima.config;import org.springframework.web.servlet.support.AbstractDispatcherServletInitializer;
import org.springframework.web.servlet.support.AnnotationConfigWebApplicationContext;import javax.servlet.Filter;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;public class ServletConfig extends AbstractDispatcherServletInitializer {@Overrideprotected WebApplicationContext createServletApplicationContext() {AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();context.register(SpringMvcConfig.class); // 注册配置类return context;}@Overrideprotected String[] getServletMappings() {return new String[]{"/"}; // 所有请求都由 Spring_MVC 处理}@Overrideprotected WebApplicationContext createRootApplicationContext() {return null;}@Overrideprotected Filter[] getServletFilters() {CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();characterEncodingFilter.setEncoding("UTF-8");characterEncodingFilter.setForceEncoding(true);return new Filter[]{characterEncodingFilter};}
}

4. 创建控制器

创建一个控制器类 UserController.java,使用 @Controller 注解标记,并通过 @RequestMapping 注解设置请求路径:

package com.itheima.Controller;import org.springframework.web.bind.annotation.*;@Controller
public class UserController {@RequestMapping("/hello")@ResponseBodypublic String sayHello() {return "Hello, Spring_MVC!";}@RequestMapping(value = "/user/save", method = RequestMethod.POST)@ResponseBodypublic String saveUser() {System.out.println("User saved successfully");return "{\"status\": \"success\", \"message\": \"User saved\"}";}@RequestMapping(value = "/user/{id}", method = RequestMethod.GET)@ResponseBodypublic String getUserById(@PathVariable Integer id) {System.out.println("Retrieving user with ID: " + id);return "{\"id\": " + id + ", \"name\": \"John Doe\"}";}
}

构造形式:

在这里插入图片描述

三、请求路径设置与控制器注解详解

1. @Controller 注解

  • 用于标记一个类为控制器类。
  • Spring 容器会扫描带有 @Controller 注解的类,并将其注册为 Spring Bean。

2. @RequestMapping 注解

  • 用于映射 HTTP 请求到处理方法。
  • 可用于类级别(设置基础路径)和方法级别(设置具体路径)。
  • 支持多种 HTTP 方法(GET、POST、PUT、DELETE)。
@Controller
@RequestMapping("/api") // 类级别的基础路径
public class ApiController {@RequestMapping(value = "/user", method = RequestMethod.GET)public String getUser() {return "User data";}
}

3. @ResponseBody 注解

  • 用于指定方法的返回值将直接作为响应体返回给客户端。
  • 常用于返回 JSON 或 XML 数据。
@RequestMapping(value = "/user", method = RequestMethod.GET)
@ResponseBody
public String getUser() {return "{\"id\": 1, \"name\": \"John Doe\"}";
}

4. @RequestBody 注解

  • 用于将请求体中的数据绑定到方法参数。
  • 常用于处理 POST 或 PUT 请求中的 JSON 或 XML 数据。
@RequestMapping(value = "/user", method = RequestMethod.POST)
@ResponseBody
public String saveUser(@RequestBody User user) {return "{\"status\": \"success\"}";
}

5. @PathVariable 注解

  • 用于从 URL 中提取占位符参数。
  • 常用于动态获取路径中的参数。
@RequestMapping(value = "/user/{id}", method = RequestMethod.GET)
@ResponseBody
public String getUserById(@PathVariable Integer id) {return "{\"id\": " + id + ", \"name\": \"John Doe\"}";
}

四、运行应用

完成上述步骤后,启动应用服务器(如 Tomcat),可以通过以下 URL 访问您的应用:

  • http://localhost:8080/hello:返回 “Hello, Spring_MVC!”。
  • http://localhost:8080/user/save:返回用户保存成功的 JSON 数据。
  • http://localhost:8080/user/1:返回用户信息的 JSON 数据。

五、常见问题与解决方案

1. 无法访问控制器方法

  • 可能原因:控制器类或方法未正确标注注解,或注解路径配置错误。
  • 解决方案:检查控制器类是否使用 @Controller 注解,方法是否使用 @RequestMapping 注解,以及路径是否正确。

2. 返回 JSON 数据时出现 406 错误

  • 可能原因:客户端不接受应用返回的 JSON 数据类型。
  • 解决方案:确保在控制器方法上添加 @ResponseBody 注解,并在请求头中设置 Accept: application/json

3. 中文乱码问题

  • 可能原因:请求或响应的编码设置不正确。

  • 解决方案

    ServletConfig 类中添加字符编码过滤器:

    @Override
    protected Filter[] getServletFilters() {CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();characterEncodingFilter.setEncoding("UTF-8");characterEncodingFilter.setForceEncoding(true);return new Filter[]{characterEncodingFilter};
    }
    

    在 Tomcat 启动配置中添加 JVM 参数:

-Dfile.encoding=UTF-8
http://www.dtcms.com/wzjs/112556.html

相关文章:

  • 陕西省建设厅三类人员报名网站seo 推广服务
  • 清溪仿做网站前端培训班一般多少钱
  • 中国嘉兴门户网站培训机构加盟店排行榜
  • 电影网站加盟可以做么2022新闻大事件摘抄
  • php 怎么做 网站西安关键词排名首页
  • 桃城区网站制作公司艺考培训
  • 爱的网站郑州优化网站关键词
  • 公众号做微网站吗郑州seo外包阿亮
  • 返利网一类的网站怎么做台州网站建设平台
  • 成立一间网站开发公司seo教程有什么
  • 遵义哪里有做网站的怎么制作网站
  • 网络建设公司有哪些泸州网站seo
  • 网站建设尚品天津百度关键词排名
  • tp框架可以做网站吗sem和seo区别与联系
  • 网站源码偷取工具百度指数的搜索指数代表什么
  • 品牌网站建设维护互动营销成功案例
  • 网站被301搜索引擎优化案例分析
  • 什么网站专做韩国美妆批发的广东疫情最新消息今天又封了
  • 网页排版设计模板优化公司流程制度
  • 网站首页的图标是怎么做的网络营销促销方案
  • 手机网站菜单栏怎么做最新长尾关键词挖掘
  • 廊坊网站制作公司谷歌seo零基础教程
  • 哈尔滨做网站价格百度推广客户端官方下载
  • 做网站js是什么windows7系统优化工具
  • 珠海市横琴建设局网站搜索引擎优化
  • 有什么网站可以做logo赚钱怎样免费建立自己的网站
  • 专业做网文的网站太原百度关键词优化
  • 如何做好网站的建设与维护seo技巧是什么
  • h5页面免费制作百度seo原理
  • 网站工具查询东莞网站建设seo