स्प्रिंग MVC से JSON के रूप में गतिशील रूप से जावा ऑब्जेक्ट से फ़ील्ड्स को अनदेखा करें


105

हाइबरनेट के लिए मेरे पास मॉडल क्लास है

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

    private Integer userId;
    private String userName;
    private String emailId;
    private String encryptedPwd;
    private String createdBy;
    private String updatedBy;

    @Id
    @GeneratedValue(strategy = IDENTITY)
    @Column(name = "UserId", unique = true, nullable = false)
    public Integer getUserId() {
        return this.userId;
    }

    public void setUserId(Integer userId) {
        this.userId = userId;
    }

    @Column(name = "UserName", length = 100)
    public String getUserName() {
        return this.userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    @Column(name = "EmailId", nullable = false, length = 45)
    public String getEmailId() {
        return this.emailId;
    }

    public void setEmailId(String emailId) {
        this.emailId = emailId;
    }

    @Column(name = "EncryptedPwd", length = 100)
    public String getEncryptedPwd() {
        return this.encryptedPwd;
    }

    public void setEncryptedPwd(String encryptedPwd) {
        this.encryptedPwd = encryptedPwd;
    }

    public void setCreatedBy(String createdBy) {
        this.createdBy = createdBy;
    }

    @Column(name = "UpdatedBy", length = 100)
    public String getUpdatedBy() {
        return this.updatedBy;
    }

    public void setUpdatedBy(String updatedBy) {
        this.updatedBy = updatedBy;
    }
}

स्प्रिंग एमवीसी नियंत्रक में, डीएओ का उपयोग करके, मैं ऑब्जेक्ट प्राप्त करने में सक्षम हूं। और JSON ऑब्जेक्ट के रूप में लौट रहा है।

@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;
    }
}

भाग को AngularJS का उपयोग करके किया जाता है, इसलिए इसे JSON इस तरह मिलेगा

{
  "userId" :2,
  "userName" : "john",
  "emailId" : "john@gmail.com",
  "encryptedPwd" : "Co7Fwd1fXYk=",
  "createdBy" : null,
  "updatedBy" : null
}

अगर मुझे एन्क्रिप्टेड पासवर्ड सेट नहीं करना है, तो मैं उस फील्ड को भी अशक्त कर दूंगा।

लेकिन मैं ऐसा नहीं चाहता, मैं सभी क्षेत्रों को ग्राहक पक्ष में नहीं भेजना चाहता। अगर मुझे पासवर्ड नहीं चाहिए, अपडेट करने के लिए, बनाए गए फ़ील्ड्स भेजने के लिए, मेरा परिणाम JSON जैसा होना चाहिए

{
  "userId" :2,
  "userName" : "john",
  "emailId" : "john@gmail.com"
}

उन फ़ील्ड्स की सूची, जिन्हें मैं अन्य डेटाबेस तालिका से आने वाले क्लाइंट को नहीं भेजना चाहता। तो यह लॉग इन करने वाले उपयोगकर्ता के आधार पर बदल जाएगा। मैं यह कैसे कर सकता हूं?

मुझे आशा है कि आपको मेरा सवाल मिल गया होगा।


इस उत्तर के बारे में आप क्या कहेंगे? stackoverflow.com/a/30559076/3488143
Iryna

यह जानकारी उपयोगी हो सकती है stackoverflow.com/questions/12505141/…
मूसा

जवाबों:


142

@JsonIgnoreProperties("fieldname")अपने POJO में एनोटेशन जोड़ें ।

या आप @JsonIgnoreउस क्षेत्र के नाम से पहले उपयोग कर सकते हैं जिसे आप JSON के डीरसाइज़ करते समय अनदेखा करना चाहते हैं। उदाहरण:

@JsonIgnore
@JsonProperty(value = "user_password")
public String getUserPassword() {
    return userPassword;
}

गिटहब उदाहरण


63
क्या मैं इसे गतिशील रूप से कर सकता हूं? POJO में नहीं? क्या मैं इसे अपने नियंत्रक वर्ग में कर सकता हूँ?
आईकोड

3
@iProgrammer: यहां जैसा आप चाहते हैं वैसा ही है: stackoverflow.com/questions/8179986/…
user3145373

3
@iProgrammer: बहुत प्रभावशाली उत्तर यहां stackoverflow.com/questions/13764280/…
user3145373 37

