Springboot+ajax传输json数组以及单条数据的方法

下面是用ajax传输到后台单条以及多条数据的解析的Demo:

结构图如下:

下面是相关的代码:

pom.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <modelVersion>4.0.0</modelVersion>
  5. <groupId>com.example</groupId>
  6. <artifactId>springboot-ssm</artifactId>
  7. <version>0.0.1-SNAPSHOT</version>
  8. <packaging>jar</packaging>
  9. <name>springboot-ssm</name>
  10. <description>Demo project for Spring Boot</description>
  11. <parent>
  12. <groupId>org.springframework.boot</groupId>
  13. <artifactId>spring-boot-starter-parent</artifactId>
  14. <version>1.5.9.RELEASE</version>
  15. <relativePath/> <!-- lookup parent from repository -->
  16. </parent>
  17. <properties>
  18. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  19. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  20. <java.version>1.8</java.version>
  21. <!--以下两项需要如果不配置,解析themleaft 会有问题-->
  22. <thymeleaf.version>3.0.2.RELEASE</thymeleaf.version>
  23. <thymeleaf-layout-dialect.version>2.0.5</thymeleaf-layout-dialect.version>
  24. </properties>
  25. <dependencies>
  26. <dependency>
  27. <groupId>org.springframework.boot</groupId>
  28. <artifactId>spring-boot-starter-web</artifactId>
  29. </dependency>
  30. <dependency>
  31. <groupId>org.springframework.boot</groupId>
  32. <artifactId>spring-boot-starter-test</artifactId>
  33. <scope>test</scope>
  34. </dependency>
  35. <!--mybatis与mysql-->
  36. <dependency>
  37. <groupId>org.mybatis.spring.boot</groupId>
  38. <artifactId>mybatis-spring-boot-starter</artifactId>
  39. <version>1.2.0</version>
  40. </dependency>
  41. <dependency>
  42. <groupId>mysql</groupId>
  43. <artifactId>mysql-connector-java</artifactId>
  44. </dependency>
  45. <!--druid依赖-->
  46. <dependency>
  47. <groupId>com.alibaba</groupId>
  48. <artifactId>druid</artifactId>
  49. <version>1.0.25</version>
  50. </dependency>
  51. <!--添加static和templates的依赖-->
  52. <dependency>
  53. <groupId>org.springframework.boot</groupId>
  54. <artifactId>spring-boot-starter-web</artifactId>
  55. </dependency>
  56. <dependency>
  57. <groupId>org.springframework.boot</groupId>
  58. <artifactId>spring-boot-starter-test</artifactId>
  59. <scope>test</scope>
  60. </dependency>
  61. <dependency>
  62. <groupId>org.springframework.boot</groupId>
  63. <artifactId>spring-boot-starter-thymeleaf</artifactId>
  64. </dependency>
  65. <!--解析json-->
  66. <dependency>
  67. <groupId>net.sf.json-lib</groupId>
  68. <artifactId>json-lib</artifactId>
  69. <version>2.4</version>
  70. <classifier>jdk15</classifier>
  71. </dependency>
  72. </dependencies>
  73. <build>
  74. <plugins>
  75. <plugin>
  76. <groupId>org.springframework.boot</groupId>
  77. <artifactId>spring-boot-maven-plugin</artifactId>
  78. </plugin>
  79. </plugins>
  80. </build>
  81. </project>

