Проблемы с Spring Boot, возвращающим Map с собственным объектом в качестве ключа - PullRequest
0 голосов
/ 11 июня 2018

У меня проблема с Spring Boot.Я делаю REST-приложение, и у меня есть служба, которая возвращает Map (Share, Integer)

Share - это класс, написанный мной:

public class Share {

    private String ticker;
    private String name;
    private Double value;

    public Share() {
        super();
    }

    public Share(String ticker, String name, Double value) {
        super();
        this.ticker = ticker;
        this.name = name;
        this.value = value;
    }

    public String getTicker() {
        return ticker;
    }

    public void setTicker(String ticker) {
        this.ticker = ticker;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Double getValue() {
        return value;
    }

    public void setValue(Double value) {
        this.value = value;
    }

    @Override
    public int hashCode() {
       final int prime = 31;
       int result = 1;
        result = prime * result + ((ticker == null) ? 0 : ticker.hashCode());
        return result;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        Share other = (Share) obj;
        if (ticker == null) {
            if (other.ticker != null)
                return false;
            } else if (!ticker.equals(other.ticker))
                return false;
        return true;
    } 

    @Override
    public String toString() {
        return "Share [ticker=" + ticker + ", name=" + name + ", value=" + value + "]";
    }
}

И @RestController:

public class ShareController {

    @Autowired
    private ShareBussines shareBussines;

    @RequestMapping("/getShare/{ticker}")
    public Share getShare(@PathVariable("ticker") String ticker) throws BrokerNotFoundException, BrokerArgumentException, BrokerGeneralException {
        return shareBussines.getShare(ticker);
    }

    @RequestMapping(value="/buyShares", method=RequestMethod.POST)
    public Map<Share, Integer> buyShares(@RequestBody Map<String,Double> sharesToBuy) throws BrokerGeneralException, BrokerArgumentException, BrokerInsufficientStockException {
        return shareBussines.buyShares(sharesToBuy);
    }

}

Проблема в том, что я звоню в службу почтальона.

Результат:

{
    "Share [ticker=AMZN, name=Amazon, value=259.32126508258295]": 1,
    "Share [ticker=GOOGL, name=Google, value=249.35339337497606]": 1,
    "Share [ticker=FB, name=Facebook, value=181.15005639608364]": 55
}

Ключ карты share.toString() ... Iхочу, чтобы ключом была доля JSON.Я пытаюсь удалить метод toString из класса Share, но в результате получилось:

{
    "Share@1eb87f": 1,
    "Share@40d9fab": 1,
    "Share@8db": 54
}

Он использует toString () объекта.

Спасибо за совет.

1 Ответ

0 голосов
/ 11 июня 2018

Во-первых, он работает так, как вы его запрограммировали:

@RequestMapping(value="/buyShares", method=RequestMethod.POST)
public Map<Share, Integer> buyShares(@RequestBody Map<String,Double> sharesToBuy) throws BrokerGeneralException, BrokerArgumentException, BrokerInsufficientStockException {
    return shareBussines.buyShares(sharesToBuy);
}

Поделиться здесь - это ключ.И это довольно странно.Почему бы не создать какой-нибудь объект, такой как:

public class ShareResponse {
    private Share share;
    private Integer someVal; // that's the one you have in your Map as a value

    // getters and setters
}

А потом немного изменить службу:

@RequestMapping(value="/buyShares", method=RequestMethod.POST)
public List<ShareResponse>  buyShares(@RequestBody Map<String,Double> sharesToBuy) throws BrokerGeneralException, BrokerArgumentException, BrokerInsufficientStockException {
    // do your business here, create a list of ShareResponse and return it
    return shareBussines.buyShares(sharesToBuy); // instead of this
}

И вы должны получить действительный, хорошо отформатированный JSON.Если вам нужно, чтобы каждый элемент был идентифицируем по некоторому уникальному значению, просто добавьте поле идентификатора в ShareResponse.

Имеет ли это какой-то смысл?)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...