spring MVC在spring-data页面上使用@JsonView

Max*_*llé 6 spring-mvc jackson spring-data-jpa jhipster

我在Jhipster项目中使用Spring-MVC,Spring-data-jpa,jackson.

我设法@JsonView在一个对象上使用注释,当其余控制器中的方法返回一个类型时,它很有效,但是当方法返回类型ResponseEntity<List<MyObject>>为时,我无法使它工作ResponseEntity<Page<MyObject>>.

我试图设置MapperFeature.DEFAULT_VIEW_INCLUSION为true(默认为false).当我这样做时,所有属性都被序列化.但过滤@JsonView不再起作用.

我无法修改Page对象,因为它是一个Spring-data对象.

我正在寻找一种方法告诉杰克逊包含Page对象的所有属性.

这是我的代码:

我的实体:

@Entity
@Table(name = "T_REGION")
public class Region implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;

    @Column(name = "code", nullable = false)
    private Integer code;

    @Column(name = "name", length = 60, nullable = false)
    @JsonView(View.Summary.class)
    private String name;

    // Getters and setters
}
Run Code Online (Sandbox Code Playgroud)

我的休息控制器:

@RestController
@RequestMapping("/api")
public class RegionResource {

    @RequestMapping(value = "/regionsearch1",
                method = RequestMethod.GET,
                produces = MediaType.APPLICATION_JSON_VALUE)
    @JsonView(View.Summary.class)
    public ResponseEntity<Page<Region>> findAll1(
        @RequestParam(value = "page" , required = false) Integer offset,
        @RequestParam(value = "per_page", required = false) Integer limit,
        Sort sort)
        throws URISyntaxException {
        Pageable pageRequest = PaginationUtil.generatePageRequest(offset, limit, sort);
        Page<Region> page = regionRepository.findAll(pageRequest);
        HttpHeaders headers = PaginationUtil.generatePaginationHttpHeaders(page, "/api/regionsearch1", pageRequest);
        return new ResponseEntity<>(page, headers, HttpStatus.OK);
    }


    @RequestMapping(value = "/regionsearch2",
                method = RequestMethod.GET,
                produces = MediaType.APPLICATION_JSON_VALUE)
    @JsonView(View.Summary.class)
    public ResponseEntity<List<Region>> findAll2(
        @RequestParam(value = "page" , required = false) Integer offset,
        @RequestParam(value = "per_page", required = false) Integer limit,
        Sort sort)
        throws URISyntaxException {
        Pageable pageRequest = PaginationUtil.generatePageRequest(offset, limit, sort);
        Page<Region> page = regionRepository.findAll(pageRequest);
        HttpHeaders headers = PaginationUtil.generatePaginationHttpHeaders(page, "/api/regionsearch2", pageRequest);
        return new ResponseEntity<>(page.getContent(), headers, HttpStatus.OK);
    }

}
Run Code Online (Sandbox Code Playgroud)

findAll1 收益:

[
  {
    "name": "Ile-de-France"
  },
  {
    "name": "Champagne-Ardenne"
  },
  ....
]
Run Code Online (Sandbox Code Playgroud)

findAll2 收益:

{}
Run Code Online (Sandbox Code Playgroud)

对象Page没有@JsonView属性,因此没有序列化属性.

Page即使@JsonView使用了,我找不到告诉杰克逊包含所有属性的方法.

有任何想法吗 ?

msp*_*ant 9

返回所有页面元素的另一种方法是为Page接口创建自己的实现(包括你想要的JsonView):

JsonPage

public class JsonPage<T> extends org.springframework.data.domain.PageImpl<T> {

public JsonPage(final List<T> content, final Pageable pageable, final long total) {
    super(content, pageable, total);
}

public JsonPage(final List<T> content) {
    super(content);
}

public JsonPage(final Page<T> page, final Pageable pageable) {
    super(page.getContent(), pageable, page.getTotalElements());
}

@JsonView(JsonViews.UiView.class)
public int getTotalPages() {
    return super.getTotalPages();
}

@JsonView(JsonViews.UiView.class)
public long getTotalElements() {
    return super.getTotalElements();
}

@JsonView(JsonViews.UiView.class)
public boolean hasNext() {
    return super.hasNext();
}

@JsonView(JsonViews.UiView.class)
public boolean isLast() {
    return super.isLast();
}

@JsonView(JsonViews.UiView.class)
public boolean hasContent() {
    return super.hasContent();
}

@JsonView(JsonViews.UiView.class)
public List<T> getContent() {
    return super.getContent();
}
}
Run Code Online (Sandbox Code Playgroud)