StudentController:

  1. package com.home.controller;
  2. import com.home.entity.Student;
  3. import com.home.service.StudentService;
  4. import net.sf.json.JSONArray;
  5. import net.sf.json.JSONObject;
  6. import org.springframework.beans.factory.annotation.Autowired;
  7. import org.springframework.stereotype.Controller;
  8. import org.springframework.ui.Model;
  9. import org.springframework.web.bind.annotation.RequestMapping;
  10. import org.springframework.web.bind.annotation.RequestParam;
  11. import org.springframework.web.bind.annotation.ResponseBody;
  12. import java.util.List;
  13. @Controller
  14. public class StudentController {
  15. @Autowired
  16. private StudentService studentService;
  17. @RequestMapping("/list")
  18. @ResponseBody
  19. public List<Student> list() {
  20. List<Student> studentList = studentService.getAllStu();
  21. return studentList;
  22. }
  23. @RequestMapping("/tableList")
  24. public String tableList(Model model) {
  25. List<Student> studentList = studentService.getAllStu();
  26. model.addAttribute("studentList", studentList);
  27. return "jsonArray";
  28. }
  29. @RequestMapping("/goToAdd")
  30. public String goToAdd() {
  31. return "add";
  32. }
  33. @RequestMapping("/add")
  34. public String add(Student stu) {
  35. studentService.insert(stu);
  36. return "result";
  37. }
  38. @RequestMapping("/goToAddJson")
  39. public String goToAddJson() {
  40. return "json";
  41. }
  42. @RequestMapping("/jsonArrayAdd")
  43. @ResponseBody
  44. public String jsonaAdd(@RequestParam("ids") String ids) {
  45. System.out.println(ids);
  46. JSONArray jsonArray = JSONArray.fromObject(ids);
  47. for (int i = 0; i < jsonArray.size(); i++) {
  48. JSONObject jsonObject = jsonArray.getJSONObject(i);
  49. System.out.println("json数组传递过来的参数为:" + "第" + i + "条:" + "\n" + jsonObject.get("id"));
  50. }
  51. return "json数组添加成功了";
  52. }
  53. //json数组传递
  54. @RequestMapping("/jsonAdd")
  55. @ResponseBody
  56. public String jsonArrayAdd(@RequestParam("ids") String ids) {
  57. JSONObject jsonObject = JSONObject.fromObject(ids);
  58. System.out.println("jsonObject==>" + jsonObject);
  59. Student stu = (Student) JSONObject.toBean(jsonObject, Student.class);
  60. System.out.println("stu==>" + stu);
  61. return "成功了!";
  62. }
  63. }

Student:

  1. package com.home.entity;
  2. import java.io.Serializable;
  3. public class Student implements Serializable {
  4. private Integer id;
  5. private String name;
  6. private Integer age;
  7. public Integer getId() {
  8. return id;
  9. }
  10. public void setId(Integer id) {
  11. this.id = id;
  12. }
  13. public String getName() {
  14. return name;
  15. }
  16. public void setName(String name) {
  17. this.name = name;
  18. }
  19. public Integer getAge() {
  20. return age;
  21. }
  22. public void setAge(Integer age) {
  23. this.age = age;
  24. }
  25. @Override
  26. public String toString() {
  27. return "Student{" +
  28. "id=" + id +
  29. ", name='" + name + '\'' +
  30. ", age=" + age +
  31. '}';
  32. }
  33. }

StudentMapper:

  1. package com.home.mapper;
  2. import com.home.entity.Student;
  3. import org.apache.ibatis.annotations.Mapper;
  4. import java.util.List;
  5. @Mapper
  6. public interface StudentMapper {
  7. List<Student> getAllStu();
  8. int deleteByPrimaryKey(Integer id);
  9. int insert(Student record);
  10. int insertSelective(Student record);
  11. Student selectByPrimaryKey(Integer id);
  12. int updateByPrimaryKeySelective(Student record);
  13. int updateByPrimaryKey(Student record);
  14. }

StudentService:

  1. package com.home.service;
  2. import com.home.entity.Student;
  3. import java.util.List;
  4. public interface StudentService {
  5. List<Student> getAllStu();
  6. void insert(Student stu);
  7. }

StudentServiceImpl:

  1. package com.home.service.impl;
  2. import com.home.entity.Student;
  3. import com.home.mapper.StudentMapper;
  4. import com.home.service.StudentService;
  5. import org.springframework.beans.factory.annotation.Autowired;
  6. import org.springframework.stereotype.Service;
  7. import javax.annotation.Resource;
  8. import java.util.List;
  9. @Service
  10. public class StudentServiceImpl implements StudentService {
  11. @Resource
  12. private StudentMapper studentMapper;
  13. @Override
  14. public List<Student> getAllStu() {
  15. return studentMapper.getAllStu();
  16. }
  17. @Override
  18. public void insert(Student stu) {
  19. studentMapper.insert(stu);
  20. }
  21. }

