利用Spring 框架时接收表单数据的几种方式
- 前台主要代码
- <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>
2. 接收方式1------直接把表单的参数写在Controller相应的方法的形参中
3. 接收方式2-----通过HttpServletRequest接收
@RequestMapping("/addUser1") public String addUser1(String userName,String password) { System.out.println("userName is:"+userName); System.out.println("password is:"+password); return "/user/success"; }
@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"; }
4. 通过一个bean来接收
(1)建立一个和表单参数对应的bean
2)通过这个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; } }
- @RequestMapping("/addUser3")
- public String addUser3(User user) {
- System.out.println("userName is:"+user.getUserName());
- System.out.println("password is:"+user.getPassword());
- return "/user/success";
- }
5. 通过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数据
6、 使用jQuery的serializeArray()方法序列化表单元素
@RequestMapping("/addUser4") public String addUser4(User user) { System.out.println("userName is:"+user.getUserName()); System.out.println("password is:"+user.getPassword()); return "/user/success"; }
如果表单元素很多,手工拼装成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";
- }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· 因为Apifox不支持离线,我果断选择了Apipost!