热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

前端session怎么传值_10年程序猿总结,SpringMVC多种传值方式

前端传到Controller:方法1通过HttpServletRequest。写法如下:HttpServletRequest类是Servlet中的类型&

前端传到Controller:

方法1

通过HttpServletRequest 。

写法如下:

4faee82360ff8f82d83dcd1c9587a639.png

HttpServletRequest类是Servlet中的类型,代表了一个Servlet请求。无论Post还是Get请求,都能通过这种方式获取到。

可以通过Post方法,使用Postman工具模拟一个post请求,都可以将值传到Controller。

这招可以获得COOKIE以及Session数据。

还可以通过注解@Autowired,将HttpServletRequest 自动的注入进来,不必担心多线程下的并发问题,因为这里HttpServletRequest注入的是一个AOP proxy ,而不是一个普通bean 。每次请求过来,都会检查线程本地属性,来获取真正的Request对象。这些都是Spring自动配置的默认场景。

但是不推荐使用这个方法,因为这种方法破坏了对一个注入对象的常规理解,造成混乱。

代码如下:

64026ff1e380cbf3558df5cbf6f1bdcf.png

方法2

使用路径变量。

写法如下:

d70017079e95008ef949d6e24f13f184.png

@RequestMapping中的{}中即为路径变量,该变量还需要在方法的参数值出现,并且标记@PathVariable。

通过URL匹配的方式既可以实现传值,这是REST风格的一种传值方式。

上面的例子,只需输入URL:

http://127.0.0.1:8080/WebApp/print/ZhangSan/30

controller接收到传值,输出:

name:ZhangSan

age:30

@RequestMapping("/print/{name}/{age}")是@RequestMapping(Value="/print/{name}/{age}")的缩写形式,本质上是一样的。

方法3

参数名匹配的方式:

8241adf37f4c6c784bdcc33b4e776772.png

或者:

819019d63e68ba89402a79b5ae6fb2a5.png

当请求传入的参数名字和controller

中代码的名字一样的时候,两种方式都可以,区别在于使用了注解@RequestParam,可以设置一个默认值来处理到null值。

@RequestParam(value=“name”, defaultValue=“John”)

但是如果请求中参数的名字和变量名不一样的时候,就只能使用@RequestParam注解。

Controller代码只能如下的写法

@RequestMapping(value="/print")

public String PrintInfo(@RequestParam(“user_name”) String name, @RequestParam(“user_age”)int age) {

}

尽量使用@RequestParam注解,因为这样可以清晰的知道该参数来自Request,可读性高。

方法4

传递请求头中的参数,需要用到@RequestHeader注解,该注解将Header中的值绑定到参数上,可以获取一个,多个或者所有的参数。

例如

3a94fb29ae1476890e04ebd917901cfb.png

或者

90b08e560e4663de944198e46d52dae1.png

方法5

使用到@RequestBody注解,得到整个RequestBody的信息

ac6e1c17b742fa59f13389368511a74e.png

@RequestBody可以将Json数据直接映射程Java对象。例如:

方法6

采用@ModelAttribute注解,命名匹配,Post中的参数值和Model中的参数值一致的话,会自动绑定到该值。

9aca5413d3a5cee33f7d063f38f03e0b.png

然后当Post的值中有name和age时,Controller中的user对象会自动附上值。

Controller传递到JSP

方法1

使用ModelAndView类,代码如下:

25aa689529610aab02f641f6ac1c5f15.png

JSP页面中:

b99652d3894510c2af9f486c540e12b0.png

ModelAndView 初始化的时候,设置了view的名字,同时也把对象存起来,直接传给view。简单实用。

方法2

使用Model或者ModelMap

(Model是一个接口,ModelMap实现了Model接口)

该方法和ModelAndView方法相似,只是Model和View分开来了,通过返回一个String来找到View,Model是注入到Controller的一个参数,通过对它添加属性,在jsp端读取值。代码如下:

2164faf152739034bd3117e580c3f9b7.png

JSP页面中:

081f8937bb385e66212bd45026c013f3.png



