Spring MVC+Spring+Mybatis реализует платежную функцию Alipay (подробное изображение и текст)

Java Spring MyBatis Alipay

предисловие

В этом руководстве подробно рассказывается, как использовать структуру ssm для реализации платежной функции Alipay. Эта статья разделена на две части, а именно «Тест кода тестовой среды Alipay» и «Интеграция оплаты Alipay в структуру ssm», с подробным кодом и графическими пояснениями, вы должны внимательно прочитать соответствующие документы, когда будете практиковаться, нечего сказать, давайте начинать.

Проверка кода тестовой среды Alipay

исходный код

https://github.com/OUYANGSIHAI/sihai-maven-ssm-alipay

1. Загрузите официальную демоверсию компьютера с сайта:

Скачать: https://docs.open.alipay.com/270/106291/

2. Скачать, разархивировать и импортировать в eclipse

Пожалуйста, внимательно просмотрите файл readme.txt.

Существует только один класс конфигурации Java, остальные — JSP.

3. Настройте алипайконфиг

(1) Зарегистрируйте учетную запись разработчика Ant Financial (бесплатно, в отличие от Apple, которая взимает плату)

Адрес регистрации: https://open.alipay.com, используйте свою учетную запись Alipay, чтобы отсканировать код для входа в систему, заполнить личную информацию и выбрать тип услуги (я выбрал самостоятельную разработку).

(2) Установите app_id и gatewayUrl

Ключ необходимо сгенерировать самостоятельно, appID и шлюз Alipay уже заданы, а на шлюзе стоит слово dev, что говорит о том, что он используется для разработки и тестирования.

(3) Установите ключ

Нажмите «Создать метод», чтобы открыть интерфейс следующим образом:

Инструмент генерации ключей на следующей неделе, после распаковки и открытия, выберите 2048-битный ключ генерации:

Если он не был установлен, в это время отображается текст «Установите открытый ключ приложения», я уже установил его здесь.

Метод настройки «Путь к файлу открытого ключа»:

Скопируйте содержимое открытого ключа приложения 2048.txt во всплывающее окно, нажав «Установить открытый ключ приложения», и сохраните:

  • Закрытый ключ продавца (merchant_private_key)

    Скопируйте содержимое закрытого ключа приложения 2048.txt в файлmerchant_private_key.

  • Открытый ключ Alipay (alipay_public_key)

Нажмите на ссылку выше и скопируйте содержимое всплывающего окна в alipay_public_key.

Если эта настройка неверна, результат будет таким: платеж прошел успешно, но проверка подписи не удалась.

Если это формальная среда, ее необходимо загрузить в соответствующее приложение:

(4) Сервер асинхронно уведомляет путь к странице (notify_url)

Если вы не меняете имя, вы можете просто изменить IP и номер порта.Мой собственный выглядит следующим образом:

http://localhost:8080/alipay.trade.page.pay-JAVA-UTF-8/notify_url.jsp

(5) Путь страницы уведомления о синхронизации перехода к странице (return_url)

http://localhost:8080/alipay.trade.page.pay-JAVA-UTF-8/return_url.jsp

4. Пробный запуск

Учетную запись покупателя Alipay, используемую для тестирования, можно найти на странице «Учетная запись песочницы»:

После успешной оплаты результат проверки подписи:

проблема решена

Поскольку мы используем тестовую среду песочницы, тестовую среду и официально запущенную средушлюзЭто не то же самое, если конфигурация неверна, будет проблема с неправильным приложением. Конфигурация выглядит следующим образом:

Загрузка исходного кода

链接: https://pan.baidu.com/s/1n6GbEJiMzoGWJrSw0bb2Cg 密码: zd9eскопировать код

Интеграция оплаты Alipay в структуру ssm

1. Структура проекта

  • Архитектура проекта: spring+springmvc+mybatis

  • База данных: mysql

  • Среда развертывания: tomcat9.0

  • Среда разработки: jdk9, идея

  • Оплата: Alipay, WeChat.

Как и SSM, нам нужно модифицировать как тестовую среду песочницы.Платежная информация