11
टिप्पणी: @JsonIgnoreहै com.fasterxml.jackson.annotation.JsonIgnoreनहीं org.codehaus.jackson.annotate.JsonIgnore
xiaohuo

5
यह अनुरोध से पढ़ते समय और प्रतिक्रिया भेजते समय दोनों को अनदेखा करता है। मैं केवल प्रतिक्रिया भेजते समय उपेक्षा करना चाहता हूं क्योंकि मुझे अनुरोध ऑब्जेक्ट से उस संपत्ति की आवश्यकता है। कोई विचार?
zulkarnain shah

32

मुझे पता है कि मैं पार्टी में थोड़ा लेट हो गया हूं, लेकिन मैं वास्तव में कुछ महीने पहले ही भाग गया था। सभी उपलब्ध समाधान मुझे बहुत पसंद नहीं थे (मिक्सिन्स; यूजी!), इसलिए मैंने इस प्रक्रिया को क्लीनर बनाने के लिए एक नई लाइब्रेरी का निर्माण किया। अगर कोई इसे आज़माना चाहे तो यह यहां उपलब्ध है: https://github.com/monitorjbl/spring-json-view

मूल उपयोग बहुत सरल है, आप JsonViewअपने नियंत्रक विधियों में ऑब्जेक्ट का उपयोग करते हैं जैसे:

import com.monitorjbl.json.JsonView;
import static com.monitorjbl.json.Match.match;

@RequestMapping(method = RequestMethod.GET, value = "/myObject")
@ResponseBody
public void getMyObjects() {
    //get a list of the objects
    List<MyObject> list = myObjectService.list();

    //exclude expensive field
    JsonView.with(list).onClass(MyObject.class, match().exclude("contains"));
}

आप इसे स्प्रिंग के बाहर भी उपयोग कर सकते हैं:

import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.module.SimpleModule;
import static com.monitorjbl.json.Match.match;

ObjectMapper mapper = new ObjectMapper();
SimpleModule module = new SimpleModule();
module.addSerializer(JsonView.class, new JsonViewSerializer());
mapper.registerModule(module);

