SpringMVC接收页面表单参数
一个普通的表单。

表单的代码如下:
- <%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <title>Add User</title>
- <script type="text/javascript">
- //添加用户
- function addUser() {
- var form = document.forms[0];
- form.action = "${pageContext.request.contextPath}/user/addUser1";
- //form.action = "${pageContext.request.contextPath}/user/addUser2";
- //form.action = "${pageContext.request.contextPath}/user/addUser3";
- form.method = "post";
- form.submit();
- }
- </script>
- </head>
- <body>
- <form>
- <table>
- <tr>
- <td>账号</td>
- <td>
- <input type="text" name="userName">
- </td>
- </tr>
- <tr>
- <td>密码</td>
- <td>
- <input type="password" name="password">
- </td>
- </tr>
- <tr>
- <td> </td>
- <td>
- <input type="button" value="提交" onclick="addUser()">
- </td>
- </tr>
- </table>
- </form>
- </body>
- </html>
1、直接把表单的参数写在Controller相应的方法的形参中
- @RequestMapping("/addUser1")
- public String addUser1(String userName,String password) {
- System.out.println("userName is:"+userName);
- System.out.println("password is:"+password);
- return "/user/success";
- }
2、通过HttpServletRequest接收
- @RequestMapping("/addUser2")
- public String addUser2(HttpServletRequest request) {
- String userName = request.getParameter("userName");
- String password = request.getParameter("password");
- System.out.println("userName is:"+userName);
- System.out.println("password is:"+password);
- return "/user/success";
- }
3、通过一个bean来接收
1)建立一个和表单中参数对应的bean
- public class User {
- private String userName;
- private String password;
- public String getUserName() {
- return userName;
- }
- public void setUserName(String userName) {
- this.userName = userName;
- }
- public String getPassword() {
- return password;
- }
- public void setPassword(String password) {
- this.password = password;
- }
- }
2)用这个bean来封装接收的参数
- @RequestMapping("/addUser3")
- public String addUser3(User user) {
- System.out.println("userName is:"+user.getUserName());
- System.out.println("password is:"+user.getPassword());
- return "/user/success";
- }
4、通过json数据接收
- <%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <title>Add User</title>
- <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>
- <script type="text/javascript">
- $(document).ready(function(){
- $("#button_submit").click(function(){
- var name = $("#userName").val();
- var pass = $("#password").val();
- var user = {userName:name,password:pass};//拼装成json格式
- $.ajax({
- type:"POST",
- url:"${pageContext.request.contextPath}/user/addUser4",
- data:user,
- success:function(data){
- alert("成功");
- },
- error:function(e) {
- alert("出错:"+e);
- }
- });
- });
- });
- </script>
- </head>
- <body>
- <form>
- <table>
- <tr>
- <td>账号</td>
- <td>
- <input type="text" id="userName" name="userName">
- </td>
- </tr>
- <tr>
- <td>密码</td>
- <td>
- <input type="password" id="password" name="password">
- </td>
- </tr>
- <tr>
- <td> </td>
- <td>
- <input type="button" id="button_submit" value="提交">
- </td>
- </tr>
- </table>
- </form>
- </body>
- </html>
依然可以使用bean来接收json数据
- @RequestMapping("/addUser4")
- public String addUser4(User user) {
- System.out.println("userName is:"+user.getUserName());
- System.out.println("password is:"+user.getPassword());
- return "/user/success";
- }
5、使用jQuery的serializeArray() 方法序列化表单元素
如果表单元素很多,手工拼装成json数据非常麻烦,可以使用jQuery提供的serializeArray()方法序列化表单元素,返回json数据结构数据。
- <%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <title>Add User</title>
- <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>
- <script type="text/javascript">
- $(document).ready(function(){
- $("#button_submit").click(function(){
- //序列化表单元素,返回json数据
- var params = $("#userForm").serializeArray();
- //也可以把表单之外的元素按照name value的格式存进来
- //params.push({name:"hello",value:"man"});
- $.ajax({
- type:"POST",
- url:"${pageContext.request.contextPath}/user/addUser5",
- data:params,
- success:function(data){
- alert("成功");
- },
- error:function(e) {
- alert("出错:"+e);
- }
- });
- });
- });
- </script>
- </head>
- <body>
- <form id="userForm">
- <table>
- <tr>
- <td>账号</td>
- <td>
- <input type="text" id="userName" name="userName">
- </td>
- </tr>
- <tr>
- <td>密码</td>
- <td>
- <input type="password" id="password" name="password">
- </td>
- </tr>
- <tr>
- <td> </td>
- <td>
- <input type="button" id="button_submit" value="提交">
- </td>
- </tr>
- </table>
- </form>
- </body>
- </html>
依然可以使用bean来接收json数据:
- @RequestMapping("/addUser5")
- public String addUser5(User user) {
- System.out.println("userName is:"+user.getUserName());
- System.out.println("password is:"+user.getPassword());
- return "/user/success";
- }
SpringMVC接收页面表单参数的更多相关文章
- SpringMVC接收页面表单参数-java-电脑编程网
body { font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI ...
- SpringMVC接收页面表单参数(转)
作者:CN.programmer.Luxh 和java相关 一个普通的表单. 表单的代码如下: <%@ page language="java" contentType=&q ...
- SpringMVC获取页面表单参数的几种方式
以下几种方式只有在已搭好的SpringMVC环境中,才能执行成功! 首先,写一个登陆页面和一个Bean类 <%@ page language="java" co ...
- spring mvc 接收页面表单List
很少写博客,如果写的不好请多多包涵! 最近在用Spring mvc时遇到一个问题,在网上搜了很多资料.几乎没看到解决办法! 例如:当我们在做批量添加或者更新时,在Controller层接收表单数据的问 ...
- 把JSON数据载入到页面表单的两种思路(对easyui自带方法进行改进)
#把JSON数据载入到页面表单的两种思路(对easyui自带方法进行改进) ##背景 项目中经常需要把JSON数据填充到页面表单,一开始我使用easyui自带的form load方法,觉得效率很低,经 ...
- html 页面表单如果是disabled,则不能提交到服务器端,request.getParameter得到的将为null
html 页面表单如果是disabled,则不能提交到服务器端,request.getParameter得到的将为null 解决方法:使用hidden 利用javascript赋值,传递到后台
- 记录ASP.NET页面表单初始状态(主要是为了前台可以根据这个判断页面是否变动了)
把页面表单状态记录到HiddenField中. 这里只提供后台代码, 前台逻辑根据需求自由定义. 存放值的ViewState: protected Dictionary<string, stri ...
- 使用JQuery.Validate插件来校验页面表单有效性
使用JQuery.Validate插件来校验页面表单有效性1. [代码] 常见的注册表单元素 <form action="#" method="post" ...
- JavaScript学习——使用JS完成注册页面表单校验
1.步骤分析 第一步:确定事件(onsubmit)并为其绑定一个函数 第二步:书写这个函数(获取用户输入的数据<获取数据时需要在指定位置定义一个 id>) 第三步:对用户输入的数据进行判断 ...
随机推荐
- AndroidManifest.xml的android:name是否带.的区别
android项目里面的AndroidManifest.xml,会有这样的定义 <activity android:name=".Main" ...
- Lucene.net 多条件查询搜索
最近一直在研究lucene,目的是想让网站实现像搜索引擎那样的搜索,可以快速.准确的帮用户查询出想要的结果.废话不多说,上代码实例: 1.利用BooleanQuery进行多条件搜索(比较灵活) L ...
- html狂记
由于承接一部分站点优化工作,竟无节操地好几天没有喂博客,好了,今天完成交接工作,马上奉上DIV+CSS传统开发的干货一枚,内容绝非原创,仅是收集.学习.消化.总结.吐出... 基本结构标签: < ...
- 二模15day1解题报告
T1.合并序列(minval) 给出长为 n的AB两个序列求两两相加中最小的n个. 据说有证明(在蓝书上,优先队列部分)先把A[1~n]+b[1]入队,然后每取一个a[x]+b[y]就把a[x]+b[ ...
- Linux常见疑难问答
Linux常见疑难问答 (1)按a~z顺序排列启动服务进程. #exportLC_ALL=C #英文环境变量设置,主要用于解决乱码问题 #chkconfig –list | gre ...
- PSP个人项目耗时记录
估计这个任务需要多少时间: 计划 估计用时 估计这个任务需要多少时间 500min 开发 450min 需求分析 120min 生成设计文档 20min 设计复审 30miin 代码规范 10min ...
- 1117 冲刺一(Day 1)
冲刺一(第一天) 项目需求确定 现阶段我们进行的项目是到店点餐系统.主要是开发手机端app为用户提供方便快捷的点餐服务.免去顾客到店后遇到因吃饭的人太多而找不到服务人员点餐的窘境.减少了服务人员因为忙 ...
- 采用TCP协议实现PIC18F97J60 ethernet bootloader
了解更多关于bootloader 的C语言实现,请加我QQ: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). TCP/IP Stac ...
- Ninject之旅之二:开始使用Ninject(附程序下载)
摘要 这篇文章介绍怎样将Ninject添加到实际的项目中,使用Ninject框架最基本的功能.首先用一个Hello World例子介绍怎么添加和使用Ninject.然后用一个更复杂的例子,介绍Ninj ...
- Access、Hybrid和Trunk
以太网端口有三种链路类型:Access.Hybrid和Trunk.Access类型的端口只能属于1个VLAN,一般用于连接计算机的端口:Trunk类型的端口可以属于多个VLAN,可以接收和发送多个VL ...