推荐阅读
  • Cookie学习小结
    Cookie学习小结 ... [详细]
  • 本文介绍了 Go 语言中的高性能、可扩展、轻量级 Web 框架 Echo。Echo 框架简单易用,仅需几行代码即可启动一个高性能 HTTP 服务。 ... [详细]
  • 深入解析Django CBV模型的源码运行机制
    本文详细探讨了Django CBV(Class-Based Views)模型的源码运行流程,通过具体的示例代码和详细的解释,帮助读者更好地理解和应用这一强大的功能。 ... [详细]
  • HTTP(HyperTextTransferProtocol)是超文本传输协议的缩写,它用于传送www方式的数据。HTTP协议采用了请求响应模型。客服端向服务器发送一 ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 开机自启动的几种方式
    0x01快速自启动目录快速启动目录自启动方式源于Windows中的一个目录,这个目录一般叫启动或者Startup。位于该目录下的PE文件会在开机后进行自启动 ... [详细]
  • 技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统
    技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统 ... [详细]
  • DVWA学习笔记系列:深入理解CSRF攻击机制
    DVWA学习笔记系列:深入理解CSRF攻击机制 ... [详细]
  • 在对WordPress Duplicator插件0.4.4版本的安全评估中,发现其存在跨站脚本(XSS)攻击漏洞。此漏洞可能被利用进行恶意操作,建议用户及时更新至最新版本以确保系统安全。测试方法仅限于安全研究和教学目的,使用时需自行承担风险。漏洞编号:HTB23162。 ... [详细]
  • 在List和Set集合中存储Object类型的数据元素 ... [详细]
  • 优化后的标题:深入探讨网关安全:将微服务升级为OAuth2资源服务器的最佳实践
    本文深入探讨了如何将微服务升级为OAuth2资源服务器,以订单服务为例,详细介绍了在POM文件中添加 `spring-cloud-starter-oauth2` 依赖,并配置Spring Security以实现对微服务的保护。通过这一过程,不仅增强了系统的安全性,还提高了资源访问的可控性和灵活性。文章还讨论了最佳实践,包括如何配置OAuth2客户端和资源服务器,以及如何处理常见的安全问题和错误。 ... [详细]
  • 利用爬虫技术抓取数据,结合Fiddler与Postman在Chrome中的应用优化提交流程
    本文探讨了如何利用爬虫技术抓取目标网站的数据,并结合Fiddler和Postman工具在Chrome浏览器中的应用,优化数据提交流程。通过详细的抓包分析和模拟提交,有效提升了数据抓取的效率和准确性。此外,文章还介绍了如何使用这些工具进行调试和优化,为开发者提供了实用的操作指南。 ... [详细]
  • 2012年9月12日优酷土豆校园招聘笔试题目解析与备考指南
    2012年9月12日,优酷土豆校园招聘笔试题目解析与备考指南。在选择题部分,有一道题目涉及中国人的血型分布情况,具体为A型30%、B型20%、O型40%、AB型10%。若需确保在随机选取的样本中,至少有一人为B型血的概率不低于90%,则需要选取的最少人数是多少?该问题不仅考察了概率统计的基本知识,还要求考生具备一定的逻辑推理能力。 ... [详细]
  • PHP中函数名、常量名和变量名大小写转换及规范详解
    在PHP编程中,初学者常常会遇到关于函数名、常量名和变量名大小写的问题。本文详细解析了PHP中这些名称的大小写敏感性及其命名规范,帮助开发者更好地理解和使用PHP。具体而言,文章探讨了PHP中的常量名是否区分大小写,自定义函数名的大小写敏感性,以及类名的大小写规则。此外,还提供了实用的代码示例和最佳实践,以确保代码的可读性和一致性。 ... [详细]
  • 本文作为探讨PHP依赖注入容器系列文章的开篇,将首先通过具体示例详细阐述依赖注入的基本概念及其重要性,为后续深入解析容器的实现奠定基础。 ... [详细]
author-avatar
是不是有谁代替我陪在你身旁
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有