mapper.writeValueAsString(JsonView.with(list)
      .onClass(MyObject.class, match()
        .exclude("contains"))
      .onClass(MySmallObject.class, match()
        .exclude("id"));

5
धन्यवाद! मेरे लिए यही रास्ता था। मुझे विभिन्न स्थानों में समान वस्तुओं के साथ कस्टम JSON विचारों की आवश्यकता थी और @JsonIgnore सिर्फ काम नहीं करेगा। इस पुस्तकालय ने इसे मृत सरल बना दिया।
जेफ

2
आपने मेरा कोड क्लीनर और कार्यान्वयन आसान बना दिया। धन्यवाद
anindis

@monitorjbl: यह थोड़ा सा ट्रैक है, मैंने json के विचारों और इसके उद्देश्य को हल करने में उपयोग किया है। लेकिन मैं java.util के लिए कस्टम धारावाहिक को पंजीकृत करने में सक्षम नहीं हूँ। श्रेणी (कोई रनटाइम / संकलन समय त्रुटि) स्ट्रिंग के लिए के रूप में मैं कस्टम धारावाहिक निर्माता रजिस्टर करने में सक्षम था।
निनाद

17

क्या मैं इसे गतिशील रूप से कर सकता हूं?

दृश्य वर्ग बनाएं:

public class View {
    static class Public { }
    static class ExtendedPublic extends Public { }
    static class Internal extends ExtendedPublic { }
}

आप मॉडल पर ध्यान दें

@Document
public class User {

    @Id
    @JsonView(View.Public.class)
    private String id;

    @JsonView(View.Internal.class)
    private String email;

    @JsonView(View.Public.class)
    private String name;

    @JsonView(View.Public.class)
    private Instant createdAt = Instant.now();
    // getters/setters
}

अपने नियंत्रक में दृश्य वर्ग निर्दिष्ट करें

@RequestMapping("/user/{email}")
public class UserController {

    private final UserRepository userRepository;

    @Autowired
    UserController(UserRepository userRepository) {
        this.userRepository = userRepository;
    }

    @RequestMapping(method = RequestMethod.GET)
    @JsonView(View.Internal.class)
    public @ResponseBody Optional<User> get(@PathVariable String email) {
        return userRepository.findByEmail(email);
    }

}

डेटा उदाहरण:

{"id":"5aa2496df863482dc4da2067","name":"test","createdAt":"2018-03-10T09:35:31.050353800Z"}

1
यह एक शानदार और न्यूनतर उत्तर है! मैं एक JSON के रूप में एक @Configuration एनोटेट घटक से केवल कुछ फ़ील्ड वापस लौटना चाहता था और स्वचालित रूप से शामिल किए गए सभी आंतरिक फ़ील्ड को छोड़ देता हूं। आपका बहुत बहुत धन्यवाद!
स्टेक्स

15

हम JsonProperty.Access.WRITE_ONLYसंपत्ति की घोषणा करते समय पहुंच स्थापित करके ऐसा कर सकते हैं।

@JsonProperty( value = "password", access = JsonProperty.Access.WRITE_ONLY)
@SerializedName("password")
private String password;

12

जोड़े @JsonInclude(JsonInclude.Include.NON_NULL)वर्ग के लिए (बलों जैक्सन serialize शून्य मान करने के लिए) के साथ-साथ@JsonIgnore पासवर्ड क्षेत्र के लिए।

आप निश्चित रूप @JsonIgnoreसे createBy और updateBy पर सेट कर सकते हैं और यदि आप हमेशा इस विशेष मामले में नहीं तो केवल अनदेखा करना चाहते हैं।

अपडेट करें

इस घटना में कि आप POJO में एनोटेशन को स्वयं नहीं जोड़ना चाहते हैं, एक बढ़िया विकल्प जैक्सन का मिक्सिन एनोटेशन है। की जाँच करें प्रलेखन


क्या मैं इसे गतिशील रूप से कर सकता हूं? POJO में नहीं? क्या मैं इसे अपने नियंत्रक वर्ग में कर सकता हूँ?
आईकोड

क्या आपका मतलब है कि आप POJO में एनोटेशन नहीं जोड़ना चाहते हैं?
जियोन्ड

क्योंकि कभी-कभी मैं सभी क्षेत्रों को ग्राहक पक्ष में भेजना चाहूंगा। कभी-कभी कुछ खेत। फ़ील्ड जो मुझे क्लाइंट साइड में भेजनी चाहिए, वह डेटाबेस से कंट्रोलर क्लास में ही मिल रही है। उसके बाद केवल मुझे यह निर्धारित करना होगा कि किन क्षेत्रों को अनदेखा करना चाहिए।
आईकोड

12

हां, आप यह निर्दिष्ट कर सकते हैं कि किन क्षेत्रों को JSON प्रतिक्रिया के रूप में क्रमबद्ध किया गया है और कौन सा अनदेखा करना है। यह आपको गतिशील रूप से गुणों को अनदेखा करने के लिए क्या करने की आवश्यकता है।

1) सबसे पहले, आपको अपनी इकाई वर्ग पर com.fasterxml.jackson.annotation.JsonFilter से @JsonFilter जोड़ना होगा।

import com.fasterxml.jackson.annotation.JsonFilter;

@JsonFilter("SomeBeanFilter")
public class SomeBean {

  private String field1;

  private String field2;

  private String field3;

  // getters/setters
}

2) फिर अपने कंट्रोलर में आपको MappingJacksonValue ऑब्जेक्ट बनाना होगा और उस पर फिल्टर सेट करना होगा और अंत में आपको इस ऑब्जेक्ट को वापस करना होगा।

import java.util.Arrays;
import java.util.List;

import org.springframework.http.converter.json.MappingJacksonValue;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import com.fasterxml.jackson.databind.ser.FilterProvider;
import com.fasterxml.jackson.databind.ser.impl.SimpleBeanPropertyFilter;
import com.fasterxml.jackson.databind.ser.impl.SimpleFilterProvider;

@RestController
public class FilteringController {

  // Here i want to ignore all properties except field1,field2.
  @GetMapping("/ignoreProperties")
  public MappingJacksonValue retrieveSomeBean() {
    SomeBean someBean = new SomeBean("value1", "value2", "value3");

    SimpleBeanPropertyFilter filter = SimpleBeanPropertyFilter.filterOutAllExcept("field1", "field2");

    FilterProvider filters = new SimpleFilterProvider().addFilter("SomeBeanFilter", filter);

    MappingJacksonValue mapping = new MappingJacksonValue(someBean);

    mapping.setFilters(filters);

    return mapping;
  }
}

