Heim > Java > javaLernprogramm > Hauptteil

Wie ignoriere ich Felder in Spring MVC JSON-Antworten dynamisch?

Linda Hamilton
Freigeben: 2024-10-26 15:47:02
Original
511 Leute haben es durchsucht

How to Dynamically Ignore Fields in Spring MVC JSON Responses?

Felder aus Java-Objekten in JSON-Antworten von Spring MVC dynamisch ignorieren

In Spring MVC kann es vorkommen, dass Sie bei der Serialisierung bestimmte Felder aus Java-Objekten dynamisch ignorieren müssen sie als JSON. Dies ist besonders nützlich, wenn Objekte verarbeitet werden, die vertrauliche oder irrelevante Daten für bestimmte Clients oder Endpunkte enthalten.

Betrachten Sie die folgende Java-Modellklasse, die mit @Entity von Hibernate annotiert ist:

<code class="java">@Entity
@Table(name = "user", catalog = "userdb")
@JsonIgnoreProperties(ignoreUnknown = true)
public class User implements java.io.Serializable {

    // ... Class definition omitted for brevity
}</code>
Nach dem Login kopieren

In Ihrem Spring MVC Controller rufen Sie das Benutzerobjekt aus einer Datenbank ab und geben es als JSON-Antwort zurück:

<code class="java">@Controller
public class UserController {

    @Autowired
    private UserService userService;

    @RequestMapping(value = "/getUser/{userId}", method = RequestMethod.GET)
    @ResponseBody
    public User getUser(@PathVariable Integer userId) throws Exception {

        User user = userService.get(userId);
        user.setCreatedBy(null);
        user.setUpdatedBy(null);
        return user;
    }
}</code>
Nach dem Login kopieren

Standardmäßig enthält die JSON-Darstellung des Benutzerobjekts alle seine Felder. Möglicherweise möchten Sie jedoch vertrauliche Felder wie „encryptedPwd“, „createdBy“ und „updateBy“ von bestimmten Antworten ausschließen.

Ein Ansatz, dies zu erreichen, besteht darin, die unerwünschten Felder manuell auf Null zu setzen, bevor das Objekt zurückgegeben wird. Diese Methode kann jedoch fehleranfällig und ineffizient sein.

Eine elegantere Lösung ist die Verwendung der Annotation @JsonIgnoreProperties. Sie können die zu ignorierenden Felder mithilfe ihrer Eigenschaftsnamen in der Annotation angeben:

<code class="java">@Entity
@Table(name = "user", catalog = "userdb")
@JsonIgnoreProperties(ignoreUnknown = true, value = {"encryptedPwd", "createdBy", "updatedBy"})
public class User implements java.io.Serializable {

    // ... Class definition omitted for brevity
}</code>
Nach dem Login kopieren

Mit dieser Annotation werden die Felder „encryptedPwd“, „createdBy“ und „updateBy“ aus der JSON-Darstellung ausgeschlossen.

Alternativ können Sie die Annotation @JsonIgnore für einzelne Felder verwenden:

<code class="java">@Entity
@Table(name = "user", catalog = "userdb")
@JsonIgnoreProperties(ignoreUnknown = true)
public class User implements java.io.Serializable {

    @JsonIgnore
    private String encryptedPwd;
    private String createdBy;

    // ... Class definition omitted for brevity
}</code>
Nach dem Login kopieren

Indem Sie das Feld „encryptedPwd“ mit @JsonIgnore annotieren, schließen Sie es explizit aus der JSON-Antwort aus.

Github-Beispiel : [JsonIgnore-Beispiel](https://github.com/java089/spring-mvc-exclude-fields-json)

Das obige ist der detaillierte Inhalt vonWie ignoriere ich Felder in Spring MVC JSON-Antworten dynamisch?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!