From c8d7a10d9fc972bddb31ca92b496c715f31d3a2e Mon Sep 17 00:00:00 2001 From: xiongxiaoyang <773861846@qq.com> Date: Mon, 11 May 2020 18:28:07 +0800 Subject: [PATCH] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E5=85=85=E5=80=BC=E6=A8=A1?= =?UTF-8?q?=E5=9D=97=EF=BC=8C=E6=8E=A5=E9=80=9A=E6=94=AF=E4=BB=98=E5=AE=9D?= =?UTF-8?q?=E5=85=85=E5=80=BC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 2 + novel-admin/novel-admin.iml | 165 ------------- .../com/java2nb/novel/entity/OrderPay.java | 123 ++++++++++ .../mapper/OrderPayDynamicSqlSupport.java | 64 +++++ .../java2nb/novel/mapper/OrderPayMapper.java | 224 ++++++++++++++++++ .../main/resources/application-common-dev.yml | 4 +- .../resources/mybatis/generatorConfig.xml | 6 +- novel-front/pom.xml | 7 + .../novel/controller/PayController.java | 153 ++++++++++++ .../novel/core/config/AlipayConfig.java | 23 ++ .../java2nb/novel/service/OrderService.java | 29 +++ .../java2nb/novel/service/UserService.java | 5 + .../novel/service/impl/OrderServiceImpl.java | 85 +++++++ .../novel/service/impl/UserServiceImpl.java | 11 +- .../src/main/resources/application-alipay.yml | 17 ++ .../src/main/resources/application.yml | 4 + .../main/resources/static/images/pay_wx.png | Bin 0 -> 3669 bytes .../main/resources/static/images/pay_zfb.png | Bin 0 -> 5884 bytes .../resources/static/javascript/common.js | 2 +- .../main/resources/static/javascript/pay.js | 93 ++++++++ .../main/resources/templates/common/top.html | 2 +- .../main/resources/templates/pay/index.html | 139 +++++++++++ .../resources/templates/user/userinfo.html | 4 +- novel.iml | 50 ---- sql/20200511.sql | 33 +++ 25 files changed, 1021 insertions(+), 224 deletions(-) delete mode 100644 novel-admin/novel-admin.iml create mode 100644 novel-common/src/main/java/com/java2nb/novel/entity/OrderPay.java create mode 100644 novel-common/src/main/java/com/java2nb/novel/mapper/OrderPayDynamicSqlSupport.java create mode 100644 novel-common/src/main/java/com/java2nb/novel/mapper/OrderPayMapper.java create mode 100644 novel-front/src/main/java/com/java2nb/novel/controller/PayController.java create mode 100644 novel-front/src/main/java/com/java2nb/novel/core/config/AlipayConfig.java create mode 100644 novel-front/src/main/java/com/java2nb/novel/service/OrderService.java create mode 100644 novel-front/src/main/java/com/java2nb/novel/service/impl/OrderServiceImpl.java create mode 100644 novel-front/src/main/resources/application-alipay.yml create mode 100644 novel-front/src/main/resources/static/images/pay_wx.png create mode 100644 novel-front/src/main/resources/static/images/pay_zfb.png create mode 100644 novel-front/src/main/resources/static/javascript/pay.js create mode 100644 novel-front/src/main/resources/templates/pay/index.html delete mode 100644 novel.iml create mode 100644 sql/20200511.sql diff --git a/.gitignore b/.gitignore index 47fca9c..fa4fe09 100644 --- a/.gitignore +++ b/.gitignore @@ -11,3 +11,5 @@ /novel-crawl/novel-crawl.iml /novel-crawl/target /novel-admin/target +/*.iml +/novel-admin/*.iml diff --git a/novel-admin/novel-admin.iml b/novel-admin/novel-admin.iml deleted file mode 100644 index 9efc71a..0000000 --- a/novel-admin/novel-admin.iml +++ /dev/null @@ -1,165 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/novel-common/src/main/java/com/java2nb/novel/entity/OrderPay.java b/novel-common/src/main/java/com/java2nb/novel/entity/OrderPay.java new file mode 100644 index 0000000..4500b1f --- /dev/null +++ b/novel-common/src/main/java/com/java2nb/novel/entity/OrderPay.java @@ -0,0 +1,123 @@ +package com.java2nb.novel.entity; + +import java.util.Date; +import javax.annotation.Generated; + +public class OrderPay { + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private Long id; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private Long outTradeNo; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private String tradeNo; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private Byte payChannel; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private Integer totalAmount; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private Long userId; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private Byte payStatus; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private Date createTime; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + private Date updateTime; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public Long getId() { + return id; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setId(Long id) { + this.id = id; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public Long getOutTradeNo() { + return outTradeNo; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setOutTradeNo(Long outTradeNo) { + this.outTradeNo = outTradeNo; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public String getTradeNo() { + return tradeNo; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setTradeNo(String tradeNo) { + this.tradeNo = tradeNo == null ? null : tradeNo.trim(); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public Byte getPayChannel() { + return payChannel; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setPayChannel(Byte payChannel) { + this.payChannel = payChannel; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public Integer getTotalAmount() { + return totalAmount; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setTotalAmount(Integer totalAmount) { + this.totalAmount = totalAmount; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public Long getUserId() { + return userId; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setUserId(Long userId) { + this.userId = userId; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public Byte getPayStatus() { + return payStatus; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setPayStatus(Byte payStatus) { + this.payStatus = payStatus; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public Date getCreateTime() { + return createTime; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setCreateTime(Date createTime) { + this.createTime = createTime; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public Date getUpdateTime() { + return updateTime; + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public void setUpdateTime(Date updateTime) { + this.updateTime = updateTime; + } +} \ No newline at end of file diff --git a/novel-common/src/main/java/com/java2nb/novel/mapper/OrderPayDynamicSqlSupport.java b/novel-common/src/main/java/com/java2nb/novel/mapper/OrderPayDynamicSqlSupport.java new file mode 100644 index 0000000..4d39beb --- /dev/null +++ b/novel-common/src/main/java/com/java2nb/novel/mapper/OrderPayDynamicSqlSupport.java @@ -0,0 +1,64 @@ +package com.java2nb.novel.mapper; + +import java.sql.JDBCType; +import java.util.Date; +import javax.annotation.Generated; +import org.mybatis.dynamic.sql.SqlColumn; +import org.mybatis.dynamic.sql.SqlTable; + +public final class OrderPayDynamicSqlSupport { + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final OrderPay orderPay = new OrderPay(); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn id = orderPay.id; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn outTradeNo = orderPay.outTradeNo; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn tradeNo = orderPay.tradeNo; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn payChannel = orderPay.payChannel; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn totalAmount = orderPay.totalAmount; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn userId = orderPay.userId; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn payStatus = orderPay.payStatus; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn createTime = orderPay.createTime; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final SqlColumn updateTime = orderPay.updateTime; + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + public static final class OrderPay extends SqlTable { + public final SqlColumn id = column("id", JDBCType.BIGINT); + + public final SqlColumn outTradeNo = column("out_trade_no", JDBCType.BIGINT); + + public final SqlColumn tradeNo = column("trade_no", JDBCType.VARCHAR); + + public final SqlColumn payChannel = column("pay_channel", JDBCType.TINYINT); + + public final SqlColumn totalAmount = column("total_amount", JDBCType.INTEGER); + + public final SqlColumn userId = column("user_id", JDBCType.BIGINT); + + public final SqlColumn payStatus = column("pay_status", JDBCType.TINYINT); + + public final SqlColumn createTime = column("create_time", JDBCType.TIMESTAMP); + + public final SqlColumn updateTime = column("update_time", JDBCType.TIMESTAMP); + + public OrderPay() { + super("order_pay"); + } + } +} \ No newline at end of file diff --git a/novel-common/src/main/java/com/java2nb/novel/mapper/OrderPayMapper.java b/novel-common/src/main/java/com/java2nb/novel/mapper/OrderPayMapper.java new file mode 100644 index 0000000..f8406d8 --- /dev/null +++ b/novel-common/src/main/java/com/java2nb/novel/mapper/OrderPayMapper.java @@ -0,0 +1,224 @@ +package com.java2nb.novel.mapper; + +import static com.java2nb.novel.mapper.OrderPayDynamicSqlSupport.*; +import static org.mybatis.dynamic.sql.SqlBuilder.*; + +import com.java2nb.novel.entity.OrderPay; +import java.util.Collection; +import java.util.List; +import java.util.Optional; +import javax.annotation.Generated; +import org.apache.ibatis.annotations.DeleteProvider; +import org.apache.ibatis.annotations.InsertProvider; +import org.apache.ibatis.annotations.Mapper; +import org.apache.ibatis.annotations.Result; +import org.apache.ibatis.annotations.ResultMap; +import org.apache.ibatis.annotations.Results; +import org.apache.ibatis.annotations.SelectProvider; +import org.apache.ibatis.annotations.UpdateProvider; +import org.apache.ibatis.type.JdbcType; +import org.mybatis.dynamic.sql.BasicColumn; +import org.mybatis.dynamic.sql.delete.DeleteDSLCompleter; +import org.mybatis.dynamic.sql.delete.render.DeleteStatementProvider; +import org.mybatis.dynamic.sql.insert.render.InsertStatementProvider; +import org.mybatis.dynamic.sql.insert.render.MultiRowInsertStatementProvider; +import org.mybatis.dynamic.sql.select.CountDSLCompleter; +import org.mybatis.dynamic.sql.select.SelectDSLCompleter; +import org.mybatis.dynamic.sql.select.render.SelectStatementProvider; +import org.mybatis.dynamic.sql.update.UpdateDSL; +import org.mybatis.dynamic.sql.update.UpdateDSLCompleter; +import org.mybatis.dynamic.sql.update.UpdateModel; +import org.mybatis.dynamic.sql.update.render.UpdateStatementProvider; +import org.mybatis.dynamic.sql.util.SqlProviderAdapter; +import org.mybatis.dynamic.sql.util.mybatis3.MyBatis3Utils; + +@Mapper +public interface OrderPayMapper { + @Generated("org.mybatis.generator.api.MyBatisGenerator") + BasicColumn[] selectList = BasicColumn.columnList(id, outTradeNo, tradeNo, payChannel, totalAmount, userId, payStatus, createTime, updateTime); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + @SelectProvider(type=SqlProviderAdapter.class, method="select") + long count(SelectStatementProvider selectStatement); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + @DeleteProvider(type=SqlProviderAdapter.class, method="delete") + int delete(DeleteStatementProvider deleteStatement); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + @InsertProvider(type=SqlProviderAdapter.class, method="insert") + int insert(InsertStatementProvider insertStatement); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + @InsertProvider(type=SqlProviderAdapter.class, method="insertMultiple") + int insertMultiple(MultiRowInsertStatementProvider multipleInsertStatement); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + @SelectProvider(type=SqlProviderAdapter.class, method="select") + @ResultMap("OrderPayResult") + Optional selectOne(SelectStatementProvider selectStatement); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + @SelectProvider(type=SqlProviderAdapter.class, method="select") + @Results(id="OrderPayResult", value = { + @Result(column="id", property="id", jdbcType=JdbcType.BIGINT, id=true), + @Result(column="out_trade_no", property="outTradeNo", jdbcType=JdbcType.BIGINT), + @Result(column="trade_no", property="tradeNo", jdbcType=JdbcType.VARCHAR), + @Result(column="pay_channel", property="payChannel", jdbcType=JdbcType.TINYINT), + @Result(column="total_amount", property="totalAmount", jdbcType=JdbcType.INTEGER), + @Result(column="user_id", property="userId", jdbcType=JdbcType.BIGINT), + @Result(column="pay_status", property="payStatus", jdbcType=JdbcType.TINYINT), + @Result(column="create_time", property="createTime", jdbcType=JdbcType.TIMESTAMP), + @Result(column="update_time", property="updateTime", jdbcType=JdbcType.TIMESTAMP) + }) + List selectMany(SelectStatementProvider selectStatement); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + @UpdateProvider(type=SqlProviderAdapter.class, method="update") + int update(UpdateStatementProvider updateStatement); + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default long count(CountDSLCompleter completer) { + return MyBatis3Utils.countFrom(this::count, orderPay, completer); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default int delete(DeleteDSLCompleter completer) { + return MyBatis3Utils.deleteFrom(this::delete, orderPay, completer); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default int deleteByPrimaryKey(Long id_) { + return delete(c -> + c.where(id, isEqualTo(id_)) + ); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default int insert(OrderPay record) { + return MyBatis3Utils.insert(this::insert, record, orderPay, c -> + c.map(id).toProperty("id") + .map(outTradeNo).toProperty("outTradeNo") + .map(tradeNo).toProperty("tradeNo") + .map(payChannel).toProperty("payChannel") + .map(totalAmount).toProperty("totalAmount") + .map(userId).toProperty("userId") + .map(payStatus).toProperty("payStatus") + .map(createTime).toProperty("createTime") + .map(updateTime).toProperty("updateTime") + ); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default int insertMultiple(Collection records) { + return MyBatis3Utils.insertMultiple(this::insertMultiple, records, orderPay, c -> + c.map(id).toProperty("id") + .map(outTradeNo).toProperty("outTradeNo") + .map(tradeNo).toProperty("tradeNo") + .map(payChannel).toProperty("payChannel") + .map(totalAmount).toProperty("totalAmount") + .map(userId).toProperty("userId") + .map(payStatus).toProperty("payStatus") + .map(createTime).toProperty("createTime") + .map(updateTime).toProperty("updateTime") + ); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default int insertSelective(OrderPay record) { + return MyBatis3Utils.insert(this::insert, record, orderPay, c -> + c.map(id).toPropertyWhenPresent("id", record::getId) + .map(outTradeNo).toPropertyWhenPresent("outTradeNo", record::getOutTradeNo) + .map(tradeNo).toPropertyWhenPresent("tradeNo", record::getTradeNo) + .map(payChannel).toPropertyWhenPresent("payChannel", record::getPayChannel) + .map(totalAmount).toPropertyWhenPresent("totalAmount", record::getTotalAmount) + .map(userId).toPropertyWhenPresent("userId", record::getUserId) + .map(payStatus).toPropertyWhenPresent("payStatus", record::getPayStatus) + .map(createTime).toPropertyWhenPresent("createTime", record::getCreateTime) + .map(updateTime).toPropertyWhenPresent("updateTime", record::getUpdateTime) + ); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default Optional selectOne(SelectDSLCompleter completer) { + return MyBatis3Utils.selectOne(this::selectOne, selectList, orderPay, completer); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default List select(SelectDSLCompleter completer) { + return MyBatis3Utils.selectList(this::selectMany, selectList, orderPay, completer); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default List selectDistinct(SelectDSLCompleter completer) { + return MyBatis3Utils.selectDistinct(this::selectMany, selectList, orderPay, completer); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default Optional selectByPrimaryKey(Long id_) { + return selectOne(c -> + c.where(id, isEqualTo(id_)) + ); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default int update(UpdateDSLCompleter completer) { + return MyBatis3Utils.update(this::update, orderPay, completer); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + static UpdateDSL updateAllColumns(OrderPay record, UpdateDSL dsl) { + return dsl.set(id).equalTo(record::getId) + .set(outTradeNo).equalTo(record::getOutTradeNo) + .set(tradeNo).equalTo(record::getTradeNo) + .set(payChannel).equalTo(record::getPayChannel) + .set(totalAmount).equalTo(record::getTotalAmount) + .set(userId).equalTo(record::getUserId) + .set(payStatus).equalTo(record::getPayStatus) + .set(createTime).equalTo(record::getCreateTime) + .set(updateTime).equalTo(record::getUpdateTime); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + static UpdateDSL updateSelectiveColumns(OrderPay record, UpdateDSL dsl) { + return dsl.set(id).equalToWhenPresent(record::getId) + .set(outTradeNo).equalToWhenPresent(record::getOutTradeNo) + .set(tradeNo).equalToWhenPresent(record::getTradeNo) + .set(payChannel).equalToWhenPresent(record::getPayChannel) + .set(totalAmount).equalToWhenPresent(record::getTotalAmount) + .set(userId).equalToWhenPresent(record::getUserId) + .set(payStatus).equalToWhenPresent(record::getPayStatus) + .set(createTime).equalToWhenPresent(record::getCreateTime) + .set(updateTime).equalToWhenPresent(record::getUpdateTime); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default int updateByPrimaryKey(OrderPay record) { + return update(c -> + c.set(outTradeNo).equalTo(record::getOutTradeNo) + .set(tradeNo).equalTo(record::getTradeNo) + .set(payChannel).equalTo(record::getPayChannel) + .set(totalAmount).equalTo(record::getTotalAmount) + .set(userId).equalTo(record::getUserId) + .set(payStatus).equalTo(record::getPayStatus) + .set(createTime).equalTo(record::getCreateTime) + .set(updateTime).equalTo(record::getUpdateTime) + .where(id, isEqualTo(record::getId)) + ); + } + + @Generated("org.mybatis.generator.api.MyBatisGenerator") + default int updateByPrimaryKeySelective(OrderPay record) { + return update(c -> + c.set(outTradeNo).equalToWhenPresent(record::getOutTradeNo) + .set(tradeNo).equalToWhenPresent(record::getTradeNo) + .set(payChannel).equalToWhenPresent(record::getPayChannel) + .set(totalAmount).equalToWhenPresent(record::getTotalAmount) + .set(userId).equalToWhenPresent(record::getUserId) + .set(payStatus).equalToWhenPresent(record::getPayStatus) + .set(createTime).equalToWhenPresent(record::getCreateTime) + .set(updateTime).equalToWhenPresent(record::getUpdateTime) + .where(id, isEqualTo(record::getId)) + ); + } +} \ No newline at end of file diff --git a/novel-common/src/main/resources/application-common-dev.yml b/novel-common/src/main/resources/application-common-dev.yml index bd8a8cc..a2636a1 100644 --- a/novel-common/src/main/resources/application-common-dev.yml +++ b/novel-common/src/main/resources/application-common-dev.yml @@ -2,9 +2,9 @@ spring: profiles: include: [common] datasource: - url: jdbc:mysql://127.0.0.1:3306/novel_biz?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai + url: jdbc:mysql://127.0.0.1:3306/novel_plus?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai username: root - password: + password: test123456 driver-class-name: com.mysql.cj.jdbc.Driver diff --git a/novel-common/src/main/resources/mybatis/generatorConfig.xml b/novel-common/src/main/resources/mybatis/generatorConfig.xml index a7bbbce..b4015c0 100644 --- a/novel-common/src/main/resources/mybatis/generatorConfig.xml +++ b/novel-common/src/main/resources/mybatis/generatorConfig.xml @@ -8,8 +8,8 @@ - +
diff --git a/novel-front/pom.xml b/novel-front/pom.xml index 767e631..273d04e 100644 --- a/novel-front/pom.xml +++ b/novel-front/pom.xml @@ -26,6 +26,13 @@ jjwt${jjwt.version} + + + + com.alipay.sdk + alipay-sdk-java + 4.9.153.ALL + diff --git a/novel-front/src/main/java/com/java2nb/novel/controller/PayController.java b/novel-front/src/main/java/com/java2nb/novel/controller/PayController.java new file mode 100644 index 0000000..4fd2210 --- /dev/null +++ b/novel-front/src/main/java/com/java2nb/novel/controller/PayController.java @@ -0,0 +1,153 @@ +package com.java2nb.novel.controller; + +import com.alipay.api.AlipayClient; +import com.alipay.api.DefaultAlipayClient; +import com.alipay.api.internal.util.AlipaySignature; +import com.alipay.api.request.AlipayTradePagePayRequest; +import com.java2nb.novel.core.bean.UserDetails; +import com.java2nb.novel.core.config.AlipayConfig; +import com.java2nb.novel.service.OrderService; +import lombok.RequiredArgsConstructor; +import lombok.SneakyThrows; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Controller; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestMapping; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.PrintWriter; +import java.util.HashMap; +import java.util.Iterator; +import java.util.Map; + +/** + * @author 11797 + */ +@Controller +@RequestMapping("pay") +@RequiredArgsConstructor +@Slf4j +public class PayController extends BaseController { + + + private final AlipayConfig alipayConfig; + + private final OrderService orderService; + + + /** + * 支付宝支付 + */ + @SneakyThrows + @PostMapping("aliPay") + public void aliPay(Integer payAmount,HttpServletRequest request,HttpServletResponse httpResponse) { + + UserDetails userDetails = getUserDetails(request); + if (userDetails == null) { + //未登录,跳转到登陆页面 + httpResponse.sendRedirect("/user/login.html?originUrl=/pay/aliPay?payAmount="+payAmount); + return; + }else { + //创建充值订单 + Long outTradeNo = orderService.createPayOrder((byte)1,payAmount,userDetails.getId()); + + //获得初始化的AlipayClient + AlipayClient alipayClient = new DefaultAlipayClient(alipayConfig.getGatewayUrl(), alipayConfig.getAppId(), alipayConfig.getMerchantPrivateKey(), "json", alipayConfig.getCharset(), alipayConfig.getPublicKey(), alipayConfig.getSignType()); + //创建API对应的request + AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest(); + alipayRequest.setReturnUrl(alipayConfig.getReturnUrl()); + //在公共参数中设置回跳和通知地址 + alipayRequest.setNotifyUrl(alipayConfig.getNotifyUrl()); + //填充业务参数 + alipayRequest.setBizContent("{" + + " \"out_trade_no\":\"" + outTradeNo + "\"," + + " \"product_code\":\"FAST_INSTANT_TRADE_PAY\"," + + " \"total_amount\":" + payAmount + "," + + " \"subject\":\"小说精品屋-plus\"" + + " }"); + //调用SDK生成表单 + String form = alipayClient.pageExecute(alipayRequest).getBody(); + + httpResponse.setContentType("text/html;charset=utf-8"); + //直接将完整的表单html输出到页面 + httpResponse.getWriter().write(form); + httpResponse.getWriter().flush(); + httpResponse.getWriter().close(); + } + + + + + } + + /** + * 支付宝支付通知 + * */ + @SneakyThrows + @RequestMapping("aliPay/notify") + public void aliPayNotify(HttpServletRequest request,HttpServletResponse httpResponse){ + + + PrintWriter out = httpResponse.getWriter(); + + //获取支付宝POST过来反馈信息 + Map params = new HashMap(); + Map requestParams = request.getParameterMap(); + for (Iterator iter = requestParams.keySet().iterator(); iter.hasNext();) { + String name = (String) iter.next(); + String[] values = (String[]) requestParams.get(name); + String valueStr = ""; + for (int i = 0; i < values.length; i++) { + valueStr = (i == values.length - 1) ? valueStr + values[i] + : valueStr + values[i] + ","; + } + params.put(name, valueStr); + } + + //调用SDK验证签名 + boolean signVerified = AlipaySignature.rsaCheckV1(params, alipayConfig.getPublicKey(), alipayConfig.getCharset(), alipayConfig.getSignType()); + + //——请在这里编写您的程序(以下代码仅作参考)—— + + /* 实际验证过程建议商户务必添加以下校验: + 1、需要验证该通知数据中的out_trade_no是否为商户系统中创建的订单号, + 2、判断total_amount是否确实为该订单的实际金额(即商户订单创建时的金额), + 3、校验通知中的seller_id(或者seller_email) 是否为out_trade_no这笔单据的对应的操作方(有的时候,一个商户可能有多个seller_id/seller_email) + 4、验证app_id是否为该商户本身。 + */ + if(signVerified) { + //验证成功 + //商户订单号 + String outTradeNo = new String(request.getParameter("out_trade_no").getBytes("ISO-8859-1"),"UTF-8"); + + //支付宝交易号 + String tradeNo = new String(request.getParameter("trade_no").getBytes("ISO-8859-1"),"UTF-8"); + + //交易状态 + String tradeStatus = new String(request.getParameter("trade_status").getBytes("ISO-8859-1"),"UTF-8"); + + //更新订单状态 + orderService.updatePayOrder(Long.parseLong(outTradeNo), tradeNo, tradeStatus); + + + out.println("success"); + + }else {//验证失败 + out.println("fail"); + + //调试用,写文本函数记录程序运行情况是否正常 + //String sWord = AlipaySignature.getSignCheckContentV1(params); + //AlipayConfig.logResult(sWord); + } + + + + } + + + + + + +} diff --git a/novel-front/src/main/java/com/java2nb/novel/core/config/AlipayConfig.java b/novel-front/src/main/java/com/java2nb/novel/core/config/AlipayConfig.java new file mode 100644 index 0000000..0d31fa8 --- /dev/null +++ b/novel-front/src/main/java/com/java2nb/novel/core/config/AlipayConfig.java @@ -0,0 +1,23 @@ +package com.java2nb.novel.core.config; + +import lombok.Data; +import org.springframework.boot.context.properties.ConfigurationProperties; +import org.springframework.stereotype.Component; + +/** + * @author 11797 + */ +@Data +@Component +@ConfigurationProperties(prefix="alipay") +public class AlipayConfig { + + private String appId; + private String merchantPrivateKey; + private String publicKey; + private String notifyUrl; + private String returnUrl; + private String signType; + private String charset; + private String gatewayUrl; +} diff --git a/novel-front/src/main/java/com/java2nb/novel/service/OrderService.java b/novel-front/src/main/java/com/java2nb/novel/service/OrderService.java new file mode 100644 index 0000000..83d5109 --- /dev/null +++ b/novel-front/src/main/java/com/java2nb/novel/service/OrderService.java @@ -0,0 +1,29 @@ +package com.java2nb.novel.service; + + + +/** + * @author 11797 + */ +public interface OrderService { + + + /** + * 创建充值订单 + * + * @param payChannel 支付渠道 + * @param payAmount 支付金额 + * @param userId 用户ID + * @return 商户订单号 + * */ + Long createPayOrder(Byte payChannel, Integer payAmount, Long userId); + + + /** + * 更新订单状态 + * @param outTradeNo 商户订单号 + * @param tradeNo 支付宝/微信 订单号 + * @param tradeStatus 支付状态 + * */ + void updatePayOrder(Long outTradeNo, String tradeNo, String tradeStatus); +} diff --git a/novel-front/src/main/java/com/java2nb/novel/service/UserService.java b/novel-front/src/main/java/com/java2nb/novel/service/UserService.java index 0b3df2d..930c9ad 100644 --- a/novel-front/src/main/java/com/java2nb/novel/service/UserService.java +++ b/novel-front/src/main/java/com/java2nb/novel/service/UserService.java @@ -117,4 +117,9 @@ public interface UserService { void updatePassword(Long userId, String oldPassword, String newPassword); + /** + * 增加用户余额 + * @param userId 用户ID + * @param amount 增加的余额 */ + void addAmount(Long userId, int amount); } diff --git a/novel-front/src/main/java/com/java2nb/novel/service/impl/OrderServiceImpl.java b/novel-front/src/main/java/com/java2nb/novel/service/impl/OrderServiceImpl.java new file mode 100644 index 0000000..1ff25ee --- /dev/null +++ b/novel-front/src/main/java/com/java2nb/novel/service/impl/OrderServiceImpl.java @@ -0,0 +1,85 @@ +package com.java2nb.novel.service.impl; + +import com.java2nb.novel.entity.OrderPay; +import com.java2nb.novel.mapper.OrderPayDynamicSqlSupport; +import com.java2nb.novel.mapper.OrderPayMapper; +import com.java2nb.novel.service.OrderService; +import com.java2nb.novel.service.UserService; +import lombok.RequiredArgsConstructor; +import lombok.SneakyThrows; +import org.mybatis.dynamic.sql.render.RenderingStrategies; +import org.mybatis.dynamic.sql.select.render.SelectStatementProvider; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import java.text.SimpleDateFormat; +import java.util.Date; +import java.util.Random; + +import static org.mybatis.dynamic.sql.SqlBuilder.isEqualTo; +import static org.mybatis.dynamic.sql.select.SelectDSL.select; + +/** + * @author 11797 + */ +@Service +@RequiredArgsConstructor +public class OrderServiceImpl implements OrderService { + + private final OrderPayMapper orderPayMapper; + + private final UserService userService; + + + @SneakyThrows + @Override + public Long createPayOrder(Byte payChannel, Integer payAmount, Long userId) { + Date currentDate = new Date(); + Long outTradeNo = Long.parseLong(new SimpleDateFormat("yyyyMMddHHmmssSSS").format(currentDate)+new Random().nextInt(10)); + OrderPay orderPay = new OrderPay(); + orderPay.setOutTradeNo(outTradeNo); + orderPay.setPayChannel(payChannel); + orderPay.setTotalAmount(payAmount); + orderPay.setUserId(userId); + orderPay.setCreateTime(currentDate); + orderPay.setUpdateTime(currentDate); + orderPayMapper.insertSelective(orderPay); + return outTradeNo; + } + + @Transactional(rollbackFor = Exception.class) + @Override + public void updatePayOrder(Long outTradeNo, String tradeNo, String tradeStatus) { + SelectStatementProvider selectStatement = select(OrderPayDynamicSqlSupport.id,OrderPayDynamicSqlSupport.payStatus,OrderPayDynamicSqlSupport.totalAmount,OrderPayDynamicSqlSupport.userId) + .from(OrderPayDynamicSqlSupport.orderPay) + .where(OrderPayDynamicSqlSupport.outTradeNo, isEqualTo(outTradeNo)) + .build() + .render(RenderingStrategies.MYBATIS3); + + OrderPay orderPay = orderPayMapper.selectMany(selectStatement).get(0); + + if(orderPay.getPayStatus()!=1) { + //此订单还未处理过 + + if (tradeStatus.equals("TRADE_SUCCESS") || tradeStatus.equals("TRADE_FINISHED")) { + //支付成功 + //1.更新订单状态为成功 + orderPay.setPayStatus((byte) 1); + orderPay.setUpdateTime(new Date()); + orderPayMapper.updateByPrimaryKeySelective(orderPay); + + //2.增加用户余额 + userService.addAmount(orderPay.getUserId(),orderPay.getTotalAmount()*100); + + + + + + + } + } + + + + } +} diff --git a/novel-front/src/main/java/com/java2nb/novel/service/impl/UserServiceImpl.java b/novel-front/src/main/java/com/java2nb/novel/service/impl/UserServiceImpl.java index ed715fe..26cac3f 100644 --- a/novel-front/src/main/java/com/java2nb/novel/service/impl/UserServiceImpl.java +++ b/novel-front/src/main/java/com/java2nb/novel/service/impl/UserServiceImpl.java @@ -211,7 +211,7 @@ public class UserServiceImpl implements UserService { @Override public User userInfo(Long userId) { - SelectStatementProvider selectStatement = select(username, nickName, userPhoto,userSex) + SelectStatementProvider selectStatement = select(username, nickName, userPhoto,userSex,accountBalance) .from(user) .where(id, isEqualTo(userId)) .build() @@ -256,6 +256,15 @@ public class UserServiceImpl implements UserService { } + @Transactional(rollbackFor = Exception.class) + @Override + public void addAmount(Long userId, int amount) { + User user = this.userInfo(userId); + user.setId(userId); + user.setAccountBalance(user.getAccountBalance()+amount); + userMapper.updateByPrimaryKeySelective(user); + + } } diff --git a/novel-front/src/main/resources/application-alipay.yml b/novel-front/src/main/resources/application-alipay.yml new file mode 100644 index 0000000..e19affc --- /dev/null +++ b/novel-front/src/main/resources/application-alipay.yml @@ -0,0 +1,17 @@ +alipay: + #请填写您的AppId,例如:2019091767145019 + app-id: 2016101600696458 + #请填写您的应用私钥,例如:MIIEvQIBADANB + merchant-private-key: MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQCJrd9qg88m1p9c7IopcGlLksP9ts0eaf1wesgz4K3O6CzmgaCfR2f+scRI4xrMhKBHfzKDdKlW16LtrebD/YS/aDhRL9MM1GJ0Pr7zFdw6fIka9eIz1FojmmXNyaQVEbaGt/7DvoI+rJjjNtTQAYpMztHnof2W0Nfpra5U4dShJrzsvumS8NapEt9YgQ36jY9Z40RJ97Z06avmMGrAVlQSSTvUInTYz8EQmM3YN0ed3CmnlQFRhuW7kkbgBtZKjq+24iaU2mzp4qvWi5T89l3wuMahhxhFTgTNd24qxFuYShIdD0G3KCtunpwegomj1iQnF47qGv97UwOuA36b6l75AgMBAAECggEAJraZZ94AVa9ryDlK8DQHp5RxP9oy+yZaeVJNESlQNina1kYE4ES33UonI0eYtYFlgDUoAwa+xwiDa8nGZb3XoeqwS0PjWGwv8vfhwYCYGGoEM2yIWoKPhgtYLPFSDgqZBHCgVnIvNWha5Sj51jNYrBhLtZI7ODkpPS/1ITEPFPDds9LmH3Ujci20ttzr1SffKL/1caZ2Xph/Jkm2Xhh227cclORakDsggUmaxt723zibwFwpS6wwRlPJYf7hr3v3SnIgcc0osqKAcnJzrBlmaJVTBgnOAdulp+m/DjKVoIEieMr75OIYTWMRi0trlxAyvv4aDHxxJB6cDGNHFQLIMQKBgQD5j4fJDub2n9EjgxqYS9B6qa2pH5S9yypU+mM6fIXO/AjHpNwEzFQgU8lN3FE1CVfFb4yZx8sOJsQvZPGLvIhMPYT/2xMOIRL2IguJICt23Xnw+c1tNkvHvsHAiLvo/yzwSFixHcOaEwXDKUDsydPyalDFWBrwCGmGGxPEFG/Q/wKBgQCNO0+Muo+HzeUButDyA5gt9oPCX7uZ9g64rnFhuQXZ/eLDQeCW/lhjRiT2R+QafvbRyOYYomKZ6/1iQALY4tqQD7XMClRdu0OUvYR2WaNb9j4sWXl8qhMxgWjXssqorZRzNe+txicX8yOA5/ZVhhq647e2zt4kOS5H6Np0HvxYBwKBgQDvNfA+/cTPk4NhWdLNNqagXTJz0Sy+/BYYnGUu85tDOvyjeVfYVY8x6X4k3tEMWGdEfdc0tHjjmK8misipW8793V417WUHfxZwzVNnXmmrJ0IyhQ+u5oOe9C8+ARK1lJsbuw0gwNn0PtWgK1PrZM5/J/9CGmC/wiB8BkpdAgXoOwKBgE5fa3Wc0al7CGo9UVX7yKc49UUX+vMlKGYz55djJWwjB4NzOz6PRl1Qv5IrstlBO5aO9aEV+8GOw72R6AKTYNYw4aGo2chp8sbHpIpIk+6kZzwVKuWTO7NtLNEF1pBkQszsUWUNYQRZWIpgLsKm+I5db8VyZrOTR6t//DoUN9RhAoGAQLNaaULlw5L2Qsq9hbsdZVkbZN6YY4oiqMufmDKavbpUvchagFBe7/bneX4orza+DiC4vBFDIUOsZawB9eStx8hvL4AcuUF+eoZT3FCmvHB8dAYs4vok28f1nqUpYLmu4yN+wc/sLhihaJd7keErc987/E8mxW18AEin4Q4pKK8= + #支付宝公钥字符串 + public-key: MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAoR1gAyrjj/XugdKT3zUJBJksYnCXxD3RDiBex+JGfo6oO0oPbyoIQb2cAIIJjCCxT97QATlbYpRGMa+RuXxlxTeBh5ZFkELOsGc/UX0d9Tm51UvN+OV5pyysytlRdZfVgOETORzv9CvfnK7ND1SSHUPDan7TkMoVFipmQnf8205V3tcsDBat5kHEPFCmWXkPxrtLPVge1dAtKSRW9KFMslXkKrspvF1fSLGt12CE38ZwzP39INKgaI+RbIk3o7aRW5CrLqPkYdrgE1KcFBOj/gJXqbZvL/30q1KVn29UQUYm9SR/n6ZaLlAG38p4O3dL9Lu2lGhTBQlUr2qtpo+g8QIDAQAB + #填写您的支付类接口异步通知接收服务地址,例如:https://www:test:com/callback: + notify-url: http://50148a0b.ngrok.io/pay/aliPay/notify + #支付成功跳转页面 + return-url: http://127.0.0.1:8080/user/userinfo.html + #签名方式 + sign-type: RSA2 + #编码 + charset: utf-8 + #支付宝网关 + gateway-url: https://openapi.alipaydev.com/gateway.do diff --git a/novel-front/src/main/resources/application.yml b/novel-front/src/main/resources/application.yml index f8181f2..9ab7ea8 100644 --- a/novel-front/src/main/resources/application.yml +++ b/novel-front/src/main/resources/application.yml @@ -4,6 +4,7 @@ server: spring: profiles: active: dev + include: alipay jwt: secret: novel!#20191230 @@ -23,3 +24,6 @@ xss: excludes: /system/notice/* # 匹配链接 (多个用逗号分隔) urlPatterns: /book/addBookComment,/user/addFeedBack + + + diff --git a/novel-front/src/main/resources/static/images/pay_wx.png b/novel-front/src/main/resources/static/images/pay_wx.png new file mode 100644 index 0000000000000000000000000000000000000000..ed823d14b200977449bdf6a31eda8d36e13c6ef8 GIT binary patch literal 3669 zcmaJ^2|SePA0LvH#UeJ9V~h$h<}znSZjoVf-x_l;F*BMOW{6gfLdaE7QBtIkoaLz4 zN=PVKDY=S8IdjMUUv2GwKl|CwKA-n}pXc{Hzw`V2p5Obv@nl;|X~`XuAP`8}>VTO& z&{qIAK|&OGo>P3^26Wr`=B|7P4udbCaOogp8poFowqjBI==O99E%azJ-2epI6vK3M z<-3w>2viPBkFvp|Cu9Wy(jbt*eqj)W8bIfRed&HoHW4ya`v3xF(ufcjGzm@$GNt=7 z4}@{)4q>*A)UW_5o(9=(2sRKB00k^Mp8^)L0@*x*kO=vzmjH}6reP59R~CK%5%Q-~ zt|T(pl*6Ti(Rvst6@fs2v3NZM8izunb-_qD0u6)XVF)-Bjvyf51SA~%tw8{5TpEL5 zZ)Wk$7C;dp{(OEA0R|HY1bPCL9*64(L*Vgv7#s;hBB1~Wlo!h8Q-n}9Pvg4=GdhpT zWd`w?95#4EBgK~!%qKzsPyY;o6+|NarI^k81{44pOh^fWA@txd7HcD}uiQMoJ^lY~ z{3|!lF*Jw{v#0Yo!CWe^9}JD}!T@&vZD@lL@P=T=WdfT*2{hwSgIRPo-^z>#0ao;A zOd0`8!BY{wbSxBuK_Z~Oczp^KPsdQ9STqeqW1txrVE((Ff0H*xAPib zV~lYYXdKQIg~DSIrg*H`cUdbok56G!>ECTL0o&hX;r}U1Fy+!Id=A%;r)${jAK49fiFgJtG`R0jiVN$_)gi_?&&`HbveoD@&h@Yf~=;bGT#O_m3^S&VC+mvKX~@0O@snSu zv4UFE8&`{1xG-zyV_3KA49mqw9_@@Sl5V>YyT*#_#s~JqzoZCa*Y%ii*z8 z&fXZV=Jc!LxiPQQb#*^}S)P-(h>MSpPfliRE-xz!`P936!u<$~)mOpX>V198)74e@ zdx!cKmF^<9xs~~eK~ov{@Pxsrnhr$Vz=UL(WV(>{zJ|smP$f|)RMQ!?%Q-p8)ha3~ zc9#tw8&jzoZJA%bgj1>1Ez#HV^OIGH7Zmjoh{BSR<4eG8D|s&9|tyySs;l zg`GSDHrKv4zcO-6#uwf)KwoV=UOU(ud-7z>-Mfi9&@JulFa#o%EiWM^Cnx9k{8B^9 zts6JsSnO0lN=r-2ix>6*0TVhdC8Zb0D(wFIUiS8lQh?$e+qbXjMlJat*7V*gFQ1W- z@yJ7ybU~l`M5-p=KsXIzj{G*{yzX{!$q>J(^kv0d*P?sTyk(9utk_U`MZvxDc9e>| zeBmEHEAdidNa&4s(3RDLR_U@TK`UUl+G z!P3K|3lq6}{Hkn%h7CS^d|lq2L);g!Qc+iT%{_GL9WiB-!r0`bg^1`+KkK?0wJZO; zlD$t59v&VPzBEl4dr*2^;!?9N9{;+p&kMkHR^qAN!oq@<4w&uWkRFp(ke`1t`tj*) zzdU(=popZ!gr?5xDy4Jw1okbw`P5}-$rJE`m}LLgV+%PUbYhYZX&nm<)M-PwH zNAX)*&%-QfqtCN}7B>vKCsrw*_2BMZoSvRc+SQvkC7X1`!7P0&*0hYwQ6q+l$yhB_ z<>%*jIo4~Y1W&s;_C^*p2-1yYZkj~Ad%sk;q8SpeLS%0Fg((bmwS%3yi9Ccbz8TcL z=I-Xb?3I-=k#sX*7P>s?w5n5McPQY{aff$OPNt_<{62I!U?xIuQzT?W68OGvmHk#hdLi%*}jva*aa&d8~{y|&0e ze(v&o_I$tH0XVv^;ifq}ZaG`lvb$W=G24b?~#6`xkw7t&F? zO~W$z^YrwU49VE2s3=Xl9GgqH8HYDwJI%Nmm1pljID~%Bl7zQ}qaOL@=LCb*R-CkR zGv_~b&1GVqeBM^x;T?KosU30q>MDOL>udzt_|ve-@QY!ktZ2Gg6{ml4WaK0>(jW!~ z)zLx0;a5B;6f!%gJBN5IQ`NF8SnO3wN~T;Fns#Nl=?rf#8Fz%k;pEH2`o{k1UK_%) zwUxPLJyiV+$RS}`bPcspv@7~e4Cl$-8-MtRop`nDqg;+cOibO(kKM3(IGuE zGb3APYim2S*0BF~A4b~4#Y4`{-t}SV)5@Wtp$!cU+hE>b!1Rf9jZ+t*+^H@aIuh|= z!}IfJ3AfhUV_W8*xHPF#;xu<2_1}9W;fFi-qobmvq@~9KjZa(uoS2lP0fCg>?d1Kj zzQzw<|FS&Ps$g#2?UOV+I5rml86MEBtD&L6*qY{SZEfx9s)Ul55R;E9$O@esQQvaH zPwnU^RaS7IpwMPG@sH`DU2~s?^WQ#p^I<;~oISbyq2t-YA!CWy-d^`ObZ?VyTQMcl zdT+*q$lgfZj+ZZ~y(U=Dla>)t#ksXQ*r0gkZ_# ztmKO7>WddIn$iYv+S>8=cZ-NW%R-ILerSDD#hO?gHZd`od{_U*MJGX_wXY-cyhZlx z%#4Wo6?jW)>rbi%alI543%a(s;?AA;#KbRg%~aXuJICt+O2Kgsp?8UWbs1B#PQmvI zYpwDTF8=$D1f5lkY)<@xl{LMbG2!6kv>87>K7Pf7%qANi7O+^X>&uV!$3MJ>YACWE ziZm6e26J3WJmc{eJB&or$C{Fr5TZGC{e9)_WkpKKNPcJVV4%Fj=D`n?GUO(U-2Q9rPR!wcruXdG!|tn5oOsvQM?|9)@1L9-IsI8_<(CfhUF^Fh>o5N0Jsp z5cYmBuL~L!<@W;^Gc}`Dl6J=#_;`9s1xIzyPyDvJyu4Xl94Xj`E4X+4dhD-f-JWtzi_+QId2Deq)+vO~e}qk)&sE2FX5;alhEs6$9}X9?w{zAP z(RR+&{Awwo>`v0f2U(A`nh#FwA)5_&{!X$Q&v{(zQC(J6Hn3Cs!NB|Xj?T{F4Z_K{ z_${VhTXSK?E!Q>+&!wktLb|!TnqAqt1HKjV$6>F3PD#=Lcxd&w^h($$l*!&IC0tR8HZa&>lbae1!O)72$L zx_SF{`=!pPDA5sJdzsBT$3eWv7?Erdovx`Ni-_j7w%9z%g`S=sR|h%Vt_wy+tOdI) zBweeurGsc%QxLT1)A}o&K!4tYH}+AkRtiwJgg-0N{qfnTQLyE>v%rz}?&8_4Ye|jv z>uJ)%SiLUS0}TJA^t_Vt$)i*~nd1eRiKT6tMP0=MRNfBWdf%6#s`9GbTOy=!$?>q3 z6_it(O_PmU!%pLokvwW#i*;B;&B2_x)aL%$@tT&or$&D%aS#;*@{Z`r6@ZgYbZNe z$G)ZPs^9d!Z{P3xYf^|F{T(Bls2h1(+POLHjKofy8wIo^^=qozm zJ*6Ce<4E~?5-8LFfU=4|!NJKLO9VS&U2t9~!L8axK`;)3610FDNE;9|u&y}m03YnN z07Fx!0Cy)OMo{H4SlM5Z!oU+tbO8H%dU*LN`lAH@;;Tq`{|$x;g8xDxx}yaDR?5=A z7_5Q!!GhsZ@(?E&3vQl^-7bpygL_(!ypfWNL3I@dYmKV{%AL8XJ^oN5c z*4N1gMMIU+t>6K0Sh(3`r`e3oG9^d7WzX>@!kIx^c#_)jiQkcjuI3H4^6z2pC{If zsH2Gzq?|}$a2Q1e2c#3s5vu@^mzRM-9FcMk5F}RK38DbU$YPw~&hixaA3py^uO=&_ zDXS@qM9Qnlz+hVPY6vtOfzXhZMJm8FkP4cAXmz}Ni4I;)*gvvy6xsjKBK{|>qJ|IF zfr$4p#p6BxWP!0Oo{0B##S_398h=F{EM|f8!r)21;=jZ6x7C_hAKXnW2JM6Q1pnn{ zMclvWAd7W|Dac~s5Tt^3dh($Z&f2J?1pvSa)X`Kk^&eliVe;oBzsrJjV%!JQ^I0OP^UuWg zQ|Du^M1&Q26@^)!rEM$Re<~JWoGZZ`_AeyAqK2aO>fVk39?7BHtRn1#KPw2nLW5Kn@Mo;Lw;vRaOp==n1Z-I;bwXmNoeK;qiNT?xm zhGar=TY-0Z;+A5+JjlPY{6m*u_mQ6brEk%b8r*byL3W2dVg;kUzk+7`UpG}OK7Bnz zTD6Rr0qL#HMGL&TA}CVqai_AOp{`C}BCTBVllZGjt75OWKkhv`UpVAeJwayH($tLL zcf(wd8|#r~?e^BqHxb0`8O|t^u~>q{GDn*3*`c?xQ4Unh2{ejsEij?BH|NjY1m@aQ zOK5RWdx~6kG#yR8y2^OC!7oQ#aN)gtxU{!nQgHwIih{-Sd*@N_BKP3%cjRtccaNH} z(U;jrA6h?31%0VD@G~27;Z<1X-3@tzlXV92BP(tZEVHr{N}tw&hEr2gRSpP&Gj0j& zdLG4E^t9nGVR`i+ntRkquBu7s;c#uM_-?d(WqQ^?>;g6ZRVOCwtbgEaDY~$ptzmxy z`qp0!LD)_b2%31%ySQE?8T-^eaCw`f#jvJp>_j<-nY9fNDgXGaR{7DEpZ#lb$<$3ySncvg$vU*&^hLc@>unINI| zr%xXr*AqJu_*z?9yG!hr;KszNR3G9y(x<_hg@)xbJ3ve|e5-iph^X(jx>IdVON+?k z8Mm5k60k>_jB}J*z1VeyYH;i&l#o+7i0^jYN5ULKq)4Jt9n5t(oASZG7I{Zk-ZB`= z$ooy&eVJ=c4pd%S#WyxHi^WjShCP;AZXCiVK&b7a+M4qbktixm_2Q3z#z+E*&wmXf>pAprQg&?(koJ1n-LtdG4Y0+r6{ugP!@k-n=0GUx}wK$ ztkwEGu!?=d0jp|qnxNA>RyiHK&-YzS>>BAdsN-BZT*>5Y;)^0l)xji(Rzg_6t6T^G zaVtY=Am+z$^>)ro6#!WCab{+w>6Nd4WCWRUm_dLw5jgys+ZGeArrnimbRAC^WxDT4 zC(=pY$x{ozv%dsV*`&Yni;Cuv9@i3cUlvs2^soRYc_}kyZRofX+5mVgB)}*wdVdPo zPxTf+kJ)`?2DZs1pG2};G|Zx|8Yr=;C4I4DbE6rLh=^ha`&MQ=&ZlL*Uh)0xv*r-a z8r^)LJ;8FcQCLjWFU88WuX4LtMU-oWSGPud>8-zyk3~U*Dk_s}0Vvc~pW@!7Abrxl zu}u~DZ6DuARU(QN{*}&&uwGt>;oPL34%#(q&()yiKW%^T?%lhC%lihmmIV%6e|-r= zXE-A4tXZ#6#fQ+mDl809R_!3h#`vZ&bO%kb zYNf$j8`UfyGp`kfXWiNyi%At_d3cv>Niz2-8TAn1mf~ThXKkfRr}3kBfl85d|=A{KD(k5=akAq7$ZDqpnNGCPb?11NI zC%<}XSHY{Os8+XntK_7?NsfTPI&BP((IJ!4EGlT1oME`Q(Bw=UDJhumXw?m}wbj!4Si%n2MWZ%R6u7!6*EcA5Uq`U$#>|=>r(Ezb6y`m6 zzo6x3P7atv3dn@y20JcE+2}&;8m`*~FMeOSD}L?7w(89rE>)&S8qy`|R-r7R0cYiX zjk3qTue{)jYZGD`w5jzACXQDD=oz|3YFw3C=AJx0BhA3KUgKE(7UNdN+9s{p1-^z_ z&AOrM3A)SCnQ23K|MIF{2IP3=$G$`0#_CXxhy#1kgvT3rp}CpaR}np90XUICk)lp# zXDAzx8uF%`Gja9mu!bQa;r^!c>4fY^^_7SB37w(hR{2g38q1QA)>>0jNh+h=?NRN$ zk1tnSLAIV3%RM$=k2mNTwGS+0dP4l7K@MxUEa< z&Yn9rhWio4R@d;>ENp)2Q!Kfg&Yq1I<~T6dX77hb(WHxzcT^27y_78unaL5$SOg3< zA#A;7O0HgSt^m|)mwlF!$!B3xDji>&5j(U2I`w5KS(GH9^AEC^J#fL~Cl_SSZBDhCN7X)cVP1X6$`|-5U1CV~Ucg>x z!yuwK_2OXZ#JBUVmtW+N?9J*tgukmfqoa%m0U0chG%Rc~f3B4h(8gh;&zG|99VVMq znLVHz^DfMH7g5>j$#|^5f}q)-C?stGoPa1<#DfEzwJ`(T&DIvPN4U&;7SF7h#*^QV zr@qt;+XIT)KOD1hwy#MY`aU3YyukB9xv1KQpX&jeT-b+!TGgmdS4jwDs@i40BvWbD z&!TWhBZ`ezT6$%4;Mql^CkKZee2qU(K1JxHwyPinMCH?kJC#r>rRcZ!hInD{4C{O-EdfK8sIKI}o(G>%cgsRQLIYyHUm(|YE$Z_?d~2dX z_66w~`vbvtcbzUn-8*w7?KT!3+Nat_nn9oDT@wm($G+>*S45!`3}TY>6O;2Jbkwm1 zt^vjjb8Fs@Xs~-uL#7R(TJe&J?1Pb~+kd68urS-+2`VqUF#UqvGG0Iuh8VaK|5DU*6QrE8u<=^O_i`2$93*CSJ{AO~C3Dz;u^y;z1`a{JdADULB z^V)JVb|(fvfOyjVCzG|LJ98mFz3T(2lc1Cit(AH!z}rC}=Y7t|4T$-@sQq%ziv|gC zapCfv;^Bep@i8&iD~RIXOZ3s>>u)}M(B9|4`)eN57LN3viIk^{)>LPdV9fzM5!hya z$<}nL<8{F5L}OXpxEl~>8sKybf>PA4aCvexTOUO%;}xj+#hvME&vU^L^27Y;P8t=n zR$P)4&fain@QOr%B%fK4%c-adIrVz!gzpj#Q&Zn;RK=qq$@y?t1^2uTG@P@r&Eb|Z`li`OfU)6-thZWCDZHkZ zw}GK7WaM=k{gP2HXjeai76mu+ElI!7Sjh2NbPoROBbF#cAlk&bIT!gNR`1ZrZiM76 z(?^PxX~HiT#}N&UWORo-s;RcixU%0EzBu;kPEUS@-sMO1uLZ@Aa zZEPNz;j8KW#*rXPsy_$KH*VZWSl0Q zH_=dcoV)goJFnOZ?)KevdHqs;eimEPGNq}xkU+<|&^B$K*`&HLT|I)4yKvb*$7s4i z2t5_NWv(p{;u!7IX6C3*k~i3xqAS5 zo(Vel@*t)ub}bb!a^Edp39C4*I2luS$zeSCPvf~ zb@)i43JTcmQ})SCK9{)mL5|DFvtG|@_WQ06+f<3-VwSWQ%;MMb?1ql@bjug9`gGcO@-*qG5d z&zAnG)Op~Zni@FC0s=hZvgFe`!JO^;T9_BA6K-q0lQR8GCJ_|cNaw;58yhRu71U6} zLl{GewwG42)hKq%XXfMDhDCL#xca#VpQou(I_arJN$n@6<#Gcn?Yg^4^M0* z2{TE|wz3b0yvS7cbMyC)=%)AOsyuhJqp?F1*B0+|FmI$hd&o(ZI!62OgWGGkfN*;K z)oa&m7k??ZiEu;nejRo9&$e<)TGMuXsk`O768vjq&+|rx)a~9><#_s_y^4V)i`4x- z=_1SWrv_4!ml#znH7t%#VuxZ*eJ?R^4gXP(&F_i(vdEiGu1kT)z@yLh>;@THJ zO^nA!ge6Hqh>WS-;{yoRfz*+L zK-`;rJ77~A6%mC-qur{`$C!>QUCshOx@$fPx}P%G5O~}q5%%?LoK*lip`fMZr*{U= zROrDp2FnuzzsPbYE~|_)E2b1qhhgk|*7-iJwva_Oe(R8`pzPDW^LUwQ;+u`&f~)-> zLKsn|8oap8{oVyPb=0X1%; 0) { + $("#pValue").val($(this).attr("vals")); + $("#showTotal").html('¥' + $(this).attr("vals") + '元'); + for (var i = 0; i < UserPay.czData.length; i++) { + if (UserPay.czData[i][0] == $(this).attr("vals")) { + $("#showRemark").html(UserPay.czData[i][1]); + break; + } + } + } + }); + $("#ulPayPal li").click(function () { + $("#ulPayPal li").removeClass("on"); + $(this).addClass("on"); + if ($(this).attr("vals") > 0) { + $("#pValue").val($(this).attr("vals")); + $("#showPayPalTotal").html($(this).attr("vals") + '美元'); + for (var i = 0; i < UserPay.czData.length; i++) { + if (UserPay.czPayPalData[i][0] == $(this).attr("vals")) { + $("#showPayPalRemark").html(UserPay.czPayPalData[i][1]); + break; + } + } + } + }); +}); \ No newline at end of file diff --git a/novel-front/src/main/resources/templates/common/top.html b/novel-front/src/main/resources/templates/common/top.html index 163dd47..0b78dc1 100644 --- a/novel-front/src/main/resources/templates/common/top.html +++ b/novel-front/src/main/resources/templates/common/top.html @@ -42,7 +42,7 @@
  • 首页
  • 全部作品
  • 排行榜
  • -
  • 充值
  • +
  • 充值
  • 作家专区
  • diff --git a/novel-front/src/main/resources/templates/pay/index.html b/novel-front/src/main/resources/templates/pay/index.html new file mode 100644 index 0000000..91f3ec6 --- /dev/null +++ b/novel-front/src/main/resources/templates/pay/index.html @@ -0,0 +1,139 @@ + + + + + + + + + + + +
    +
    + +
    +
    + +
    + +
    +
    +
    + 充值账号:余额:0屋币 +
    + +
    +
    +
    选择充值方式
    +
      +
    • 支付宝支付
    • +
    • 微信支付
    • + +
    +
    选择充值金额
    +
      +
    • 10元1000屋币
    • +
    • 30元3000屋币
    • +
    • 50元5000屋币
    • +
    • 100元10000屋币
    • +
    • 200元20000屋币
    • +
    • 500元50000屋币
    • +
    + +
      +
    • 当前汇率:1元=100屋币
    • +
    • 总计金额:¥50元 获得 5000屋币
    • +
    • 立即支付
    • +
    + +
    +
    + 温馨提示 +
      +
    • 1. 充值阅读权限仅限本书城使用
    • +
    • 2. 充值支持信用卡、借记卡、支付宝余额、微信零钱等支付
    • +
    • 3. 包年时间是365天,重复购买时间会累加
    • +
    • 4. 若充值遇到问题,点此留言
    • +
    +
    +
    + +
    +
    + + + + +
    +
    +
    + + + + + + + \ No newline at end of file diff --git a/novel-front/src/main/resources/templates/user/userinfo.html b/novel-front/src/main/resources/templates/user/userinfo.html index 8fdb3b3..706c40d 100644 --- a/novel-front/src/main/resources/templates/user/userinfo.html +++ b/novel-front/src/main/resources/templates/user/userinfo.html @@ -30,7 +30,7 @@

    @@ -96,6 +96,8 @@ $("#my_name").html(data.data.username); } + $("#accountBalance").html(data.data.accountBalance); + } else if (data.code == 1001) { //未登录 location.href = '/user/login.html?originUrl=' + decodeURIComponent(location.href); diff --git a/novel.iml b/novel.iml deleted file mode 100644 index 3ac9e4e..0000000 --- a/novel.iml +++ /dev/null @@ -1,50 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/sql/20200511.sql b/sql/20200511.sql new file mode 100644 index 0000000..8eb12a3 --- /dev/null +++ b/sql/20200511.sql @@ -0,0 +1,33 @@ +/* +Navicat MySQL Data Transfer + +Source Server : localhost +Source Server Version : 50725 +Source Host : localhost:3306 +Source Database : novel_plus + +Target Server Type : MYSQL +Target Server Version : 50725 +File Encoding : 65001 + +Date: 2020-05-11 17:56:23 +*/ + +SET FOREIGN_KEY_CHECKS=0; + +-- ---------------------------- +-- Table structure for order_pay +-- ---------------------------- +DROP TABLE IF EXISTS `order_pay`; +CREATE TABLE `order_pay` ( + `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键', + `out_trade_no` bigint(20) NOT NULL COMMENT '商户订单号', + `trade_no` varchar(64) DEFAULT NULL COMMENT '支付宝/微信交易号', + `pay_channel` tinyint(1) NOT NULL DEFAULT '1' COMMENT '支付渠道,1:支付宝,2:微信', + `total_amount` int(11) NOT NULL COMMENT '交易金额(单位元)', + `user_id` bigint(20) NOT NULL COMMENT '支付用户ID', + `pay_status` tinyint(1) DEFAULT '2' COMMENT '支付状态:0:支付失败,1:支付成功,2:待支付', + `create_time` datetime DEFAULT NULL COMMENT '创建时间', + `update_time` datetime DEFAULT NULL COMMENT '更新时间', + PRIMARY KEY (`id`) +) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8mb4 COMMENT='充值订单';