StudentMapper.xml:

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
  3. <mapper namespace="com.home.mapper.StudentMapper" >
  4. <resultMap id="BaseResultMap" type="com.home.entity.Student" >
  5. <id column="id" property="id" jdbcType="INTEGER" />
  6. <result column="name" property="name" jdbcType="VARCHAR" />
  7. <result column="age" property="age" jdbcType="INTEGER" />
  8. </resultMap>
  9. <sql id="Base_Column_List" >
  10. id, name, age
  11. </sql>
  12. <select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
  13. select
  14. <include refid="Base_Column_List" />
  15. from student
  16. where id = #{id,jdbcType=INTEGER}
  17. </select>
  18. <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer" >
  19. delete from student
  20. where id = #{id,jdbcType=INTEGER}
  21. </delete>
  22. <insert id="insert" parameterType="com.home.entity.Student" >
  23. insert into student (id, name, age
  24. )
  25. values (#{id,jdbcType=INTEGER}, #{name,jdbcType=VARCHAR}, #{age,jdbcType=INTEGER}
  26. )
  27. </insert>
  28. <insert id="insertSelective" parameterType="com.home.entity.Student" >
  29. insert into student
  30. <trim prefix="(" suffix=")" suffixOverrides="," >
  31. <if test="id != null" >
  32. id,
  33. </if>
  34. <if test="name != null" >
  35. name,
  36. </if>
  37. <if test="age != null" >
  38. age,
  39. </if>
  40. </trim>
  41. <trim prefix="values (" suffix=")" suffixOverrides="," >
  42. <if test="id != null" >
  43. #{id,jdbcType=INTEGER},
  44. </if>
  45. <if test="name != null" >
  46. #{name,jdbcType=VARCHAR},
  47. </if>
  48. <if test="age != null" >
  49. #{age,jdbcType=INTEGER},
  50. </if>
  51. </trim>
  52. </insert>
  53. <update id="updateByPrimaryKeySelective" parameterType="com.home.entity.Student" >
  54. update student
  55. <set >
  56. <if test="name != null" >
  57. name = #{name,jdbcType=VARCHAR},
  58. </if>
  59. <if test="age != null" >
  60. age = #{age,jdbcType=INTEGER},
  61. </if>
  62. </set>
  63. where id = #{id,jdbcType=INTEGER}
  64. </update>
  65. <update id="updateByPrimaryKey" parameterType="com.home.entity.Student" >
  66. update student
  67. set name = #{name,jdbcType=VARCHAR},
  68. age = #{age,jdbcType=INTEGER}
  69. where id = #{id,jdbcType=INTEGER}
  70. </update>
  71. <select id="getAllStu" resultType="com.home.entity.Student">
  72. select * from student
  73. </select>
  74. </mapper>

SqlMapperConfig.xml:

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  3. "http://mybatis.org/dtd/mybatis-3-config.dtd">
  4. <configuration>
  5. <!-- <settings> 开启二级缓存 <setting name="cacheEnabled" value="true" /> </settings> -->
  6. <!-- 只需要定义个别名,这个应该有 -->
  7. <!-- springboot集成pageHelper(Java配置未注入的时候可以用下面配置) -->
  8. <!-- <plugins>
  9. com.github.pagehelper为PageHelper类所在包名
  10. <plugin interceptor="com.github.pagehelper.PageInterceptor">
  11. 使用下面的方式配置参数,后面会有所有的参数介绍
  12. <property name="helperDialect" value="mysql" />
  13. </plugin>
  14. </plugins> -->
  15. </configuration>

