JSONObject排序的映射参数

时间:2015-07-30 05:09:56

标签: java json

我有一个Map,它包含String键和String和整数值。 我将值放入地图中,如下所示:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>com.rajkishan</groupId>
<artifactId>Test</artifactId>
<packaging>war</packaging>
<version>1.0.-SNAPSHOT</version>

<name>Test</name>

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <java-version>1.8</java-version>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
    <start-class>com.rajkishan.Application</start-class>
</properties>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.2.5.RELEASE</version>
</parent>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-log4j</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <!-- Spring Data JPA -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context-support</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-tomcat</artifactId>
        <scope>provided</scope>
    </dependency>
    <!--Manual-->
    <dependency>
        <groupId>com.microsoft.sqlserver</groupId>
        <artifactId>sqljdbc41</artifactId>
        <version>4.1</version>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.3</version>
            <configuration>
                <showDeprecation>true</showDeprecation>
                <compilerArgs>
                    <arg>-verbose</arg>
                    <arg>-Xlint:unchecked</arg>
                </compilerArgs>
            </configuration>
        </plugin>
    </plugins>
</build>

在此之后,我将地图添加到List中:

Map map = new LinkedHashMap();
map.put("b", 1);
map.put("a", 2);

之后,我创建了List out = new LinkedList(); out.add(map); 并将列表放入其中:

JSONObject

但如果我这样做,我会看到这个json结构:

  

{&#34;标题&#34;:&#34;标题&#34;,&#34;数组&#34;:[{&#34; a&#34;:2,&#34; b&# 34;:1}]}

但我希望看到:

  

{&#34;头&#34;:&#34;头&#34;&#34;阵列&#34;:[{&#34; B&#34;:1,&#34;&# 34;:2}]}

我哪里出错了?也许这不是正确的方法吗?

3 个答案:

答案 0 :(得分:3)

如果您想保留订单,则不应使用org.json库,因为它会将数据存储在HashMap中,因此您要保留的任何订单都将被忽略。使用org.json无法轻松解决此问题。我建议你使用另一个JSON库(GSONJacksonminimal-json等)。几乎任何其他库都保留了LinkedHashMap等插入顺序。

答案 1 :(得分:0)

没错。默认情况下,JSON将对等体按字母顺序排序。因为每个术语都是明确命名的,所以顺序完全没有区别。两种情况下都是“b = 1”和“a = 2”。

答案 2 :(得分:0)

您无法使用JSONObject维护Map中的顺序。

如果可行,那么我建议使用 List (因为它维护订单)并在客户端准备地图,例如在java脚本代码中。

参考Array of objects vs Object of Objects