यह वही है जो आपको प्रतिक्रिया में मिलेगा:

{
  field1:"value1",
  field2:"value2"
}

इसके अलावा:

{
  field1:"value1",
  field2:"value2",
  field3:"value3"
}

यहां आप देख सकते हैं कि यह प्रॉपर्टी फ़ील्ड 1 और फ़ील्ड 2 को छोड़कर प्रतिक्रिया में अन्य गुणों (इस मामले में फ़ील्ड 3) को अनदेखा करता है।

उम्मीद है की यह मदद करेगा।


1
@ शफ़क़त यार, बहुत बहुत शुक्रिया, आप मेरे तारणहार हैं। लगभग एक दिन इस तरह की कार्यक्षमता का पता लगाने की कोशिश की। यह समाधान इतना सुरुचिपूर्ण और सरल है? और जैसा अनुरोध किया गया था वैसा ही करता है। सही उत्तर के रूप में चिह्नित किया जाना चाहिए।
ओलेग कर्ट्स

6

यदि मैं आप थे और ऐसा करना चाहते थे, तो मैं नियंत्रक परत में अपनी उपयोगकर्ता इकाई का उपयोग नहीं करूंगा। इसके अलावा मैं व्यवसाय (सेवा) परत और नियंत्रक के साथ संवाद करने के लिए UserDto (डेटा ट्रांसफर ऑब्जेक्ट) का निर्माण और उपयोग करता हूं। आप उपयोगकर्ता इकाई से UserDto तक डेटा कॉपी करने के लिए Apache BeanUtils (copyProperties विधि) का उपयोग कर सकते हैं।


3

मैंने एक JsonUtil बनाया है जिसका उपयोग प्रतिक्रिया देने के दौरान रनटाइम पर फ़ील्ड्स को अनदेखा करने के लिए किया जा सकता है।

उदाहरण उपयोग: पहला तर्क किसी भी POJO वर्ग (छात्र) का होना चाहिए और अनदेखा करना है कि आप प्रतिक्रिया में उपेक्षा करना चाहते हैं।

 Student st = new Student();
 createJsonIgnoreFields(st,"firstname,age");

import java.util.logging.Logger;

import org.codehaus.jackson.map.ObjectMapper;
import org.codehaus.jackson.map.ObjectWriter;
import org.codehaus.jackson.map.ser.FilterProvider;
import org.codehaus.jackson.map.ser.impl.SimpleBeanPropertyFilter;
import org.codehaus.jackson.map.ser.impl.SimpleFilterProvider;

public class JsonUtil {

  public static String createJsonIgnoreFields(Object object, String ignoreFields) {
     try {
         ObjectMapper mapper = new ObjectMapper();
         mapper.getSerializationConfig().addMixInAnnotations(Object.class, JsonPropertyFilterMixIn.class);
         String[] ignoreFieldsArray = ignoreFields.split(",");
         FilterProvider filters = new SimpleFilterProvider()
             .addFilter("filter properties by field names",
                 SimpleBeanPropertyFilter.serializeAllExcept(ignoreFieldsArray));
         ObjectWriter writer = mapper.writer().withFilters(filters);
         return writer.writeValueAsString(object);
     } catch (Exception e) {
         //handle exception here
     }
     return "";
   }

   public static String createJson(Object object) {
        try {
         ObjectMapper mapper = new ObjectMapper();
         ObjectWriter writer = mapper.writer().withDefaultPrettyPrinter();
         return writer.writeValueAsString(object);
        }catch (Exception e) {
         //handle exception here
        }
        return "";
   }
 }    

2

मैंने केवल @JsonIgnoreसुझाव दिया है जैसे @kryger ने सुझाव दिया है। तो आपका गेट्टर बन जाएगा:

@JsonIgnore
public String getEncryptedPwd() {
    return this.encryptedPwd;
}

आप यहाँ@JsonIgnore वर्णित की तरह क्षेत्र, सेटर या गेट्टर पर निश्चित रूप से सेट कर सकते हैं

और, यदि आप एन्क्रिप्ट किए गए पासवर्ड को केवल क्रमांकन पक्ष पर संरक्षित करना चाहते हैं (जैसे जब आपको अपने उपयोगकर्ताओं को लॉगिन करने की आवश्यकता होती है), तो इस @JsonPropertyएनोटेशन को अपने क्षेत्र में जोड़ें :