json.html:

  1. <!DOCTYPE html>
  2. <html xmlns:th="http://www.thymeleaf.org">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <!--<script src="${pageContxt.request.contextPath}/jquery-3.3.1/jquery-3.3.1.min.js"></script>-->
  7. <script type="text/javascript" th:src="@{../static/jquery-3.3.1/jquery-3.3.1.min.js}"></script>
  8. </head>
  9. <body>
  10. <p>这个页面使用的是json的传输:</p>
  11. <form th:action="@{/} " th:method="post">
  12. id:<input id="id" type="text" name="id"><br/>
  13. name:<input id="name" type="text" name="name"><br/>
  14. age:<input id="age" type="text" name="age"><br/>
  15. </form>
  16. <button onclick="tijiao()">提交json</button>
  17. <script>
  18. function tijiao() {
  19. var id = $("#id").val().trim();
  20. var name = $("#name").val().trim();
  21. var age = $("#age").val().trim();
  22. console.log("id:" + id + " name:" + name + " age:" + age);
  23. var stu = {
  24. id:id,name:name,age:age
  25. }
  26. $.ajax({
  27. type:"post",
  28. url:"/jsonAdd",
  29. datatype:"json",
  30. data:{ids:JSON.stringify(stu)},
  31. success:function(data){
  32. alert(data) ;
  33. }
  34. });
  35. }
  36. </script>
  37. </body>
  38. </html>

jsonArray.html:

  1. <!DOCTYPE html>
  2. <html xmlns:th="http://www.thymeleaf.org">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <script type="text/javascript" th:src="@{../static/jquery-3.3.1/jquery-3.3.1.min.js}"></script>
  7. </head>
  8. <body>
  9. <table border="1" id="stuTable">
  10. <tr>
  11. <td>是否选中</td>
  12. <td>编号</td>
  13. <td>姓名</td>
  14. <td>年龄</td>
  15. </tr>
  16. <tr th:each="stu:${studentList}">
  17. <td><input th:type="checkbox" th:name="id" th:value="${stu.id}"></td>
  18. <td th:text="${stu.id}">编号</td>
  19. <td th:text="${stu.name}">姓名</td>
  20. <td th:text="${stu.age}">年龄</td>
  21. </tr>
  22. </table>
  23. <button id="pltj">批量提交</button>
  24. <script>
  25. $("#pltj").click(
  26. function () {
  27. var checkbox = $("#stuTable").find(":checked");
  28. console.log(checkbox);
  29. if (checkbox == 0) {
  30. return;
  31. } else {
  32. var str = [];
  33. for (var i = 0; i < checkbox.length; i++) {
  34. var ck = checkbox[i];
  35. var a = $(ck).val().trim();
  36. str.push({id: a});
  37. console.log("str==>" + str);
  38. }
  39. $.ajax({
  40. url: "/jsonArrayAdd",
  41. datatype: "json",
  42. data: {ids: JSON.stringify(str)},
  43. success: function (data) {
  44. alert(data);
  45. }
  46. });
  47. }
  48. });
  49. </script>
  50. </body>
  51. </html>