2. Код базы данных

В основном он включает в себя следующие таблицы базы данных:

  • пользователь: пользовательская таблица

  • заказ: заказ, созданный платежом

  • поток: текущая учетная запись

  • product: Товарная таблица: используется для имитации покупки товаров.

drop table if exists user;/*==============================================================*//* Table: user                                                  *//*==============================================================*/create table user(   id                   varchar(20) not null,   username             varchar(128),   sex                  varchar(20),   primary key (id));alter table user comment '用户表';CREATE TABLE `flow` (  `id` varchar(20) NOT NULL,  `flow_num` varchar(20) DEFAULT NULL COMMENT '流水号',  `order_num` varchar(20) DEFAULT NULL COMMENT '订单号',  `product_id` varchar(20) DEFAULT NULL COMMENT '产品主键ID',  `paid_amount` varchar(11) DEFAULT NULL COMMENT '支付金额',  `paid_method` int(11) DEFAULT NULL COMMENT '支付方式\r\n            1:支付宝\r\n            2:微信',  `buy_counts` int(11) DEFAULT NULL COMMENT '购买个数',  `create_time` datetime DEFAULT NULL COMMENT '创建时间',  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='流水表';CREATE TABLE `orders` (  `id` varchar(20) NOT NULL,  `order_num` varchar(20) DEFAULT NULL COMMENT '订单号',  `order_status` varchar(20) DEFAULT NULL COMMENT '订单状态\r\n            10:待付款\r\n            20:已付款',  `order_amount` varchar(11) DEFAULT NULL COMMENT '订单金额',  `paid_amount` varchar(11) DEFAULT NULL COMMENT '实际支付金额',  `product_id` varchar(20) DEFAULT NULL COMMENT '产品表外键ID',  `buy_counts` int(11) DEFAULT NULL COMMENT '产品购买的个数',  `create_time` datetime DEFAULT NULL COMMENT '订单创建时间',  `paid_time` datetime DEFAULT NULL COMMENT '支付时间',  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='订单表';CREATE TABLE `product` (  `id` varchar(20) NOT NULL,  `name` varchar(20) DEFAULT NULL COMMENT '产品名称',  `price` varchar(11) DEFAULT NULL COMMENT '价格',  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='产品表 ';

3. Уровень интерфейса данных Дао

Я не буду вводить его здесь, это включает в себя только простой творог, вы можете использовать «общий маппер» или «реверс-инжиниринг». Возьмите порядок заказа в качестве примера, чтобы дать:

public interface OrdersMapper {    int countByExample(OrdersExample example);    int deleteByExample(OrdersExample example);    int deleteByPrimaryKey(String id);    int insert(Orders record);    int insertSelective(Orders record);    List<Orders> selectByExample(OrdersExample example);    Orders selectByPrimaryKey(String id);    int updateByExampleSelective(@Param("record") Orders record, @Param("example") OrdersExample example);    int updateByExample(@Param("record") Orders record, @Param("example") OrdersExample example);    int updateByPrimaryKeySelective(Orders record);    int updateByPrimaryKey(Orders record);}

Примечание: исходный код приведен в конце

4. Сервисный уровень

То же самое, наконец, видно в исходном коде проекта. Возьмите порядок заказа в качестве примера, чтобы дать:

/** * 订单操作 service * @author ibm * */public interface OrdersService {    /**     * 新增订单     * @param order     */    public void saveOrder(Orders order);    /**     *      * @Title: OrdersService.java     * @Package com.sihai.service     * @Description: 修改叮当状态,改为 支付成功,已付款; 同时新增支付流水     * Copyright: Copyright (c) 2017     * Company:FURUIBOKE.SCIENCE.AND.TECHNOLOGY     *      * @author sihai     * @date 2017年8月23日 下午9:04:35     * @version V1.0     */    public void updateOrderStatus(String orderId, String alpayFlowNum, String paidAmount);    /**     * 获取订单     * @param orderId     * @return     */    public Orders getOrderById(String orderId);}

4. Платежный контроллер Alipay (процесс оплаты)

Схема оплаты

Во-первых, после запуска проекта введите http://localhost:8080/, вы попадете на страницу продукта следующим образом:

Ниже код страницы

Страница продукта (products.jsp)

Код:

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %><%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>  <script src="<%=request.getContextPath() %>/static/js/jquery.min.js" type="text/javascript"></script><html>    <head>    </head>    <body>        <table>            <tr>                <td>                    产品编号                </td>                <td>                    产品名称                </td>                <td>                    产品价格                </td>                <td>                    操作                </td>            </tr>            <c:forEach items="${pList }" var="p">                <tr>                    <td>                        ${p.id }                    </td>                    <td>                        ${p.name }                    </td>                    <td>                        ${p.price }                    </td>                    <td>                        <a href="<%=request.getContextPath() %>/alipay/goConfirm.action?productId=${p.id }">购买</a>                    </td>                </tr>            </c:forEach>        </table>        <input type="hidden" id="hdnContextPath" name="hdnContextPath" value="<%=request.getContextPath() %>"/>    </body></html><script type="text/javascript">    $(document).ready(function() {        var hdnContextPath = $("#hdnContextPath").val();    });</script>

нажмите вышеКупить,Входитьзаказать страницу

Введите номер, а затем нажмите «Создать заказ», чтобы вызвать следующий код.

в соответствии сSID(инструмент для генерации id) и другую информацию для формирования заказа и сохранения его в базе данных.

Перейти на страницу выбора оплаты

Вызывается следующий код:

Затем мы выбираем Alipay, чтобы оплатить и ввести нашу страницу оплаты, и вы закончите!

Вызывается следующий код:

/**     *     * @Title: AlipayController.java     * @Package com.sihai.controller     * @Description: 前往支付宝第三方网关进行支付     * Copyright: Copyright (c) 2017     * Company:FURUIBOKE.SCIENCE.AND.TECHNOLOGY     *     * @author sihai     * @date 2017年8月23日 下午8:50:43     * @version V1.0     */    @RequestMapping(value = "/goAlipay", produces = "text/html; charset=UTF-8")    @ResponseBody    public String goAlipay(String orderId, HttpServletRequest request, HttpServletRequest response) throws Exception {        Orders order = orderService.getOrderById(orderId);        Product product = productService.getProductById(order.getProductId());        //获得初始化的AlipayClient        AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);        //设置请求参数        AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();        alipayRequest.setReturnUrl(AlipayConfig.return_url);        alipayRequest.setNotifyUrl(AlipayConfig.notify_url);        //商户订单号,商户网站订单系统中唯一订单号,必填        String out_trade_no = orderId;        //付款金额,必填        String total_amount = order.getOrderAmount();        //订单名称,必填        String subject = product.getName();        //商品描述,可空        String body = "用户订购商品个数:" + order.getBuyCounts();        // 该笔订单允许的最晚付款时间,逾期将关闭交易。取值范围:1m~15d。m-分钟,h-小时,d-天,1c-当天(1c-当天的情况下,无论交易何时创建,都在0点关闭)。 该参数数值不接受小数点, 如 1.5h,可转换为 90m。        String timeout_express = "1c";        alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","                + "\"total_amount\":\""+ total_amount +"\","                + "\"subject\":\""+ subject +"\","                + "\"body\":\""+ body +"\","                + "\"timeout_express\":\""+ timeout_express +"\","                + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");        //请求        String result = alipayClient.pageExecute(alipayRequest).getBody();        return result;    }

Этот код можно найти в демо-версии Alipay, просто скопируйте его, затем измените и интегрируйте в среду ssm.

Выше весь процесс интеграции платежа Alipay в ssm.Если у вас есть какие-либо вопросы, вы можете обратить внимание на паблик WeChat: «Изучайте java хорошо» и проконсультируйтесь с редактором.

Рекомендуемое чтение:

Почему передний и задний концы должны быть разделены?

Подробное объяснение кодов состояния протокола HTTP

Что такое междоменный домен? Каковы решения?

Краткое руководство по реализации интерфейса RESTful