@JsonProperty(access = Access.WRITE_ONLY)
private String encryptedPwd;

अधिक जानकारी यहाँ


1

मैंने अपने लिए स्प्रिंग और जैक्सन के साथ एक समाधान ढूंढ लिया है

पहले इकाई में फ़िल्टर नाम निर्दिष्ट करें

@Entity
@Table(name = "SECTEUR")
@JsonFilter(ModelJsonFilters.SECTEUR_FILTER)
public class Secteur implements Serializable {

/** Serial UID */
private static final long serialVersionUID = 5697181222899184767L;

/**
 * Unique ID
 */
@Id
@JsonView(View.SecteurWithoutChildrens.class)
@Column(name = "id")
@GeneratedValue(strategy = GenerationType.IDENTITY)
private long id;

@JsonView(View.SecteurWithoutChildrens.class)
@Column(name = "code", nullable = false, length = 35)
private String code;

/**
 * Identifiant du secteur parent
 */
@JsonView(View.SecteurWithoutChildrens.class)
@Column(name = "id_parent")
private Long idParent;

@OneToMany(fetch = FetchType.LAZY)
@JoinColumn(name = "id_parent")
private List<Secteur> secteursEnfants = new ArrayList<>(0);

}

तब आप देख सकते हैं कि कॉन्स्टेंट फ़िल्टर नाम वर्ग को स्प्रिंग कॉन्फ़िगरेशन में उपयोग किए गए डिफ़ॉल्ट फ़िल्टरप्रॉइडर के साथ देख सकते हैं

public class ModelJsonFilters {

public final static String SECTEUR_FILTER = "SecteurFilter";
public final static String APPLICATION_FILTER = "ApplicationFilter";
public final static String SERVICE_FILTER = "ServiceFilter";
public final static String UTILISATEUR_FILTER = "UtilisateurFilter";

public static SimpleFilterProvider getDefaultFilters() {
    SimpleBeanPropertyFilter theFilter = SimpleBeanPropertyFilter.serializeAll();
    return new SimpleFilterProvider().setDefaultFilter(theFilter);
}

}

वसंत विन्यास:

@EnableWebMvc
@Configuration
@ComponentScan(basePackages = "fr.sodebo")

public class ApiRootConfiguration extends WebMvcConfigurerAdapter {

@Autowired
private EntityManagerFactory entityManagerFactory;


/**
 * config qui permet d'éviter les "Lazy loading Error" au moment de la
 * conversion json par jackson pour les retours des services REST<br>
 * on permet à jackson d'acceder à sessionFactory pour charger ce dont il a
 * besoin
 */
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {

    super.configureMessageConverters(converters);
    MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter();
    ObjectMapper mapper = new ObjectMapper();

    // config d'hibernate pour la conversion json
    mapper.registerModule(getConfiguredHibernateModule());//

    // inscrit les filtres json
    subscribeFiltersInMapper(mapper);

    // config du comportement de json views
    mapper.configure(MapperFeature.DEFAULT_VIEW_INCLUSION, false);

    converter.setObjectMapper(mapper);
    converters.add(converter);
}

/**
 * config d'hibernate pour la conversion json
 * 
 * @return Hibernate5Module
 */
private Hibernate5Module getConfiguredHibernateModule() {
    SessionFactory sessionFactory = entityManagerFactory.unwrap(SessionFactory.class);
    Hibernate5Module module = new Hibernate5Module(sessionFactory);
    module.configure(Hibernate5Module.Feature.FORCE_LAZY_LOADING, true);

    return module;

}

/**
 * inscrit les filtres json
 * 
 * @param mapper
 */
private void subscribeFiltersInMapper(ObjectMapper mapper) {

    mapper.setFilterProvider(ModelJsonFilters.getDefaultFilters());

}

}

अंत में मैं जब मैं चाहता हूँ restConstoller में एक विशिष्ट फिल्टर निर्दिष्ट कर सकते हैं ...।