application.properties:

  1. #server.port=80
  2. logging.level.org.springframework=DEBUG
  3. #springboot mybatis
  4. #jiazai mybatis peizhiwenjian
  5. mybatis.mapper-locations = classpath:mapper/*Mapper.xml
  6. mybatis.config-location = classpath:mybatis/sqlMapperConfig.xml
  7. #mybatis.type-aliases-package = com.demo.bean
  8. #shujuyuan
  9. spring.datasource.driver-class-name= com.mysql.jdbc.Driver
  10. spring.datasource.url = jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8
  11. spring.datasource.username = *******
  12. spring.datasource.password = *******
  13. spring.thymeleaf.prefix=classpath:/templates/

运行后选择两项,可以得到选中的那一行的id值,进行批量操作了:

Springboot+ajax传输json数组以及单条数据的方法的更多相关文章

  1. Jsp页面用ajax传输json数组的方法

    详细参考jquery的API 这里主要展示实例,即写法 <%@ page language="java" contentType="text/html; chars ...

  2. Django之AJAX传输JSON数据

    目录 Django之AJAX传输JSON数据 AJAX 中 JSON 数据传输: django响应JSON类型数据: django 响应 JSON 类型数据: Django之AJAX传输JSON数据 ...

  3. Django--多对多表的创建、contentType、ajax、ajax传输json数据格式、ajax传输文件数据、 自定义分页器

    MTV与MVC(了解): MTV模型(Django用的就是MTV): M:模型层(models.py) T:templates C:views MVC模型: M:模型层(models.py) V:视图 ...

  4. $.ajax传输js数组,spring接收异常

    今天测试,出现一个奇怪的问题 $.ajax传输js数组,spring接收这个数组,出现奇怪的现象,如果数组只有一个元素,且这个元素字符串最后一个字符是以逗号,结尾的话, spring会自动把这个逗号去 ...

  5. JSON对象与JSON数组的长度和遍历方法

    JSON对象与JSON数组的长度和遍历方法         1.json对象的长度与遍历                 结构:var json={“name”:”sm”,”sex”:”woman”} ...

  6. Django和前端用ajax传输json等数据

    需要传输的是下图中所有的input中客户端设置的数据 整个页面是用js生成,代码不长,但是用了许多拼接,看起来开比较乱,页面的核心就是下面的部分,有一些关键参数部分就不放了,可以跳过这个 下面开始重点 ...

  7. ajax使用json数组------前端往后台发送json数组及后台往前端发送json数组

    1.引子 Json是跨语言数据交流的中间语言,它以键/值对的方式表示数据,这种简单明了的数据类型能被大部分编程语言理解.它也因此是前后端数据交流的主要方式和基础. 2.前端往后台传输json数据 第一 ...

  8. Django-choices字段值对应关系(性别)-MTV与MVC科普-Ajax发json格式与文件格式数据-contentType格式-Ajax搭配sweetalert实现删除确认弹窗-自定义分页器-批量插入-07

    目录 models 字段补充 choices 参数/字段(用的很多) MTV与MVC模型 科普 Ajax 发送 GET.POST 请求的几种常见方式 用 Ajax 做一个小案例 准备工作 动手用 Aj ...

  9. ajax发送json格式与文件数据、django自带的序列化器(了解)

    上期内容回顾 聚合查询和分组查询 # 聚合查询 max min sum avg count # 查询关键字:aggregate from django.db.models import Max, Mi ...

随机推荐

  1. mysql报错排查总结

    mysql报错: [root@zabbix ~]# mysql ERROR 2002 (HY000): Can't connect to local MySQL server through sock ...

  2. UVa 111 History Grading (简单DP,LIS或LCS)

    题意:题意就是坑,看不大懂么,结果就做不对,如果看懂了就so easy了,给定n个事件,注意的是, 它给的是第i个事件发生在第多少位,并不是像我们想的,第i位是哪个事件,举个例子吧,4 2 3 1, ...

  3. 深入浅析JavaScript中with语句的理解

    JavaScript 有个 with 关键字, with 语句的原本用意是为逐级的对象访问提供命名空间式的速写方式. 也就是在指定的代码区域, 直接通过节点名称调用对象. with语句的作用是暂时改变 ...

  4. 四)mybatis 二级缓存 ehcache 常见问题

    1. java.io.NotSerializableException 94359 [EH_CACHE Async Replication Thread] ERROR n.s.e.d.jgroups. ...

  5. (线段树)敌兵布阵--hdu--1166 (入门)

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=1166 自己第一次在没有看题解AC出来的线段树,写的可能不是太好,再贴个学长的代码,学习一下 发现自己的U ...

  6. PriorityQueue源码分析

          PriorityQueue其实是一个优先队列,和先进先出(FIFO)的队列的区别在于,优先队列每次出队的元素都是优先级最高的元素.那么怎么确定哪一个元素的优先级最高呢,jdk中使用堆这么一 ...

  7. win7结束进程 时,提示“拒绝访问”、“没有此任务的实例运行”怎么办?

    开发了个程序,创建了一个进程,但是杀不掉了,在任务管理器里面 右键--结束进程,提示“拒绝访问”,或者“没有此任务实例运行” 怎么办? 直接给答案:PCHunter 具体方法: 1.打开PCHunte ...

  8. Socket常用语法与socketserver实例

    1>Socket相关: 1>Socket   Families(地址簇): socket.AF_UNIX   本机进程间通信 socket.AF_INET IPV4 socket.AF_I ...

  9. Create Your Content and Structure

    The original page source Content is the most important aspect of any site. So let's design for the c ...

  10. Bitcoin

    看李笑来老师的2013演讲——Bitcoin is not virtual currency,it is a real world. 1.由于bitcoin的算法中进行有上限量的发布,所以这是不会出现 ...