言
本教程详细介绍了如何使用ssm框架实现支付宝支付功能。本文章分为两大部分,分别是「支付宝测试环境代码测试」和「将支付宝支付整合到ssm框架」,详细的代码和图文解释,自己实践的时候一定仔细阅读相关文档,话不多说我们开始。
支付宝测试环境代码测试
源代码
https://github.com/OUYANGSIHAI/sihai-maven-ssm-alipay
1.下载电脑网站的官方demo:
下载:https://docs.open.alipay.com/270/106291/
2.下载解压导入eclipse
readme.txt请好好看一下。
只有一个Java配置类,其余都是JSP。
3.配置AlipayConfig
(1) 注册蚂蚁金服开发者账号(免费,不像苹果会收取费用)
注册地址:https://open.alipay.com ,用你的支付宝账号扫码登录,完善个人信息,选择服务类型(我选的是自研)。
(2) 设置app_id和gatewayUrl
其中密钥需要自己生成,appID和支付宝网关是已经给好的,网关有dev字样,表明是用于开发测试。
(3) 设置密钥
点击“生成方法”,打开界面如下:
下周密钥生成工具,解压打开后,选择2048位生成密钥:
如果没有设置过,此时显示文本是"设置应用公钥",我这里是已经设置过得。
设置方法,"打开密钥文件路径":
复制应用公钥2048.txt中的内容到点击"设置应用公钥"的弹出框中,保存:
商户私钥(merchant_private_key)
复制 应用私钥2048.txt 中的内容到merchant_private_key中。
支付宝公钥(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.测试运行
测试用的支付宝买家账户可以在"沙箱账"这个页面可以找到:
支付成功后,验签结果:
问题解决
由于我们使用的是沙箱测试环境,测试环境和正式上线的环境的网关是不一样的,如果配置错误,会出现,appid错误的问题。配置如下:
源代码下载
链接: https://pan.baidu.com/s/1n6GbEJiMzoGWJrSw0bb2Cg 密码: zd9e
将支付宝支付整合到ssm框架
1、项目架构
项目架构:spring+springmvc+mybatis
数据库:mysql
部署环境:tomcat9.0
开发环境:jdk9、idea
支付:支付宝、微信
整合到ssm一样,我们需要像沙箱测试环境一样,需要修改支付的配置信息
2、数据库代码
主要包括以下的数据库表:
user:用户表 order:支付产生的订单 flow:流水账 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、dao数据接口层 这里就不介绍了,这个只包括简单的curd,可以使用`通用mapper`,或者`逆向工程`就行。以订单order为例给出: 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层 同上,最后在项目源代码里可见。以订单order为例给出: /** * 订单操作 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、支付宝支付controller(支付流程)
支付流程图
首先,启动项目后,输入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的工具)等信息生成订单,保存到数据库。
进入到选择支付页面
调用了如下代码:
然后,我们选择支付宝支付,进入到了我们支付的页面了,大功告成!
调用了如下代码:
/** * * @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; }
这段代码都可以在阿里支付的demo里面找到的,只需要复制过来,然后改改,整合到ssm环境即可。
上面就是将阿里支付宝支付整合到ssm的全过程了。
Spring是一个开源框架,它由Rod Johnson创建。它是为了解决企业应用开发的复杂性而创建的。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。
Spring框架自诞生以来一直备受开发者青睐,今天在这里分享的是一套Spring面试专题集合。其中包括了Spring、SpringBoot、SpringCloud、SpringMVC四个面试专题文档,都是经过BAT面试实战精选过的重点内容。
以下就是Spring全家桶了 有需要的Java开发员可以私信我
作者:Java成长路
链接:https://www.jianshu.com/p/3fb7dda153c4
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
们选择客户关系管理(CRM)应用做演示。 本文主要讲解低代码工具配置生成应用的主体流程,更多的细节需要参考文档。
先从大迈云官网下载安装低代码工具,地址www.mvcx.net/download.html。 当然你如果手边有其他的低代码工具,可以直接使用, 基础层面的功能相差不大。
分六个主要步骤完成配置:
1、配置数据表与字段
2、设置数据表关联
3、配置枚举项
4、配置用户角色
5、配置菜单及授权
6、配置可用页面
官方演示地址: https://center.mvcx.net/web/index.html#/apps/doc/128
一、配置数据表与字段
客户关系管理(CRM)中,我们选择具有代表性的多张数据表用作配置。 分别是客户/财务合同/产品/财务合同明细/回款明细/开票明细 , 每张表都配置了一系列字段。
数据表的细节参考官方演示的Excel表格。 按照Excel模板整理完多张表的字段,在后台一次性导入,创建数据结构。 一次性导入的目的,是为了项目有个整体的规划性,避免后面频繁修改数据表。后期可对数据结构(表与字段) 进行修改, 对单表增加字段,需要走完整的配置流程。 添加字段\字段授权\绑定字段到页面。
在创建数据结构的同时,我们可以选择同时创建默认操作页,包括表单页,列表查询页,展示页等, 自动化地完成基础CRUD功能。
二、设置数据表关联
在后台数据表->数据关联中设置表之间关系,等同于数据库外键。
财务合同 - N:1 - 客户
财务合同明细 - N:1 - 产品
财务合同明细 - N:1 - 财务合同
回款明细 - N:1 - 财务合同
开票明细 - N:1 - 财务合同
这里不涉及多对多的关系,相对简单。 设置完表关联后, 绝大多数的交叉调用, 都由系统自动来完成,包括多表查询,外键约束等。
三、配置枚举项
这里我们要用到枚举项有, 省份\公司类型\跟进状态\审核状态\合同类型\合同流程\合同进度\付款方式\产品状态\结算方式等。
在后台管理,基础数据中设置, 然后把枚举项绑定到对应字段,其他交给系统来完成。
四、配置用户角色
在后台管理->人员权限-> 角色权限里设置
企业管理系统,我们一般配置 user(普通用户), sales(销售) , manager(销售经理) , finance (财务) ,admin (系统管理员), hr(人力资源) 等。
后面我们会根据角色,给相应的人员授权不同功能。 角色不完全等同于公司里的职位, 很多时候一个人是身兼多个角色。
五、配置菜单及授权
在后台管理 -> 菜单页面 -> 可用菜单中操作
先创建一级菜单, 然后创建二级,三级菜单。 菜单配置路由,才能导航到特定页,配置路由的简单方式, 在菜单页面->可用页面中,点击(+菜单),就把当前页添加到了菜单项中,
对应的路由也已设置。 熟悉后可以手动设置路由项,开启更多功能。 在菜单设置中,为当前菜单设置父菜单,以及排序。
对菜单进行角色授权,允许那些角色看到或使用那些菜单。 实时配置的菜单会在用户第二次登陆后生效,或直接当前页刷新网页。菜单可以配置图标, 颜色。这里我们分别设置客户,合同,产品等相关菜单
六、配置可用页面
在创建数据表时,系统已经默认创建了单表的表单页,列表查询页,详情展示页等。 我们对系统生成的页面进行进一步配置,来完善功能。 很多时候配置是设定交叉表的字段引用,系统会自动生成
绝大多数代码。 各种页面也存在组合形式,当前演示中,财务合同表单,就是组合页面类型,附带子表合同明细。 页面需要授权,绑定到菜单才能正式使用。
系统内置了十多种通用的页面模型, 这些模型都来自于常规应用的抽象,通过配置页面就完成了终端用户可用的功能。 很多功能都是PC端、移动端一起生成的。
这里的配置有比较多的细节、参数要调整 ,可以参考官方文档,或者安装应用后,直接看成型的配置。
配置完成后的演示截图。
低代码工具生成表单
低代码工具生成列表
低代码工具生成移动端
如果你有1-2年的编程经验,可以很轻松地利用低代码工具搭建一个基础应用。
下面一个课时,我们将着重讲低代码编程的灵活性,怎样适应各种定制化的场景。 近几年来IT技术的发展,使得低代码编程能够覆盖更广的范围。
请关注我们的公z号: 大迈云, 可直接在大迈云官网mvcx.net下载低代码编程工具。
天小萌同学跟大家探讨一下PHP流行的开源商城平台-----
ecshop!
估计很多听过。
小萌同学其实是一个程序猿。
哈哈!很意外吧!(如果有项目想合作或外包的话,可以找我哦,嘻嘻!)
言归正传!
近期在做一个基于ecshop的商城项目,刚好有一个功能需要增加支付密码。
咋一看,好像挺简单的,但又有些不知从何入手,认真看了一个支付宝等插件的支付流程
发现支付插件类上都有get_code和respond两个方法,灵感来了,就用get_code返回一个支付密码支付的HTML代码,不就能实现。
在购物提交订单时,进入支付页面效果如下:
然后在user.php上加上act=balance_pay分支,验证支付密码,验证通过后扣减钱包余额。
这样就实现了钱包通过支付密码完成支付了。当然,还需要设置支付密码。
这个代码实现比较简单,小萌同学就不贴代码出来了。
技术分享就到这里,谢谢支持启萌分享!
贴后如果对本文章有疑问,又或者想合作、外包项目的,欢迎加小萌同学的微信besky987交流!
*请认真填写需求信息,我们会在24小时内与您取得联系。