|
@@ -19,12 +19,15 @@ import com.mooctest.crowd.site.data.enums.RoleType;
|
|
|
import com.mooctest.crowd.site.data.vo.*;
|
|
|
import com.mooctest.crowd.site.mediator.ViewMediator;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
+import org.codehaus.jettison.json.JSONException;
|
|
|
+import org.codehaus.jettison.json.JSONObject;
|
|
|
import org.springframework.beans.BeanUtils;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.beans.factory.annotation.Value;
|
|
|
import org.springframework.data.domain.PageRequest;
|
|
|
import org.springframework.data.domain.Pageable;
|
|
|
import org.springframework.stereotype.Component;
|
|
|
+import org.springframework.web.client.RestTemplate;
|
|
|
|
|
|
import java.util.*;
|
|
|
import java.util.stream.Collectors;
|
|
@@ -835,11 +838,11 @@ public class WebMediatorImpl implements ViewMediator {
|
|
|
bankCardDao.findByUserIdAndIsDeleted(userId,DeletedStatus.isNotDeleted).forEach(bankCardPO ->{
|
|
|
BankCardVO bankCardVO = new BankCardVO();
|
|
|
bankCardVO.setId(bankCardPO.getId());
|
|
|
- bankCardVO.setName(bankCardPO.getName());
|
|
|
bankCardVO.setUser(bankCardPO.getUser());
|
|
|
bankCardVO.setNumber(bankCardPO.getNumber());
|
|
|
Optional<BankLogoPO> bankLogo=bankLogoDao.findByCode(bankCardPO.getCode());
|
|
|
- bankCardVO.setCode(bankLogo.get().getLogoUrl());
|
|
|
+ bankCardVO.setLogoUrl(bankLogo.get().getLogoUrl());
|
|
|
+ bankCardVO.setName(bankLogo.get().getName());
|
|
|
bankCardVOList.add(bankCardVO);
|
|
|
});
|
|
|
List<BankCardVO> results = bankCardVOList.stream().distinct().collect(Collectors.toList());
|
|
@@ -848,17 +851,21 @@ public class WebMediatorImpl implements ViewMediator {
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public BankCardDTO addBankCard(long userId, BankCardVO bankCardVO) {
|
|
|
+ public BankCardDTO addBankCard(long userId, BankCardVO bankCardVO) throws JSONException {
|
|
|
BankCardPO bankCardPO=new BankCardPO();
|
|
|
- bankCardPO.setName(bankCardVO.getName());
|
|
|
+ String bankNo=bankCardVO.getNumber();
|
|
|
+ String url = "https://ccdcapi.alipay.com/validateAndCacheCardInfo.json?_input_charset=utf-8&cardNo="+bankNo+"&cardBinCheck=true";
|
|
|
+ RestTemplate restTemplate = new RestTemplate();
|
|
|
+ String result = restTemplate.getForObject(url,String.class);
|
|
|
+ JSONObject json = new JSONObject(result);
|
|
|
+ String bank = String.valueOf(json.get("bank"));
|
|
|
bankCardPO.setUser(bankCardVO.getUser());
|
|
|
bankCardPO.setNumber(bankCardVO.getNumber());
|
|
|
- bankCardPO.setCode(bankCardVO.getCode());
|
|
|
+ bankCardPO.setCode(bank);
|
|
|
bankCardPO.setUserId(userId);
|
|
|
bankCardDao.save(bankCardPO);
|
|
|
return this.getBankCard(userId);
|
|
|
}
|
|
|
-
|
|
|
@Override
|
|
|
public BankCardDTO deleteBankCard(long id, long userId) {
|
|
|
Optional<BankCardPO> bankCardPO=bankCardDao.findById(id);
|