What is `@Controller` does?

这篇具有很好参考价值的文章主要介绍了What is `@Controller` does?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

@ControllerSpringMVC注解,标记一个类作为Web控制器(Controller),负责处理HTTP请求并返回响应结果

SpringMVC中,控制器类的主要职责是:
1、接收来自客户端的HTTP请求
2、调用服务层或其他业务逻辑组件
3、根据操作结果准备视图模型数据(Model),将控制权转移给视图解析器(View Resolver)渲染视图
4、操作结果直接返回HTTP响应(例如JSON、XML等)。
文章来源地址https://www.toymoban.com/news/detail-797820.html

使用样例

简单页面渲染

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class SimplePageController {

    @GetMapping("/hello")
    public String displayHelloPage() {
        // ...
        return "hello"; // 假设有一个名为"hello.html"的模板文件在视图解析器配置的路径下
    }
}

结合ModelAndView对象使用

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class UserViewController {

    @GetMapping("/users/{id}")
    public ModelAndView showUser(@PathVariable Long id, Model model) {
        // 假设userService.find(id)获取用户信息
        User user = userService.find(id);

        // 将用户信息添加到模型中供视图模板使用
        model.addAttribute("user", user);

        // 返回包含视图名称和模型数据的ModelAndView对象
        return new ModelAndView("user-profile", model.asMap());
    }
}

处理POST请求并返回重定向

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;

@Controller
@RequestMapping("/login")
public class LoginController {

    @GetMapping
    public String showLoginForm() {
        // 显示登录表单页面
        return "login";
    }

    @PostMapping
    public String processLogin(@RequestParam("username") String username,
                              @RequestParam("password") String password,
                              RedirectAttributes redirectAttrs) {

        // 假设userService.authenticate(username, password)进行身份验证
        if (userService.authenticate(username, password)) {
            // 登录成功,重定向到主页
            redirectAttrs.addFlashAttribute("successMessage", "Welcome, you have successfully logged in!");
            return "redirect:/home";
        } else {
            // 登录失败,将错误信息添加到模型中以便在重定向后的页面显示
            redirectAttrs.addFlashAttribute("errorMessage", "Invalid credentials. Please try again.");
            return "redirect:/login";
        }
    }
}

结合@RequestBody处理JSON数据

import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class UserController {

    @PostMapping("/users")
    public ResponseEntity<User> createUser(@RequestBody CreateUserRequest request) {
        User user = userService.createUser(request.getName(), request.getEmail());
        return ResponseEntity.ok(user);
    }

    static class CreateUserRequest {
        private String name;
        private String email;

        // getters and setters
    }
}

到了这里,关于What is `@Controller` does?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • What is `XSS` does?

    跨站脚本攻击(Cross-Site Scripting,XSS) 是一种针对网站应用程序的安全漏洞,允许攻击者将 恶意脚本 注入到其他用户查看的网页中。当这些用户访问受感染的页面时,他们的浏览器会执行这些恶意脚本,导致各种安全问题的发生,如 窃取用户的会话信息 、 cookie 或 其他敏感

    2024年01月21日
    浏览(46)
  • What is `WebMvcConfigurer` does?

    WebMvcConfigurer 用于自定义和扩展 SpringMVC 的功能配置。 比如:可以配置如视图解析器、静态资源处理、消息转换器、拦截器等MVC相关的组件。 实现 WebMvcConfigurer 接口,并使用 @Configuration 注解标记,使其成为一个配置类 [实践总结] 拦截器配置(Interceptors) 视图控制器(View C

    2024年01月16日
    浏览(40)
  • What is `@Component` does?

    @Component 是 Spring 注解,用于标记Java类为Spring容器管理的一个 Bean (组件) 当 Spring 通过 类路径扫描机制 发现带有 @Component 注解的类时,会自动将其纳入到 Spring IoC容器 中进行 实例化 、 配置 和 管理 。 基本的@Component注解使用 配合@Autowired注解进行依赖注入 配合@Configurati

    2024年01月16日
    浏览(43)
  • What is `StringEscapeUtils.escapeHtml4` does?

    StringEscapeUtils.escapeHtml4 作用是将 特殊字符 转换为它们对应的 HTML实体形式 ,从而防止这些字符在网页中被解析为 HTML标签 或 脚本 ,有助于防止 跨站脚本攻击(XSS, Cross-Site Scripting) 对于现代Web应用来说,建议使用更全面的安全策略来防止XSS攻击,而不仅仅是依赖于这种简单

    2024年01月18日
    浏览(42)
  • What is `addArgumentResolvers` does in `WebMvcConfigurer` ?

    addArgumentResolvers 在 SpringMVC 框架中,主要用于向 Spring容器 注册自定义的参数解析器。在处理 HTTP请求 时, SpringMVC 会使用这些参数解析器将请求中的数据(如查询参数、路径变量、表单数据等)转换并注入到控制器方法的参数中。 http://localhost:8080/customDateArgumentResolver?date=20

    2024年02月01日
    浏览(107)
  • SpringBoot 增强Controller方法,@ControllerAdvice注解的使用

    参考资料 @ControllerAdvice 用法 SpringBoot使用@ControllerAdvice注解 @ControllerAdvice ,是Spring3.2提供的新注解,它是一个Controller增强器,可对controller进行增强处理。 配合 @ExceptionHandler 注解,进行全局异常处理。 配合 @InitBinder 注解,用来设置 WebDataBinder ,用于自动绑定前台请求参数到

    2024年02月08日
    浏览(43)
  • 【SpringBoot】常用的的各种注解(一):Controller中的请求参数

    请求路径中的参数,可以有一个或者多个 在Postman中也是直接在请求路径中添加参数即可 获取查询参数,形式为 url?name=张三 ,可以有一个或者多个。 在Postman中可以使用 Query Params 的方式添加参数: 也可以使用Body中的 form-data 的形式添加参数 一般用于传输DTO参数,只能有一

    2024年02月06日
    浏览(48)
  • SpringBoot(三层框架Controller,Mapper,Service)中遇到的一些注解整理

    本文主要从Controller层,Service层,Mapper层这三层架构中记录用到的各种注解 还有一些MyBatis用到的注解 持续更新到本人的毕设做完为止,太多了太多了根本学不完哈哈哈 用于建立HTTP请求与处理方法之间的映射关系,其中 XXX Mapping限定了提交http请求的方法 用于获取URL中提交过来的

    2024年01月21日
    浏览(41)
  • What does `$?` do?

    shell 中 $? 是一个特殊的内置变量,可以获取最后一次执行命令的退出状态。 在执行shell函数后, $? 返回函数中最后一次执行命令的退出状态。 在执行shell脚本后, $? 返回脚本中最后一次执行命令的退出状态。 [Ref] Shell 脚本中的exit状态解释

    2024年02月01日
    浏览(40)
  • Spring框架常见注解(Spring、Springboot、Springmvc)

    注解 说明 @Component、@Controller、@Service、@Repository 使用在类上用于实例化Bean @Autowired 使用在字段上用于根据类型依赖注入 @Qualifier 结合@Autowired一起使用用于根据名称进行依赖注入 @Scope 标注Bean的作用范围 @Configuration 指定当前类是一个 Spring 配置类,当创建容器时会从该类上

    2024年02月15日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包