海外读书
This commit is contained in:
@@ -68,6 +68,7 @@ public class ShiroConfig {
|
|||||||
filterMap.put("/pay/aliPay/notify","anon"); // 支付宝回调接口
|
filterMap.put("/pay/aliPay/notify","anon"); // 支付宝回调接口
|
||||||
filterMap.put("/pay/payNotify","anon"); // 微信回调接口
|
filterMap.put("/pay/payNotify","anon"); // 微信回调接口
|
||||||
filterMap.put("/pay/refundNotify","anon"); // 微信退款回调接口
|
filterMap.put("/pay/refundNotify","anon"); // 微信退款回调接口
|
||||||
|
filterMap.put("/pay/paypal/receivePaypalStatus","anon"); // paypal回调接口
|
||||||
filterMap.put("/weChat/**","anon");
|
filterMap.put("/weChat/**","anon");
|
||||||
filterMap.put("/book/baseArea/getAllBaseArea","anon");//登录前获取全部区域
|
filterMap.put("/book/baseArea/getAllBaseArea","anon");//登录前获取全部区域
|
||||||
// filterMap.put("/book/bookchaptercontent/**","anon");
|
// filterMap.put("/book/bookchaptercontent/**","anon");
|
||||||
|
|||||||
@@ -0,0 +1,104 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.controller;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.peanut.common.utils.R;
|
||||||
|
import com.peanut.common.utils.ShiroUtils;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadCommentLikeService;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadCommentService;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadLableService;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadToLableService;
|
||||||
|
import com.peanut.modules.common.entity.*;
|
||||||
|
import com.peanut.modules.common.service.MyUserService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@RestController("bookAbroad")
|
||||||
|
@RequestMapping("bookAbroad")
|
||||||
|
public class BookAbroadController {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private MyUserService userService;
|
||||||
|
@Autowired
|
||||||
|
private BookAbroadCommentService bookAbroadCommentService;
|
||||||
|
@Autowired
|
||||||
|
private BookAbroadCommentLikeService bookAbroadCommentLikeService;
|
||||||
|
|
||||||
|
//评论
|
||||||
|
@RequestMapping("/insertBookAbroadComment")
|
||||||
|
public R insertBookAbroadComment(@RequestBody BookAbroadComment comment){
|
||||||
|
comment.setUserId(ShiroUtils.getUId());
|
||||||
|
bookAbroadCommentService.save(comment);
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
//评论树
|
||||||
|
@RequestMapping("/getBookAbroadCommentTree")
|
||||||
|
public List<BookAbroadComment> getBookAbroadCommentTree(@RequestBody Map<String,Object> params) {
|
||||||
|
List<BookAbroadComment> comments = bookAbroadCommentService.list(new LambdaQueryWrapper<BookAbroadComment>()
|
||||||
|
.eq(BookAbroadComment::getBookId,params.get("bookId")));
|
||||||
|
List<BookAbroadComment> commentsTree = comments.stream().filter((bookAbroadComment) ->
|
||||||
|
bookAbroadComment.getPid() == 0
|
||||||
|
).map((comment)->{
|
||||||
|
comment.setIsLike(bookAbroadCommentLikeService.count(new LambdaQueryWrapper<BookAbroadCommentLike>()
|
||||||
|
.eq(BookAbroadCommentLike::getCommentId,comment.getId())
|
||||||
|
.eq(BookAbroadCommentLike::getUserId,ShiroUtils.getUId())));
|
||||||
|
comment.setUserEntity(userService.getOne(new LambdaQueryWrapper<MyUserEntity>()
|
||||||
|
.select(MyUserEntity::getId,MyUserEntity::getName,MyUserEntity::getNickname,MyUserEntity::getAvatar)
|
||||||
|
.eq(MyUserEntity::getId,comment.getUserId())));
|
||||||
|
comment.setChildren(getLabelChildrens(comment,comments));
|
||||||
|
return comment;
|
||||||
|
}).collect(Collectors.toList());
|
||||||
|
return commentsTree;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<BookAbroadComment> getLabelChildrens(BookAbroadComment root,List<BookAbroadComment> all){
|
||||||
|
List<BookAbroadComment> children = all.stream().filter(bookAbroadComment -> {
|
||||||
|
return root.getId().equals(bookAbroadComment.getPid());
|
||||||
|
}).map(bookAbroadComment -> {
|
||||||
|
bookAbroadComment.setIsLike(bookAbroadCommentLikeService.count(new LambdaQueryWrapper<BookAbroadCommentLike>()
|
||||||
|
.eq(BookAbroadCommentLike::getCommentId,bookAbroadComment.getId())
|
||||||
|
.eq(BookAbroadCommentLike::getUserId,ShiroUtils.getUId())));
|
||||||
|
bookAbroadComment.setUserEntity(userService.getOne(new LambdaQueryWrapper<MyUserEntity>()
|
||||||
|
.select(MyUserEntity::getId,MyUserEntity::getName,MyUserEntity::getNickname,MyUserEntity::getAvatar)
|
||||||
|
.eq(MyUserEntity::getId,bookAbroadComment.getUserId())));
|
||||||
|
bookAbroadComment.setChildren(getLabelChildrens(bookAbroadComment, all));
|
||||||
|
return bookAbroadComment;
|
||||||
|
}).collect(Collectors.toList());
|
||||||
|
return children;
|
||||||
|
}
|
||||||
|
//删除评论
|
||||||
|
@RequestMapping("/delBookAbroadComment")
|
||||||
|
public R delBookAbroadComment(@RequestBody Map<String,Object> params){
|
||||||
|
bookAbroadCommentService.removeById(params.get("commentId").toString());
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
//点赞
|
||||||
|
@RequestMapping("/insertBookAbroadCommentLike")
|
||||||
|
public R insertBookAbroadCommentLike(@RequestBody BookAbroadCommentLike commentLike){
|
||||||
|
int count = bookAbroadCommentLikeService.count(new LambdaQueryWrapper<BookAbroadCommentLike>()
|
||||||
|
.eq(BookAbroadCommentLike::getCommentId,commentLike.getCommentId())
|
||||||
|
.eq(BookAbroadCommentLike::getUserId,ShiroUtils.getUId()));
|
||||||
|
if (count > 0) {
|
||||||
|
return R.error("已点赞");
|
||||||
|
}
|
||||||
|
commentLike.setUserId(ShiroUtils.getUId());
|
||||||
|
bookAbroadCommentLikeService.save(commentLike);
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
//取消点赞
|
||||||
|
@RequestMapping("/delBookAbroadCommentLike")
|
||||||
|
public R delBookAbroadCommentLike(@RequestBody Map<String,Object> params){
|
||||||
|
bookAbroadCommentLikeService.removeById(params.get("commentLikeId").toString());
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,230 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.controller;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
|
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
||||||
|
import com.peanut.common.utils.R;
|
||||||
|
import com.peanut.common.utils.ShiroUtils;
|
||||||
|
import com.peanut.modules.book.service.*;
|
||||||
|
import com.peanut.modules.common.entity.*;
|
||||||
|
import com.peanut.modules.master.service.BookAbroadToLableService;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadLableService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@RestController("bookAbroadHome")
|
||||||
|
@RequestMapping("bookAbroad/home")
|
||||||
|
public class HomeController {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private BookReadRateService bookReadRateService;
|
||||||
|
@Autowired
|
||||||
|
private UserEbookBuyService userEbookBuyService;
|
||||||
|
@Autowired
|
||||||
|
private BookService bookService;
|
||||||
|
@Autowired
|
||||||
|
private BookAbroadLableService lableService;
|
||||||
|
@Autowired
|
||||||
|
private BookAbroadToLableService toLableService;
|
||||||
|
@Autowired
|
||||||
|
private AuthorService authorService;
|
||||||
|
@Autowired
|
||||||
|
private BookChapterService bookChapterService;
|
||||||
|
@Autowired
|
||||||
|
private BookChapterContentService bookChapterContentService;
|
||||||
|
|
||||||
|
//我的图书
|
||||||
|
@RequestMapping("/getMyBooks")
|
||||||
|
public R getMyBooks(@RequestBody Map<String,Object> params){
|
||||||
|
MPJLambdaWrapper<UserEbookBuyEntity> wrapper = new MPJLambdaWrapper<>();
|
||||||
|
wrapper.leftJoin(BookReadRateEntity.class,BookReadRateEntity::getBookId,UserEbookBuyEntity::getBookId);
|
||||||
|
wrapper.leftJoin(BookEntity.class,BookEntity::getId,UserEbookBuyEntity::getBookId);
|
||||||
|
wrapper.eq(UserEbookBuyEntity::getUserId,ShiroUtils.getUId());
|
||||||
|
wrapper.select(BookEntity::getId,BookEntity::getName,BookEntity::getImages);
|
||||||
|
wrapper.select(BookReadRateEntity::getPrecent);
|
||||||
|
wrapper.orderByDesc(BookReadRateEntity::getUpdateTime);
|
||||||
|
wrapper.groupBy(UserEbookBuyEntity::getBookId);
|
||||||
|
Page p = userEbookBuyService.pageMaps(new Page<>(
|
||||||
|
Long.parseLong(params.get("current").toString()), Long.parseLong(params.get("limit").toString())),wrapper);
|
||||||
|
return R.ok().put("page",p);
|
||||||
|
}
|
||||||
|
|
||||||
|
//推荐图书
|
||||||
|
@RequestMapping("/getRecommendBooks")
|
||||||
|
public R getRecommendBooks(){
|
||||||
|
//查询已购买图书
|
||||||
|
LambdaQueryWrapper<UserEbookBuyEntity> wrapper = new LambdaQueryWrapper<>();
|
||||||
|
wrapper.eq(UserEbookBuyEntity::getUserId,ShiroUtils.getUId());
|
||||||
|
wrapper.groupBy(UserEbookBuyEntity::getBookId);
|
||||||
|
Set<Integer> bookIds = userEbookBuyService.getBaseMapper().selectList(wrapper).stream()
|
||||||
|
.map(UserEbookBuyEntity::getBookId).collect(Collectors.toSet());
|
||||||
|
//查询未购买图书
|
||||||
|
List<BookEntity> noBooks = bookService.list(new LambdaQueryWrapper<BookEntity>()
|
||||||
|
.eq(BookEntity::getState,1)
|
||||||
|
.eq(BookEntity::getBookType,0)
|
||||||
|
.notIn(BookEntity::getId,bookIds)
|
||||||
|
.last("limit 2"));
|
||||||
|
Set<BookEntity> books = new HashSet<>();
|
||||||
|
//查询阅读进度
|
||||||
|
List<BookReadRateEntity> readRateList = bookReadRateService.list(new LambdaQueryWrapper<BookReadRateEntity>()
|
||||||
|
.eq(BookReadRateEntity::getUserId,ShiroUtils.getUId())
|
||||||
|
.orderByDesc(BookReadRateEntity::getUpdateTime));
|
||||||
|
//根据阅读记录,查询同标签下书籍
|
||||||
|
if (readRateList.size()>0){
|
||||||
|
//书籍绑定的标签
|
||||||
|
List<BookAbroadToLable> tolableBookList = toLableService.list(new LambdaQueryWrapper<BookAbroadToLable>()
|
||||||
|
.eq(BookAbroadToLable::getBookId,readRateList.get(0).getBookId()));
|
||||||
|
for (BookAbroadToLable tolableBook : tolableBookList) {
|
||||||
|
//标签下的书籍
|
||||||
|
List<BookAbroadToLable> tolableLableList = toLableService.list(new LambdaQueryWrapper<BookAbroadToLable>()
|
||||||
|
.eq(BookAbroadToLable::getLableId,tolableBook.getLableId()));
|
||||||
|
for (BookAbroadToLable tolableLable : tolableLableList) {
|
||||||
|
if (bookIds.add(tolableLable.getBookId())) {
|
||||||
|
books.add(bookService.getById(tolableLable.getBookId()));
|
||||||
|
if (books.size()==2){
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//补充标签未填满位置
|
||||||
|
if (books.size()!=2){
|
||||||
|
int surplus = 2-books.size();
|
||||||
|
for (int i=0;i<surplus; i++){
|
||||||
|
books.add(noBooks.get(i));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return R.ok().put("books",books);
|
||||||
|
}
|
||||||
|
|
||||||
|
//获取标签列表
|
||||||
|
@RequestMapping("/getBookAbroadLableList")
|
||||||
|
public R getBookAbroadLableList(@RequestBody Map<String,Object> params) {
|
||||||
|
List<BookAbroadLable> list = lableService.list(new LambdaQueryWrapper<BookAbroadLable>()
|
||||||
|
.eq(BookAbroadLable::getPid,0)
|
||||||
|
.eq(BookAbroadLable::getType,params.get("type")));
|
||||||
|
return R.ok().put("lableList",list);
|
||||||
|
}
|
||||||
|
|
||||||
|
//获取子标签
|
||||||
|
@RequestMapping("/getBookAbroadLableListByPid")
|
||||||
|
public R getBookAbroadLableListByPid(@RequestBody Map<String,Object> params) {
|
||||||
|
List<BookAbroadLable> list = lableService.list(new LambdaQueryWrapper<BookAbroadLable>()
|
||||||
|
.eq(BookAbroadLable::getPid,params.get("pid")));
|
||||||
|
return R.ok().put("lableList",list);
|
||||||
|
}
|
||||||
|
|
||||||
|
//通过标签获取绑定图书
|
||||||
|
@RequestMapping("/getAbroadBookListByLable")
|
||||||
|
public R getAbroadBookListByLable(@RequestBody Map<String,Object> params) {
|
||||||
|
MPJLambdaWrapper<BookAbroadToLable> wrapper = new MPJLambdaWrapper();
|
||||||
|
wrapper.leftJoin(BookEntity.class,BookEntity::getId,BookAbroadToLable::getBookId);
|
||||||
|
wrapper.selectAs(BookAbroadToLable::getId,"toLableId");
|
||||||
|
wrapper.selectAs(BookEntity::getId,"bookId");
|
||||||
|
wrapper.selectAs(BookEntity::getAbroadPrice,"abroadPrice");
|
||||||
|
wrapper.select(BookEntity::getImages);
|
||||||
|
wrapper.select(BookEntity::getName);
|
||||||
|
wrapper.eq(BookAbroadToLable::getLableId,params.get("lableId"));
|
||||||
|
return R.ok().put("bookList",toLableService.listMaps(wrapper));
|
||||||
|
}
|
||||||
|
|
||||||
|
//图书详情
|
||||||
|
@RequestMapping("/getBookInfo")
|
||||||
|
public R getBookInfo(@RequestBody Map<String,Object> params) {
|
||||||
|
BookEntity bookEntity = bookService.getById(params.get("bookId").toString());
|
||||||
|
bookEntity.setAuthor(authorService.getById(bookEntity.getAuthorId()));
|
||||||
|
bookEntity.setIsBuy(false);
|
||||||
|
int count = userEbookBuyService.count(new LambdaQueryWrapper<UserEbookBuyEntity>()
|
||||||
|
.eq(UserEbookBuyEntity::getUserId,ShiroUtils.getUId())
|
||||||
|
.eq(UserEbookBuyEntity::getBookId,params.get("bookId")));
|
||||||
|
if (count > 0) {
|
||||||
|
bookEntity.setIsBuy(true);
|
||||||
|
}
|
||||||
|
return R.ok().put("bookInfo",bookEntity);
|
||||||
|
}
|
||||||
|
|
||||||
|
//图书章节
|
||||||
|
@RequestMapping("/getBookChapter")
|
||||||
|
public R getBookChapter(@RequestBody Map<String,Object> params) {
|
||||||
|
List<BookChapterEntity> chapterList = bookChapterService.list(new LambdaQueryWrapper<BookChapterEntity>()
|
||||||
|
.eq(BookChapterEntity::getBookId,params.get("bookId"))
|
||||||
|
.orderByAsc(BookChapterEntity::getId));
|
||||||
|
return R.ok().put("chapterList",chapterList);
|
||||||
|
}
|
||||||
|
|
||||||
|
//章节内容
|
||||||
|
@RequestMapping("/getBookChapterContent")
|
||||||
|
public R getBookChapterContent(@RequestBody Map<String,Object> params) {
|
||||||
|
Page<BookChapterContentEntity> contentPage = bookChapterContentService.page(new Page<>(
|
||||||
|
Long.parseLong(params.get("current").toString()), Long.parseLong(params.get("limit").toString())),
|
||||||
|
new LambdaQueryWrapper<BookChapterContentEntity>()
|
||||||
|
.eq(BookChapterContentEntity::getBookChatperId,params.get("chapterId"))
|
||||||
|
.orderByAsc(BookChapterContentEntity::getNumber));
|
||||||
|
return R.ok().put("contentPage",contentPage);
|
||||||
|
}
|
||||||
|
|
||||||
|
//获取当前书的阅读记录
|
||||||
|
@RequestMapping("/getBookReadRate")
|
||||||
|
public R getBookReadRate(@RequestBody Map<String,Object> params){
|
||||||
|
BookReadRateEntity brr = bookReadRateService.getOne(new LambdaQueryWrapper<BookReadRateEntity>()
|
||||||
|
.eq(BookReadRateEntity::getUserId,ShiroUtils.getUId())
|
||||||
|
.eq(BookReadRateEntity::getBookId,params.get("bookId")));
|
||||||
|
return R.ok().put("bookReadRate",brr);
|
||||||
|
}
|
||||||
|
|
||||||
|
//新增阅读记录
|
||||||
|
@RequestMapping("/insertBookReadRate")
|
||||||
|
public R insertBookReadRate(@RequestBody BookReadRateEntity bookReadRate){
|
||||||
|
//计算百分比
|
||||||
|
int count = bookChapterContentService.count(new LambdaQueryWrapper<BookChapterContentEntity>()
|
||||||
|
.eq(BookChapterContentEntity::getBookId,bookReadRate.getBookId()));
|
||||||
|
BookChapterContentEntity bcc = bookChapterContentService.getById(bookReadRate.getContentId());
|
||||||
|
int pre = bcc.getNumber()*100/count;
|
||||||
|
bookReadRate.setPrecent(pre);
|
||||||
|
BookReadRateEntity brr = bookReadRateService.getOne(new LambdaQueryWrapper<BookReadRateEntity>()
|
||||||
|
.eq(BookReadRateEntity::getUserId,ShiroUtils.getUId())
|
||||||
|
.eq(BookReadRateEntity::getBookId,bookReadRate.getBookId()));
|
||||||
|
if (brr==null){
|
||||||
|
bookReadRate.setUserId(ShiroUtils.getUId());
|
||||||
|
bookReadRateService.save(bookReadRate);
|
||||||
|
}else {
|
||||||
|
brr.setChapterId(bookReadRate.getChapterId());
|
||||||
|
brr.setChapterName(bookReadRate.getChapterName());
|
||||||
|
brr.setContentId(bookReadRate.getContentId());
|
||||||
|
brr.setPrecent(bookReadRate.getPrecent());
|
||||||
|
brr.setUpdateTime(new Date());
|
||||||
|
bookReadRateService.updateById(brr);
|
||||||
|
}
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
//相关图书
|
||||||
|
@RequestMapping("/getRecommendBook")
|
||||||
|
public R getRecommendBook(@RequestBody Map<String,Object> params){
|
||||||
|
Set<BookEntity> bookList = new HashSet<>();
|
||||||
|
//书籍绑定的标签
|
||||||
|
List<BookAbroadToLable> tolableBookList = toLableService.list(new LambdaQueryWrapper<BookAbroadToLable>()
|
||||||
|
.eq(BookAbroadToLable::getBookId,params.get("bookId")));
|
||||||
|
for (BookAbroadToLable tolableBook : tolableBookList) {
|
||||||
|
//标签下的书籍
|
||||||
|
List<BookAbroadToLable> tolableLableList = toLableService.list(new LambdaQueryWrapper<BookAbroadToLable>()
|
||||||
|
.eq(BookAbroadToLable::getLableId,tolableBook.getLableId()));
|
||||||
|
for (BookAbroadToLable tolableLable : tolableLableList) {
|
||||||
|
bookList.add(bookService.getById(tolableLable.getBookId()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return R.ok().put("bookList",bookList);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,53 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.controller;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
||||||
|
import com.peanut.common.utils.R;
|
||||||
|
import com.peanut.config.DelayQueueConfig;
|
||||||
|
import com.peanut.modules.book.service.BuyOrderService;
|
||||||
|
import com.peanut.modules.common.entity.BuyOrder;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.amqp.core.MessagePostProcessor;
|
||||||
|
import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@RestController("bookAbroadOrder")
|
||||||
|
@RequestMapping("bookAbroad/order")
|
||||||
|
public class OrderController {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private BuyOrderService buyOrderService;
|
||||||
|
@Autowired
|
||||||
|
private RabbitTemplate rabbitTemplate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 充值专用订单生成接口
|
||||||
|
*/
|
||||||
|
@RequestMapping("/rechargeSave")
|
||||||
|
public R rechargeSave(@RequestBody BuyOrder buyOrder){
|
||||||
|
buyOrder.setOrderStatus("0");
|
||||||
|
buyOrder.setOrderType("abroadBook");
|
||||||
|
String timeId = IdWorker.getTimeId().substring(0, 32);
|
||||||
|
buyOrder.setOrderSn(timeId);
|
||||||
|
buyOrderService.save(buyOrder);
|
||||||
|
rabbitTemplate.convertAndSend(
|
||||||
|
DelayQueueConfig.ORDER_TO_BE_PAY_EXCHANGE,
|
||||||
|
DelayQueueConfig.ORDER_TO_BE_PAY_ROUTING_KEY,
|
||||||
|
buyOrder.getOrderId(),
|
||||||
|
messagePostProcessor()
|
||||||
|
);
|
||||||
|
return R.ok().put("orderSn", timeId);
|
||||||
|
}
|
||||||
|
|
||||||
|
private MessagePostProcessor messagePostProcessor() {
|
||||||
|
return message -> {
|
||||||
|
//设置有效期30分钟
|
||||||
|
message.getMessageProperties().setExpiration(String.valueOf(30 * 60 * 1000));
|
||||||
|
return message;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadCommentLike;
|
||||||
|
|
||||||
|
public interface BookAbroadCommentLikeService extends IService<BookAbroadCommentLike> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadComment;
|
||||||
|
|
||||||
|
public interface BookAbroadCommentService extends IService<BookAbroadComment> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadLable;
|
||||||
|
|
||||||
|
public interface BookAbroadLableService extends IService<BookAbroadLable> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadToLable;
|
||||||
|
|
||||||
|
public interface BookAbroadToLableService extends IService<BookAbroadToLable> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadCommentLikeService;
|
||||||
|
import com.peanut.modules.common.dao.BookAbroadCommentLikeDao;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadCommentLike;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service("bookAbroadCommentLikeService")
|
||||||
|
public class BookAbroadCommentLikeServiceImpl extends ServiceImpl<BookAbroadCommentLikeDao, BookAbroadCommentLike> implements BookAbroadCommentLikeService {
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.peanut.modules.common.dao.BookAbroadCommentDao;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadComment;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadCommentService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service("bookAbroadComment")
|
||||||
|
public class BookAbroadCommentServiceImpl extends ServiceImpl<BookAbroadCommentDao, BookAbroadComment> implements BookAbroadCommentService {
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.peanut.modules.common.dao.BookAbroadLableDao;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadLable;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadLableService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service("bookAbroadLableService")
|
||||||
|
public class BookAbroadLableServiceImpl extends ServiceImpl<BookAbroadLableDao, BookAbroadLable> implements BookAbroadLableService {
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package com.peanut.modules.bookAbroad.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.peanut.modules.bookAbroad.service.BookAbroadToLableService;
|
||||||
|
import com.peanut.modules.common.dao.BookAbroadToLableDao;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadToLable;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service("bookAbroadToLableService")
|
||||||
|
public class BookAbroadToLableServiceImpl extends ServiceImpl<BookAbroadToLableDao, BookAbroadToLable> implements BookAbroadToLableService {
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
package com.peanut.modules.common.dao;
|
||||||
|
|
||||||
|
import com.github.yulichang.base.MPJBaseMapper;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadComment;
|
||||||
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
|
||||||
|
@Mapper
|
||||||
|
public interface BookAbroadCommentDao extends MPJBaseMapper<BookAbroadComment> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
package com.peanut.modules.common.dao;
|
||||||
|
|
||||||
|
import com.github.yulichang.base.MPJBaseMapper;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadCommentLike;
|
||||||
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
|
||||||
|
@Mapper
|
||||||
|
public interface BookAbroadCommentLikeDao extends MPJBaseMapper<BookAbroadCommentLike> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
package com.peanut.modules.common.dao;
|
||||||
|
|
||||||
|
import com.github.yulichang.base.MPJBaseMapper;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadLable;
|
||||||
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
|
||||||
|
@Mapper
|
||||||
|
public interface BookAbroadLableDao extends MPJBaseMapper<BookAbroadLable> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
package com.peanut.modules.common.dao;
|
||||||
|
|
||||||
|
import com.github.yulichang.base.MPJBaseMapper;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadToLable;
|
||||||
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
|
||||||
|
@Mapper
|
||||||
|
public interface BookAbroadToLableDao extends MPJBaseMapper<BookAbroadToLable> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,39 @@
|
|||||||
|
package com.peanut.modules.common.entity;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableLogic;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
//海外书籍评论
|
||||||
|
@Data
|
||||||
|
@TableName("book_abroad_comment")
|
||||||
|
public class BookAbroadComment implements Serializable {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
@TableId
|
||||||
|
private Integer id;
|
||||||
|
//父id
|
||||||
|
private Integer pid;
|
||||||
|
//书籍id
|
||||||
|
private Integer bookId;
|
||||||
|
//用户id
|
||||||
|
private Integer userId;
|
||||||
|
//评论内容
|
||||||
|
private String content;
|
||||||
|
//创建时间
|
||||||
|
private Date createTime;
|
||||||
|
@TableLogic
|
||||||
|
private Integer delFlag;
|
||||||
|
|
||||||
|
@TableField(exist = false)
|
||||||
|
private int isLike;
|
||||||
|
@TableField(exist = false)
|
||||||
|
private MyUserEntity userEntity;
|
||||||
|
@TableField(exist = false)
|
||||||
|
private List<BookAbroadComment> children;
|
||||||
|
}
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
package com.peanut.modules.common.entity;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableLogic;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import lombok.Data;
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
//海外书籍评论点赞
|
||||||
|
@Data
|
||||||
|
@TableName("book_abroad_comment_like")
|
||||||
|
public class BookAbroadCommentLike implements Serializable {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
@TableId
|
||||||
|
private Integer id;
|
||||||
|
//评论id
|
||||||
|
private Integer commentId;
|
||||||
|
//用户id
|
||||||
|
private Integer userId;
|
||||||
|
@TableLogic
|
||||||
|
private Integer delFlag;
|
||||||
|
}
|
||||||
@@ -0,0 +1,54 @@
|
|||||||
|
package com.peanut.modules.common.entity;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableLogic;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import lombok.Data;
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
//海外书籍分类
|
||||||
|
@Data
|
||||||
|
@TableName("book_abroad_lable")
|
||||||
|
public class BookAbroadLable implements Serializable {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
@TableId
|
||||||
|
private Integer id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 父id
|
||||||
|
*/
|
||||||
|
private Integer pid;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 类型0分类标签 1营销标签
|
||||||
|
*/
|
||||||
|
private Integer type;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 标题
|
||||||
|
*/
|
||||||
|
private String title;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 0否1是
|
||||||
|
*/
|
||||||
|
private Integer isLast;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 权重
|
||||||
|
*/
|
||||||
|
private Integer sort;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建时间
|
||||||
|
*/
|
||||||
|
private Date createTime;
|
||||||
|
|
||||||
|
@TableLogic
|
||||||
|
private Integer delFlag;
|
||||||
|
@TableField(exist = false)
|
||||||
|
private List<BookAbroadLable> children;
|
||||||
|
}
|
||||||
@@ -0,0 +1,40 @@
|
|||||||
|
package com.peanut.modules.common.entity;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableLogic;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import lombok.Data;
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
//海外书籍分类绑定表
|
||||||
|
@Data
|
||||||
|
@TableName("book_abroad_to_lable")
|
||||||
|
public class BookAbroadToLable implements Serializable {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
@TableId
|
||||||
|
private Integer id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 书籍id
|
||||||
|
*/
|
||||||
|
private Integer bookId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 标签id
|
||||||
|
*/
|
||||||
|
private Integer lableId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 权重
|
||||||
|
*/
|
||||||
|
private Integer sort;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建时间
|
||||||
|
*/
|
||||||
|
private Date createTime;
|
||||||
|
|
||||||
|
@TableLogic
|
||||||
|
private Integer delFlag;
|
||||||
|
}
|
||||||
@@ -73,6 +73,10 @@ public class BookEntity implements Serializable {
|
|||||||
* 价格
|
* 价格
|
||||||
*/
|
*/
|
||||||
private BigDecimal price;
|
private BigDecimal price;
|
||||||
|
/**
|
||||||
|
* 海外价格
|
||||||
|
*/
|
||||||
|
private BigDecimal abroadPrice;
|
||||||
/**
|
/**
|
||||||
* 价格
|
* 价格
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -1,9 +1,6 @@
|
|||||||
package com.peanut.modules.common.entity;
|
package com.peanut.modules.common.entity;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.FieldFill;
|
import com.baomidou.mybatisplus.annotation.*;
|
||||||
import com.baomidou.mybatisplus.annotation.TableField;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableId;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableName;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
@@ -67,6 +64,7 @@ public class BookReadRateEntity implements Serializable {
|
|||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@TableLogic
|
||||||
private Integer delFlag;
|
private Integer delFlag;
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -67,11 +67,11 @@ public class BuyOrder implements Serializable {
|
|||||||
*/
|
*/
|
||||||
private String address;
|
private String address;
|
||||||
/**
|
/**
|
||||||
* 订单来源,0疯子读书1国学众妙之门2医学吴门医述
|
* 订单来源,0疯子读书1国学众妙之门2医学吴门医述3海外读书
|
||||||
*/
|
*/
|
||||||
private Integer come;
|
private Integer come;
|
||||||
/**
|
/**
|
||||||
* 支付方式 1微信,2支付宝,3ios内购 ,4虚拟币
|
* 支付方式 1微信,2支付宝,3ios内购 ,4虚拟币 5PayPal
|
||||||
*/
|
*/
|
||||||
private String paymentMethod;
|
private String paymentMethod;
|
||||||
/**
|
/**
|
||||||
@@ -149,7 +149,7 @@ public class BuyOrder implements Serializable {
|
|||||||
private String buyType;
|
private String buyType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* vip order point
|
* vip order point abroadBook
|
||||||
*/
|
*/
|
||||||
private String orderType;
|
private String orderType;
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,147 @@
|
|||||||
|
package com.peanut.modules.master.controller;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
|
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
||||||
|
import com.peanut.common.utils.R;
|
||||||
|
import com.peanut.modules.common.entity.*;
|
||||||
|
import com.peanut.modules.master.service.*;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@RestController("masterBookAbroad")
|
||||||
|
@RequestMapping("master/bookAbroad")
|
||||||
|
public class BookAbroadController {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private BookAbroadCommentService bookAbroadCommentService;
|
||||||
|
@Autowired
|
||||||
|
private com.peanut.modules.bookAbroad.service.BookAbroadLableService labelService;
|
||||||
|
@Autowired
|
||||||
|
private com.peanut.modules.bookAbroad.service.BookAbroadToLableService toLableService;
|
||||||
|
|
||||||
|
//评论列表
|
||||||
|
@RequestMapping("/getBookAbroadCommentList")
|
||||||
|
public R getBookAbroadCommentList(@RequestBody Map<String,Object> params) {
|
||||||
|
Page comments = bookAbroadCommentService.page(
|
||||||
|
new Page<>(Long.parseLong(params.get("current").toString()), Long.parseLong(params.get("limit").toString())),
|
||||||
|
new LambdaQueryWrapper<BookAbroadComment>().like(BookAbroadComment::getContent,params.get("content")));
|
||||||
|
return R.ok().put("comments",comments);
|
||||||
|
}
|
||||||
|
//删除评论
|
||||||
|
@RequestMapping("/delBookAbroadComment")
|
||||||
|
public R delBookAbroadComment(@RequestBody Map<String,Object> params){
|
||||||
|
bookAbroadCommentService.removeById(params.get("commentId").toString());
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
//新增标签
|
||||||
|
@RequestMapping("/insertBookAbroadLable")
|
||||||
|
public R insertBookAbroadLable(@RequestBody BookAbroadLable lable){
|
||||||
|
labelService.save(lable);
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
//标签详情
|
||||||
|
@RequestMapping("/bookAbroadLableInfo")
|
||||||
|
public R bookAbroadLableInfo(@RequestBody Map<String,Object> params){
|
||||||
|
BookAbroadLable lable = labelService.getById(params.get("id").toString());
|
||||||
|
return R.ok().put("lable",lable);
|
||||||
|
}
|
||||||
|
|
||||||
|
//修改标签
|
||||||
|
@RequestMapping("/updateBookAbroadLable")
|
||||||
|
public R updateBookAbroadLable(@RequestBody BookAbroadLable lable){
|
||||||
|
BookAbroadLable oldLable = labelService.getById(lable.getId());
|
||||||
|
if (oldLable.getIsLast()!=lable.getIsLast()) {
|
||||||
|
int count = toLableService.count(new LambdaQueryWrapper<BookAbroadToLable>()
|
||||||
|
.eq(BookAbroadToLable::getLableId,lable.getId()));
|
||||||
|
if (count > 0){
|
||||||
|
return R.error("存在绑定书籍,删除后再操作");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
labelService.updateById(lable);
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
//删除标签
|
||||||
|
@RequestMapping("/delBookAbroadLable")
|
||||||
|
public R delBookAbroadLable(@RequestBody Map<String,Object> params){
|
||||||
|
BookAbroadLable oldLable = labelService.getById(params.get("id").toString());
|
||||||
|
int count = toLableService.count(new LambdaQueryWrapper<BookAbroadToLable>()
|
||||||
|
.eq(BookAbroadToLable::getLableId,params.get("id").toString()));
|
||||||
|
if (count > 0){
|
||||||
|
return R.error("存在绑定书籍,删除后再操作");
|
||||||
|
}
|
||||||
|
labelService.removeById(oldLable.getId());
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
//绑定图书和标签
|
||||||
|
@RequestMapping("/insertBookAbroadToLable")
|
||||||
|
public R insertBookAbroadToLable(@RequestBody BookAbroadToLable toLable){
|
||||||
|
int count = toLableService.count(new LambdaQueryWrapper<BookAbroadToLable>()
|
||||||
|
.eq(BookAbroadToLable::getBookId,toLable.getBookId())
|
||||||
|
.eq(BookAbroadToLable::getLableId,toLable.getLableId()));
|
||||||
|
if (count > 0) {
|
||||||
|
return R.error("已存在");
|
||||||
|
}
|
||||||
|
toLableService.save(toLable);
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
//解绑
|
||||||
|
@RequestMapping("/delBookAbroadToLable")
|
||||||
|
public R delBookAbroadToLable(@RequestBody Map<String,Object> params){
|
||||||
|
String[] strings = params.get("ids").toString().split(",");
|
||||||
|
toLableService.removeByIds(Arrays.asList(strings));
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
//通过标签获取绑定图书
|
||||||
|
@RequestMapping("/getAbroadBookListByLable")
|
||||||
|
public R getAbroadBookListByLable(@RequestBody Map<String,Object> params) {
|
||||||
|
MPJLambdaWrapper<BookAbroadToLable> wrapper = new MPJLambdaWrapper();
|
||||||
|
wrapper.leftJoin(BookEntity.class,BookEntity::getId,BookAbroadToLable::getBookId);
|
||||||
|
wrapper.selectAs(BookAbroadToLable::getId,"id");
|
||||||
|
wrapper.select(BookEntity::getName);
|
||||||
|
wrapper.eq(BookAbroadToLable::getLableId,params.get("lableId"));
|
||||||
|
return R.ok().put("bookList",toLableService.listMaps(wrapper));
|
||||||
|
}
|
||||||
|
|
||||||
|
//标签树
|
||||||
|
@RequestMapping("/getLableTree")
|
||||||
|
public List<BookAbroadLable> getLableTree(@RequestBody Map<String,Object> params) {
|
||||||
|
List<BookAbroadLable> labels = labelService.list(new LambdaQueryWrapper<BookAbroadLable>()
|
||||||
|
.eq(BookAbroadLable::getType,params.get("type")));
|
||||||
|
List<BookAbroadLable> labelsTree = labels.stream().filter((bookAbroadLable) ->
|
||||||
|
bookAbroadLable.getPid() == 0
|
||||||
|
).map((label)->{
|
||||||
|
label.setChildren(getLabelChildrens(label,labels));
|
||||||
|
return label;
|
||||||
|
}).sorted((label1,label2)->{
|
||||||
|
return (label1.getSort() == null? 0 : label1.getSort()) - (label2.getSort()==null?0:label2.getSort());
|
||||||
|
}).collect(Collectors.toList());
|
||||||
|
return labelsTree;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<BookAbroadLable> getLabelChildrens(BookAbroadLable root,List<BookAbroadLable> all){
|
||||||
|
List<BookAbroadLable> children = all.stream().filter(bookAbroadLable -> {
|
||||||
|
return root.getId().equals(bookAbroadLable.getPid());
|
||||||
|
}).map(bookAbroadLable -> {
|
||||||
|
bookAbroadLable.setChildren(getLabelChildrens(bookAbroadLable, all));
|
||||||
|
return bookAbroadLable;
|
||||||
|
}).sorted((label1,label2)->{
|
||||||
|
return (label1.getSort()==null?0:label1.getSort()) - (label2.getSort()==null?0:label2.getSort());
|
||||||
|
}).collect(Collectors.toList());
|
||||||
|
return children;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.peanut.modules.master.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadCommentLike;
|
||||||
|
|
||||||
|
public interface BookAbroadCommentLikeService extends IService<BookAbroadCommentLike> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.peanut.modules.master.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadComment;
|
||||||
|
|
||||||
|
public interface BookAbroadCommentService extends IService<BookAbroadComment> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.peanut.modules.master.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadLable;
|
||||||
|
|
||||||
|
public interface BookAbroadLableService extends IService<BookAbroadLable> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.peanut.modules.master.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadToLable;
|
||||||
|
|
||||||
|
public interface BookAbroadToLableService extends IService<BookAbroadToLable> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package com.peanut.modules.master.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.peanut.modules.common.dao.BookAbroadCommentLikeDao;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadCommentLike;
|
||||||
|
import com.peanut.modules.master.service.BookAbroadCommentLikeService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service("masterBookAbroadCommentLikeService")
|
||||||
|
public class BookAbroadCommentLikeServiceImpl extends ServiceImpl<BookAbroadCommentLikeDao, BookAbroadCommentLike> implements BookAbroadCommentLikeService {
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package com.peanut.modules.master.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.peanut.modules.common.dao.BookAbroadCommentDao;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadComment;
|
||||||
|
import com.peanut.modules.master.service.BookAbroadCommentService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service("masterBookAbroadCommentService")
|
||||||
|
public class BookAbroadCommentServiceImpl extends ServiceImpl<BookAbroadCommentDao, BookAbroadComment> implements BookAbroadCommentService {
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package com.peanut.modules.master.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.peanut.modules.common.dao.BookAbroadLableDao;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadLable;
|
||||||
|
import com.peanut.modules.master.service.BookAbroadLableService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service("masterBookAbroadLableService")
|
||||||
|
public class BookAbroadLableServiceImpl extends ServiceImpl<BookAbroadLableDao, BookAbroadLable> implements BookAbroadLableService {
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package com.peanut.modules.master.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.peanut.modules.common.dao.BookAbroadToLableDao;
|
||||||
|
import com.peanut.modules.common.entity.BookAbroadToLable;
|
||||||
|
import com.peanut.modules.master.service.BookAbroadToLableService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service("masterBookAbroadToLableService")
|
||||||
|
public class BookAbroadToLableServiceImpl extends ServiceImpl<BookAbroadToLableDao, BookAbroadToLable> implements BookAbroadToLableService {
|
||||||
|
}
|
||||||
183
src/main/java/com/peanut/modules/pay/paypal/PaypalConfig.java
Normal file
183
src/main/java/com/peanut/modules/pay/paypal/PaypalConfig.java
Normal file
@@ -0,0 +1,183 @@
|
|||||||
|
package com.peanut.modules.pay.paypal;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONArray;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.net.HttpURLConnection;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
@Slf4j
|
||||||
|
public class PaypalConfig {
|
||||||
|
|
||||||
|
//沙盒
|
||||||
|
public static final String modeUrl = "https://api-m.sandbox.paypal.com";
|
||||||
|
public static final String CLIENID ="Ab8SeEuhkLGp6Fts9V3Cti0UcXQhITRWZkiHDM3U1fDY9YrrRc5IOcYHPfV6qROhmh0hvgysqrfOCSUr";
|
||||||
|
public static final String SECRET ="EF63FGWI9fd4q07Ndvc_h8P7jxiZcGOWn8Ul_y1_EKpluKJNFHOW8BP62Kf1wBDQ3XYIeqF8_kVrDF7C";
|
||||||
|
public static final String WEBSCR ="https://www.sandbox.paypal.com/cgi-bin/webscr";//回调验证地址
|
||||||
|
|
||||||
|
//正式
|
||||||
|
// public static final String modeUrl = "https://api-m.paypal.com";
|
||||||
|
// public static final String CLIENID ="";
|
||||||
|
// public static final String SECRET ="";
|
||||||
|
// public static final String WEBSCR ="https://www.paypal.com/cgi-bin/webscr";
|
||||||
|
|
||||||
|
|
||||||
|
public static final String accessTokenURL = "/v1/oauth2/token";
|
||||||
|
public static final String createOrderURL = "/v2/checkout/orders";
|
||||||
|
public static final String captureURL = "/v2/checkout/orders/%1s/capture";
|
||||||
|
public static final String orderInfoURL = "/v2/checkout/orders/";
|
||||||
|
public static final String refundURL = "/v2/payments/captures/%1s/refund";
|
||||||
|
public static final String refundInfoURL = "/v2/payments/refunds/";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//回调验证
|
||||||
|
public String receiveVerify(String verifyData) throws Exception{
|
||||||
|
URL url = new URL(WEBSCR);
|
||||||
|
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
|
||||||
|
connection.setRequestMethod("POST");
|
||||||
|
connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
|
||||||
|
connection.setDoOutput(true);
|
||||||
|
OutputStreamWriter writer = new OutputStreamWriter(connection.getOutputStream());
|
||||||
|
writer.write(verifyData);
|
||||||
|
writer.flush();
|
||||||
|
writer.close();
|
||||||
|
connection.getOutputStream().close();
|
||||||
|
InputStream responseStream = connection.getResponseCode() / 100 == 2
|
||||||
|
? connection.getInputStream()
|
||||||
|
: connection.getErrorStream();
|
||||||
|
Scanner s = new Scanner(responseStream).useDelimiter("\\A");
|
||||||
|
String response = s.hasNext() ? s.next() : "";
|
||||||
|
System.out.println(response);
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
|
//退款查询
|
||||||
|
public JSONObject refundInfo(String refundId) throws Exception{
|
||||||
|
URL url = new URL(modeUrl+refundInfoURL+refundId);
|
||||||
|
HttpURLConnection httpConn = (HttpURLConnection) url.openConnection();
|
||||||
|
httpConn.setRequestMethod("GET");
|
||||||
|
httpConn.setRequestProperty("Content-Type", "application/json");
|
||||||
|
httpConn.setRequestProperty("Authorization", "Bearer " + getAccessToken().get("access_token"));
|
||||||
|
|
||||||
|
InputStream responseStream = httpConn.getResponseCode() / 100 == 2
|
||||||
|
? httpConn.getInputStream()
|
||||||
|
: httpConn.getErrorStream();
|
||||||
|
Scanner s = new Scanner(responseStream).useDelimiter("\\A");
|
||||||
|
String response = s.hasNext() ? s.next() : "";
|
||||||
|
System.out.println(response);
|
||||||
|
return JSONObject.parseObject(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
//退款
|
||||||
|
public JSONObject refund(String captureId) throws Exception{
|
||||||
|
URL url = new URL(String.format(modeUrl+refundURL,captureId));
|
||||||
|
HttpURLConnection httpConn = (HttpURLConnection) url.openConnection();
|
||||||
|
httpConn.setRequestMethod("POST");
|
||||||
|
httpConn.setRequestProperty("Content-Type", "application/json");
|
||||||
|
httpConn.setRequestProperty("Authorization", "Bearer " + getAccessToken().get("access_token"));
|
||||||
|
httpConn.setRequestProperty("Prefer", "return=representation");
|
||||||
|
httpConn.setDoOutput(true);
|
||||||
|
|
||||||
|
InputStream responseStream = httpConn.getResponseCode() / 100 == 2
|
||||||
|
? httpConn.getInputStream()
|
||||||
|
: httpConn.getErrorStream();
|
||||||
|
Scanner s = new Scanner(responseStream).useDelimiter("\\A");
|
||||||
|
String response = s.hasNext() ? s.next() : "";
|
||||||
|
System.out.println(response);
|
||||||
|
return JSONObject.parseObject(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
//订单查询
|
||||||
|
public JSONObject orderInfo(String paypalOrderId) throws Exception{
|
||||||
|
URL url = new URL(modeUrl+orderInfoURL+paypalOrderId);
|
||||||
|
HttpURLConnection httpConn = (HttpURLConnection) url.openConnection();
|
||||||
|
httpConn.setRequestMethod("GET");
|
||||||
|
httpConn.setRequestProperty("Authorization", "Bearer " + getAccessToken().get("access_token"));
|
||||||
|
|
||||||
|
InputStream responseStream = httpConn.getResponseCode() / 100 == 2
|
||||||
|
? httpConn.getInputStream()
|
||||||
|
: httpConn.getErrorStream();
|
||||||
|
Scanner s = new Scanner(responseStream).useDelimiter("\\A");
|
||||||
|
String response = s.hasNext() ? s.next() : "";
|
||||||
|
System.out.println(response);
|
||||||
|
return JSONObject.parseObject(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
//用户授权支付成功,进行扣款操作
|
||||||
|
public JSONObject capture(String paypalOrderId) throws Exception{
|
||||||
|
URL url = new URL(String.format(modeUrl+captureURL,paypalOrderId));
|
||||||
|
HttpURLConnection httpConn = (HttpURLConnection) url.openConnection();
|
||||||
|
httpConn.setRequestMethod("POST");
|
||||||
|
httpConn.setRequestProperty("Content-Type", "application/json");
|
||||||
|
httpConn.setRequestProperty("Authorization", "Bearer " + getAccessToken().get("access_token"));
|
||||||
|
|
||||||
|
InputStream responseStream = httpConn.getResponseCode() / 100 == 2
|
||||||
|
? httpConn.getInputStream()
|
||||||
|
: httpConn.getErrorStream();
|
||||||
|
Scanner s = new Scanner(responseStream).useDelimiter("\\A");
|
||||||
|
String response = s.hasNext() ? s.next() : "";
|
||||||
|
return JSONObject.parseObject(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
//下单
|
||||||
|
public JSONObject createOrder(JSONObject jsonObject){
|
||||||
|
try{
|
||||||
|
URL u = new URL(modeUrl+createOrderURL);
|
||||||
|
HttpURLConnection connection = (HttpURLConnection) u.openConnection();
|
||||||
|
connection.setRequestMethod("POST");
|
||||||
|
connection.setRequestProperty("Content-Type", "application/json");
|
||||||
|
connection.setRequestProperty("Authorization", "Bearer " + getAccessToken().get("access_token"));
|
||||||
|
connection.setDoOutput(true);
|
||||||
|
OutputStreamWriter writer = new OutputStreamWriter(connection.getOutputStream());
|
||||||
|
writer.write(jsonObject.toString());
|
||||||
|
writer.flush();
|
||||||
|
writer.close();
|
||||||
|
connection.getOutputStream().close();
|
||||||
|
InputStream responseStream = connection.getResponseCode() / 100 == 2
|
||||||
|
? connection.getInputStream()
|
||||||
|
: connection.getErrorStream();
|
||||||
|
Scanner s = new Scanner(responseStream).useDelimiter("\\A");
|
||||||
|
String response = s.hasNext() ? s.next() : "";
|
||||||
|
return JSONObject.parseObject(response);
|
||||||
|
}catch (Exception e) {
|
||||||
|
log.error(">>>>>>>>>>:PayPal创建订单网络连接失败 reason = {}", e.getMessage());
|
||||||
|
e.printStackTrace();
|
||||||
|
return JSONObject.parseObject("{'error':'PayPal创建订单网络连接失败,请联系管理员'}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public JSONObject getAccessToken(){
|
||||||
|
try {
|
||||||
|
String credentials = CLIENID + ":" + SECRET;
|
||||||
|
String encodedCredentials = Base64.getEncoder().encodeToString(credentials.getBytes());
|
||||||
|
URL url = new URL(modeUrl+accessTokenURL);
|
||||||
|
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
|
||||||
|
connection.setRequestMethod("POST");
|
||||||
|
connection.setRequestProperty("Authorization", "Basic " + encodedCredentials);
|
||||||
|
connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
|
||||||
|
connection.setDoOutput(true);
|
||||||
|
String postParameters = "grant_type=client_credentials";
|
||||||
|
try (OutputStream os = connection.getOutputStream()) {
|
||||||
|
byte[] postParametersBytes = postParameters.getBytes();
|
||||||
|
os.write(postParametersBytes);
|
||||||
|
os.flush();
|
||||||
|
}
|
||||||
|
InputStream responseStream = connection.getResponseCode() / 100 == 2
|
||||||
|
? connection.getInputStream()
|
||||||
|
: connection.getErrorStream();
|
||||||
|
Scanner s = new Scanner(responseStream).useDelimiter("\\A");
|
||||||
|
String response = s.hasNext() ? s.next() : "";
|
||||||
|
return JSONObject.parseObject(response);
|
||||||
|
}catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,150 @@
|
|||||||
|
package com.peanut.modules.pay.paypal;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONArray;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import com.peanut.common.utils.R;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.net.URLEncoder;
|
||||||
|
import java.util.Enumeration;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* paypal支付
|
||||||
|
*/
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/pay/paypal")
|
||||||
|
@Slf4j
|
||||||
|
public class PaypalController {
|
||||||
|
//点击购买 ->去支付 ->跳转完成、取消页面
|
||||||
|
// ->创建订单 ->(支付完成)确认付款,打款到商家账户 ->支付成功
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private PaypalConfig paypalConfig;
|
||||||
|
|
||||||
|
@RequestMapping("/getAccessToken")
|
||||||
|
public R getAccessToken(){
|
||||||
|
JSONObject res = paypalConfig.getAccessToken();
|
||||||
|
return R.ok().put("res",res);
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping("/createOrder")
|
||||||
|
public R createOrder(@RequestBody Map<String,Object> params){
|
||||||
|
JSONArray purchase_units = new JSONArray();
|
||||||
|
JSONObject purchaseUnit = new JSONObject();
|
||||||
|
JSONObject amount = new JSONObject();
|
||||||
|
amount.put("currency_code", "USD");//美元
|
||||||
|
amount.put("value", params.get("amount"));// 金额
|
||||||
|
purchaseUnit.put("custom_id",params.get("orderSn"));
|
||||||
|
purchaseUnit.put("invoice_id",params.get("orderSn"));
|
||||||
|
purchaseUnit.put("amount",amount);
|
||||||
|
purchaseUnit.put("description", params.get("description"));
|
||||||
|
purchase_units.add(purchaseUnit);
|
||||||
|
//取消地址、返回地址设置
|
||||||
|
JSONObject applicationContext = new JSONObject();
|
||||||
|
applicationContext.put("user_action", "PAY_NOW");//付款按钮显示立即付款
|
||||||
|
applicationContext.put("shipping_preference", "NO_SHIPPING");//从 PayPal 网站编辑送货地址。推荐用于数字商品。
|
||||||
|
applicationContext.put("return_url", params.get("returnUrl"));//客户批准付款后重定向到客户的 URL
|
||||||
|
applicationContext.put("cancel_url", params.get("cancelUrl"));//客户取消付款后,客户被重定向的 URL
|
||||||
|
JSONObject jsonObject = new JSONObject();
|
||||||
|
// 用户付款了,商户立即收款
|
||||||
|
jsonObject.put("intent","CAPTURE");
|
||||||
|
jsonObject.put("purchase_units",purchase_units);
|
||||||
|
jsonObject.put("application_context", applicationContext);
|
||||||
|
JSONObject res = paypalConfig.createOrder(jsonObject);
|
||||||
|
if (res.containsKey("links")&&res.containsKey("status")){
|
||||||
|
if ("CREATED".equals(res.get("status").toString())){
|
||||||
|
List<JSONObject> links = (List)res.get("links");
|
||||||
|
for (JSONObject o:links) {
|
||||||
|
if ("approve".equals(o.get("rel").toString())){
|
||||||
|
return R.ok().put("res",o.get("href").toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return R.error(res.get("error").toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping("/orderInfo")
|
||||||
|
public R orderInfo(@RequestBody Map<String,Object> params) throws Exception{
|
||||||
|
JSONObject res = paypalConfig.orderInfo(params.get("paypalId").toString());
|
||||||
|
return R.ok().put("res",res);
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping("/capture")
|
||||||
|
public R capture(@RequestBody Map<String,Object> params) throws Exception{
|
||||||
|
JSONObject res = paypalConfig.capture(params.get("paypalId").toString());
|
||||||
|
return R.ok().put("res",res);
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping("/refund")
|
||||||
|
public R refund(@RequestBody Map<String,Object> params) throws Exception{
|
||||||
|
JSONObject res = paypalConfig.refund(params.get("captureId").toString());
|
||||||
|
return R.ok().put("res",res);
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping("/refundInfo")
|
||||||
|
public R refundInfo(@RequestBody Map<String,Object> params) throws Exception{
|
||||||
|
JSONObject res = paypalConfig.refundInfo(params.get("refundId").toString());
|
||||||
|
return R.ok().put("res",res);
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping("/receivePaypalStatus")
|
||||||
|
public void receivePaypalStatus(HttpServletRequest request, HttpServletResponse response) throws Exception{
|
||||||
|
//获取paypal请求参数,并拼接验证参数
|
||||||
|
Enumeration<String> en = request.getParameterNames();
|
||||||
|
String str = "cmd=_notify-validate";
|
||||||
|
while (en.hasMoreElements()) {
|
||||||
|
String paramName = en.nextElement();
|
||||||
|
String paramValue = request.getParameter(paramName);
|
||||||
|
str = str + "&" + paramName + "=" + paramValue;
|
||||||
|
}
|
||||||
|
System.out.println(str);
|
||||||
|
//发送给papal,确认回调信息的安全性
|
||||||
|
String res = paypalConfig.receiveVerify(str);
|
||||||
|
if ("VERIFIED".equals(res)){
|
||||||
|
// 交易状态 Completed 代表交易成功
|
||||||
|
String paymentStatus = request.getParameter("payment_status");
|
||||||
|
// 交易时间
|
||||||
|
String paymentDate = request.getParameter("payment_date");
|
||||||
|
// 付款人email
|
||||||
|
String payerEmail = request.getParameter("payer_email");
|
||||||
|
// 付款人id
|
||||||
|
String payerId = request.getParameter("payer_id");
|
||||||
|
// 交易金额
|
||||||
|
String mcGross = request.getParameter("mc_gross");
|
||||||
|
// 手续费
|
||||||
|
String paymentFee = request.getParameter("payment_fee");
|
||||||
|
// 自定义字段,存放订单号
|
||||||
|
String custom = request.getParameter("custom");
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping("/receiveVerify")
|
||||||
|
public R receiveVerify(@RequestBody Map<String,Object> params) throws Exception{
|
||||||
|
String res = params.get("verifyData").toString();
|
||||||
|
Map<String,Object> map = new HashMap<>();
|
||||||
|
String[] items = res.split("&");
|
||||||
|
for (String item : items) {
|
||||||
|
String[] keyValues = item.split("=");
|
||||||
|
if (keyValues.length>1){
|
||||||
|
map.put(keyValues[0],keyValues[1]);
|
||||||
|
}else {
|
||||||
|
map.put(keyValues[0],"");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return R.ok().put("res",map);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -36,6 +36,8 @@ public class SysUserTokenEntity implements Serializable {
|
|||||||
private String tokenMedical;
|
private String tokenMedical;
|
||||||
//token
|
//token
|
||||||
private String tokenSociology;
|
private String tokenSociology;
|
||||||
|
//token
|
||||||
|
private String tokenAbroad;
|
||||||
//过期时间
|
//过期时间
|
||||||
private Date expireTime;
|
private Date expireTime;
|
||||||
//更新时间
|
//更新时间
|
||||||
|
|||||||
@@ -44,12 +44,14 @@ public class SysUserTokenServiceImpl extends ServiceImpl<SysUserTokenDao, SysUse
|
|||||||
//根部不同登录平台生成不同token
|
//根部不同登录平台生成不同token
|
||||||
HttpServletRequest request = HttpContextUtil.getHttpServletRequest();
|
HttpServletRequest request = HttpContextUtil.getHttpServletRequest();
|
||||||
String appType = request.getHeader("appType")==null?"":request.getHeader("appType");
|
String appType = request.getHeader("appType")==null?"":request.getHeader("appType");
|
||||||
if ("".equals(appType)){
|
if ("".equals(appType)){//同时修改 SysUserTokenDao.xml
|
||||||
tokenEntity.setToken(token);
|
tokenEntity.setToken(token);
|
||||||
}else if ("medical".equals(appType)){
|
}else if ("medical".equals(appType)){
|
||||||
tokenEntity.setTokenMedical(token);
|
tokenEntity.setTokenMedical(token);
|
||||||
}else if ("sociology".equals(appType)){
|
}else if ("sociology".equals(appType)){
|
||||||
tokenEntity.setTokenSociology(token);
|
tokenEntity.setTokenSociology(token);
|
||||||
|
}else if ("abroad".equals(appType)){
|
||||||
|
tokenEntity.setTokenAbroad(token);
|
||||||
}
|
}
|
||||||
tokenEntity.setUserId(userId);
|
tokenEntity.setUserId(userId);
|
||||||
tokenEntity.setUpdateTime(now);
|
tokenEntity.setUpdateTime(now);
|
||||||
|
|||||||
@@ -4,6 +4,6 @@
|
|||||||
<mapper namespace="com.peanut.modules.sys.dao.SysUserTokenDao">
|
<mapper namespace="com.peanut.modules.sys.dao.SysUserTokenDao">
|
||||||
|
|
||||||
<select id="queryByToken" resultType="com.peanut.modules.sys.entity.SysUserTokenEntity">
|
<select id="queryByToken" resultType="com.peanut.modules.sys.entity.SysUserTokenEntity">
|
||||||
select * from sys_user_token where (token = #{value} or token_medical = #{value} or token_sociology = #{value})
|
select * from sys_user_token where (token = #{value} or token_medical = #{value} or token_sociology = #{value} or token_abroad = #{value})
|
||||||
</select>
|
</select>
|
||||||
</mapper>
|
</mapper>
|
||||||
Reference in New Issue
Block a user