@RequestMapping(value = "/{id}/droits/", method = RequestMethod.GET)
public MappingJacksonValue getListDroits(@PathVariable long id) {

    LOGGER.debug("Get all droits of user with id {}", id);

    List<Droit> droits = utilisateurService.findDroitsDeUtilisateur(id);

    MappingJacksonValue value;

    UtilisateurWithSecteurs utilisateurWithSecteurs = droitsUtilisateur.fillLists(droits).get(id);

    value = new MappingJacksonValue(utilisateurWithSecteurs);

    FilterProvider filters = ModelJsonFilters.getDefaultFilters().addFilter(ModelJsonFilters.SECTEUR_FILTER, SimpleBeanPropertyFilter.serializeAllExcept("secteursEnfants")).addFilter(ModelJsonFilters.APPLICATION_FILTER,
            SimpleBeanPropertyFilter.serializeAllExcept("services"));

    value.setFilters(filters);
    return value;

}

5
एक आसान प्रश्न के लिए इतनी जटिलताएँ क्यों हैं
हुमायूँ अहमद

1

@JsonIgnoreमैदान या उसके गेटटर पर रखें , या एक कस्टम डोटो बनाएं

@JsonIgnore
private String encryptedPwd;

या जैसा कि ऊपर उल्लेख किया गया है, ceekayइसे एनोटेट करें @JsonPropertyजहां पहुंच विशेषता केवल लिखने के लिए सेट है

@JsonProperty( value = "password", access = JsonProperty.Access.WRITE_ONLY)
private String encryptedPwd;

0

नहीं बनाएंगे UserJsonResponse वर्ग और वांछित क्षेत्रों के साथ आबादी एक क्लीनर समाधान नहीं होगा?

जब आप सभी मॉडल को वापस देना चाहते हैं तो सीधे JSON लौटना एक शानदार समाधान लगता है। नहीं तो बस गड़बड़ हो जाती है।

भविष्य में, उदाहरण के लिए, आप एक JSON क्षेत्र चाहते हैं जो किसी भी मॉडल क्षेत्र से मेल नहीं खाता है और फिर आप एक बड़ी मुसीबत में हैं।


0

यह उपरोक्त उत्तर के लिए एक स्वच्छ उपयोगिता उपकरण है :

@GetMapping(value = "/my-url")
public @ResponseBody
MappingJacksonValue getMyBean() {
    List<MyBean> myBeans = Service.findAll();
    MappingJacksonValue mappingValue = MappingFilterUtils.applyFilter(myBeans, MappingFilterUtils.JsonFilterMode.EXCLUDE_FIELD_MODE, "MyFilterName", "myBiggerObject.mySmallerObject.mySmallestObject");
    return mappingValue;
}

//AND THE UTILITY CLASS
public class MappingFilterUtils {

    public enum JsonFilterMode {
        INCLUDE_FIELD_MODE, EXCLUDE_FIELD_MODE
    }
    public static MappingJacksonValue applyFilter(Object object, final JsonFilterMode mode, final String filterName, final String... fields) {
        if (fields == null || fields.length == 0) {
            throw new IllegalArgumentException("You should pass at least one field");
        }
        return applyFilter(object, mode, filterName, new HashSet<>(Arrays.asList(fields)));
    }

    public static MappingJacksonValue applyFilter(Object object, final JsonFilterMode mode, final String filterName, final Set<String> fields) {
        if (fields == null || fields.isEmpty()) {
            throw new IllegalArgumentException("You should pass at least one field");
        }

        SimpleBeanPropertyFilter filter = null;
        switch (mode) {
            case EXCLUDE_FIELD_MODE:
                filter = SimpleBeanPropertyFilter.serializeAllExcept(fields);
                break;
            case INCLUDE_FIELD_MODE:
                filter = SimpleBeanPropertyFilter.filterOutAllExcept(fields);
                break;
        }

        FilterProvider filters = new SimpleFilterProvider().addFilter(filterName, filter);
        MappingJacksonValue mapping = new MappingJacksonValue(object);
        mapping.setFilters(filters);
        return mapping;
    }
}

-5

अपनी इकाई @JsonInclude(JsonInclude.Include.NON_NULL)में समस्या को हल करने के लिए एनोटेशन जोड़ें

ऐसा लगेगा

@Entity
@JsonInclude(JsonInclude.Include.NON_NULL)

पूरी तरह से अप्रासंगिक रूप से जवाब दिया। प्रश्न का उद्देश्य अलग है जबकि उत्तर कुछ और है। -1 उसके लिए
हम्मद दर
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.