接下来将此类返回到控制器层:

服务

@Override
public Page<User> findAll(final int page) {
    PageRequest pr = new PageRequest(page, pageSize, new Sort(Sort.Direction.DESC, "dateCreated"));
    return new JsonPage<User>(userRepository.findAll(pr), pr);
}
Run Code Online (Sandbox Code Playgroud)

调节器

@JsonView(JsonViews.UiView.class)
@RequestMapping(method = RequestMethod.GET, value = "{page}")
public Page<User> getUsers(@PathVariable final int page) {
    return userService.findAll(page);
}
Run Code Online (Sandbox Code Playgroud)


小智 6

我这样做了,它运作良好

 

    package com.natixis.spring.ws.configuration;
    import java.io.IOException;

    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.data.domain.Page;
    import org.springframework.http.converter.json.Jackson2ObjectMapperBuilder;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

    import com.fasterxml.jackson.annotation.JsonInclude.Include;
    import com.fasterxml.jackson.core.JsonGenerator;
    import com.fasterxml.jackson.core.JsonProcessingException;
    import com.fasterxml.jackson.databind.JsonSerializer;
    import com.fasterxml.jackson.databind.MapperFeature;
    import com.fasterxml.jackson.databind.ObjectMapper;
    import com.fasterxml.jackson.databind.SerializerProvider;

    @Configuration
    public class JacksonAdapter extends WebMvcConfigurerAdapter {

        @Bean
        public Jackson2ObjectMapperBuilder jacksonBuilder() {
            return  new Jackson2ObjectMapperBuilder()
                    .failOnUnknownProperties(false)
                    .serializationInclusion(Include.NON_EMPTY)
                    .serializerByType(Page.class, new JsonPageSerializer());

        }

       public class JsonPageSerializer extends JsonSerializer>{

        @Override
        public void serialize(Page page, JsonGenerator jsonGen, SerializerProvider serializerProvider) throws IOException, JsonProcessingException {

            ObjectMapper om=new ObjectMapper()
                    .disable(MapperFeature.DEFAULT_VIEW_INCLUSION)
                    .setSerializationInclusion(Include.NON_EMPTY);
            jsonGen.writeStartObject();
            jsonGen.writeFieldName("size");
            jsonGen.writeNumber(page.getSize());
            jsonGen.writeFieldName("number");
            jsonGen.writeNumber(page.getNumber());
            jsonGen.writeFieldName("totalElements");
            jsonGen.writeNumber(page.getTotalElements());
            jsonGen.writeFieldName("last");
            jsonGen.writeBoolean(page.isLast());
            jsonGen.writeFieldName("totalPages");
            jsonGen.writeNumber(page.getTotalPages());
            jsonGen.writeObjectField("sort", page.getSort());
            jsonGen.writeFieldName("first");
            jsonGen.writeBoolean(page.isFirst());
            jsonGen.writeFieldName("numberOfElements");
            jsonGen.writeNumber(page.getNumberOfElements());
            jsonGen.writeFieldName("content");
            jsonGen.writeRawValue(om.writerWithView(serializerProvider.getActiveView())
                    .writeValueAsString(page.getContent()));
            jsonGen.writeEndObject();
        }

       }
    }

Run Code Online (Sandbox Code Playgroud)

问候,

RégisLIMARE


小智 0

我遇到了同样的问题,我通过设置MapperFeature.DEFAULT_VIEW_INCLUSION为 true 解决了这个问题,但是您应该对要应用视图的类中的所有字段JsonView进行注释,JsonIgnore这样它们就不会默认包含在 json 中。


归档时间:

查看次数:

5097 次

最近记录:

6 年,7 月 前