`
dreamoftch
  • 浏览: 495534 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

支付宝接口 学习

阅读更多

http://yuanzhaoliyu-214.iteye.com/blog/392891

之前讲过与paypal在线支付的接口通信,paypal接口主要用于国际电子商务,而国内的电子商务,目前而言一般会考虑阿里巴巴的支付宝,下面将详细讲述如何在自己的系统中集成支付宝接口。

关于支付宝的一些信息可以直接访问支付宝网站https://www.alipay.com/。

国内电子商务系统实现的基本流程如下:
客户在系统内下订单 -> 系统根据订单生成支付宝接口url -> 客户通过url使用支付宝(网上银行)付款 -> 支付宝将客户的付款完成信息发送给电子商务系统 -> 系统收到支付宝信息后确定客户订单已经付款 -> 进行发货等后续流程。

其实这个流程与以前讲paypal接口的基本类似,都是为了实现订单的自动付款确认。

paypal与支付宝在使用时候有一点区别:paypal接口是直接通过一个form提交给paypal网站;而支付宝是通过一个url跳转到支付宝网站的。

在开始下面的内容之前,你要先有一个支付宝账户,如果要集成支付宝接口,你还必须申请开通服务(关于如何开通,可以直接到支付宝网站上申请).在服务开通后,支付宝会给你2个字符串编号:1个partnerId(合作伙伴ID),还有1个securityCode(安全码).当你拿到这2个码的时候就可以开始下面的内容了.

(1)如何调用支付宝接口?(将客户的订单信息按照既定的规则生成一个url跳转到支付宝网站)

通过下面方法[makeOrderAlipayUrl(HttpServletRequest httpRequest,Order order)]的调用得到支付宝的url,然后进行跳转(response.sendRedirect(url);).

Java代码
/**
     * 根据订单生成支付宝接口URL.
     * @param httpRequest
     * @param order 订单实例
     * @return
     * @throws Exception
     */
    public static String makeOrderAlipayUrl(HttpServletRequest httpRequest,Order order) throws Exception { 
        HashMap hm = new HashMap(); 
        hm.put("_input_charset",httpRequest.getCharacterEncoding());//采用相同的编码方式 
        hm.put("body","您在www.xxx.com上的订单");//填写在跳到支付宝页面上显示的付款内容信息 
        hm.put("discount","-5");//填写折扣信息 -5表示抵扣5元 
        hm.put("logistics_fee","10");//物流费用 
        hm.put("logistics_payment","BUYER_PAY");//物流费用支付人 BUYER_PAY=买家支付物流费用 
        hm.put("logistics_type","EXPRESS");//物流方式 
        hm.put("notify_url","http://www.xxx.com/notifyurl.jsp");//客户付款后,支付宝调用的页面 
        hm.put("out_trade_no",order.getId());//外部交易号,最好具有唯一性,在获取支付宝发来的付款信息时使用. 
        hm.put("partner",partnerId);//partnerId(合作伙伴ID) 
        hm.put("agent",partnerId);//partnerId(合作伙伴ID) 
        hm.put("payment_type","1");//支付类型 1=商品购买,2=服务购买,... 
        hm.put("price","105.30");//订单金额信息 
        hm.put("quantity","1");//订单商品数量,一般都是写1,它是按照整个订单包来计算 
        hm.put("return_url","http://www.xxx.com/ReturnUrl.jsp");//客户付款成功后,显示给客户的页面 
        hm.put("seller_email","alipay@xxx.com");//你的支付宝账户email 
        hm.put("service","create_direct_pay_by_user");//create_direct_pay_by_user=直接付款,trade_create_by_buyer 担保付款  
        hm.put("subject","www.xxx.com的订单");//填写在跳到支付宝页面上显示的付款标题信息 
        String payGateway = "https://www.alipay.com/cooperate/gateway.do?";//跳转到支付宝的url头 
        return makeUrl(hm,securityCode,httpRequest.getCharacterEncoding(),payGateway);//securityCode(安全码)  
    } 
     
     
    /**
     * 根据传入的参数生成alipay的支付URL
     * @param hm 参数值
     * @param securityCode 安全码
     * @param charset 编码
     * @param payGateway 支付宝gateway
     * @return
     */
    public static String makeUrl(HashMap hm,String securityCode,String charset,String payGateway) throws Exception{ 
        List keys = new ArrayList(hm.keySet()); 
        Collections.sort(keys);//支付宝要求参数必须按字母排序 
        StringBuffer content = new StringBuffer(); 
        for (int i = 0; i < keys.size(); i++) { 
            content.append((String) keys.get(i)); 
            content.append("="); 
            content.append((String) hm.get((String) keys.get(i))); 
            if (i != keys.size() - 1) { 
                content.append("&"); 
            } 
        } 
        content.append(securityCode); 
        String sign = md5(content.toString(),charset); 
        content.delete(0,content.length()); 
        content.append(payGateway); 
        for (int i = 0; i < keys.size(); i++) { 
            content.append(keys.get(i)); 
            content.append("="); 
            content.append(URLEncoder.encode((String) hm.get(keys.get(i)), charset)); 
            content.append("&"); 
        } 
        content.append("sign="); 
        content.append(sign); 
        content.append("&sign_type=MD5"); 
        keys.clear(); 
        keys = null; 
        return content.toString(); 
    } 
     
    /**
     * 生成md5编码字符串.
     * @param str 源字符串
     * @param charset 编码方式
     * @return
     *
     */
    public static String md5(String str,String charset) { 
        if (str == null) 
            return null; 
        char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 
                'a', 'b', 'c', 'd', 'e', 'f' }; 
         
        MessageDigest md5MessageDigest = null; 
        byte[] md5Bytes = null; 
        char md5Chars[] = null; 
        byte[] strBytes = null; 
        try { 
            strBytes = str.getBytes(charset); 
            md5MessageDigest = MessageDigest.getInstance("MD5"); 
            md5MessageDigest.update(strBytes); 
            md5Bytes = md5MessageDigest.digest(); 
            int j = md5Bytes.length; 
            md5Chars = new char[j * 2]; 
            int k = 0; 
            for (int i = 0; i < j; i++) { 
                byte md5Byte = md5Bytes[i]; 
                md5Chars[k++] = hexDigits[md5Byte >>> 4 & 0xf]; 
                md5Chars[k++] = hexDigits[md5Byte & 0xf]; 
            } 
            return new String(md5Chars); 
        } catch (NoSuchAlgorithmException e) { 
            //Log.output(e.toString(), Log.STD_ERR); 
            return null; 
        } catch (UnsupportedEncodingException e) { 
            //Log.output(e.toString(), Log.STD_ERR); 
            return null; 
        } finally { 
            md5MessageDigest = null; 
            strBytes = null; 
            md5Bytes = null; 
        } 
    }

/**
     * 根据订单生成支付宝接口URL.
     * @param httpRequest
     * @param order 订单实例
     * @return
     * @throws Exception
     */
    public static String makeOrderAlipayUrl(HttpServletRequest httpRequest,Order order) throws Exception {
        HashMap hm = new HashMap();
        hm.put("_input_charset",httpRequest.getCharacterEncoding());//采用相同的编码方式
        hm.put("body","您在www.xxx.com上的订单");//填写在跳到支付宝页面上显示的付款内容信息
        hm.put("discount","-5");//填写折扣信息 -5表示抵扣5元
        hm.put("logistics_fee","10");//物流费用
        hm.put("logistics_payment","BUYER_PAY");//物流费用支付人 BUYER_PAY=买家支付物流费用
        hm.put("logistics_type","EXPRESS");//物流方式
        hm.put("notify_url","http://www.xxx.com/notifyurl.jsp");//客户付款后,支付宝调用的页面
        hm.put("out_trade_no",order.getId());//外部交易号,最好具有唯一性,在获取支付宝发来的付款信息时使用.
        hm.put("partner",partnerId);//partnerId(合作伙伴ID)
        hm.put("agent",partnerId);//partnerId(合作伙伴ID)
        hm.put("payment_type","1");//支付类型 1=商品购买,2=服务购买,...
        hm.put("price","105.30");//订单金额信息
        hm.put("quantity","1");//订单商品数量,一般都是写1,它是按照整个订单包来计算
        hm.put("return_url","http://www.xxx.com/ReturnUrl.jsp");//客户付款成功后,显示给客户的页面
        hm.put("seller_email","alipay@xxx.com");//你的支付宝账户email
        hm.put("service","create_direct_pay_by_user");//create_direct_pay_by_user=直接付款,trade_create_by_buyer 担保付款
        hm.put("subject","www.xxx.com的订单");//填写在跳到支付宝页面上显示的付款标题信息
        String payGateway = "https://www.alipay.com/cooperate/gateway.do?";//跳转到支付宝的url头
        return makeUrl(hm,securityCode,httpRequest.getCharacterEncoding(),payGateway);//securityCode(安全码)
    }
  
  
    /**
     * 根据传入的参数生成alipay的支付URL
     * @param hm 参数值
     * @param securityCode 安全码
     * @param charset 编码
     * @param payGateway 支付宝gateway
     * @return
     */
    public static String makeUrl(HashMap hm,String securityCode,String charset,String payGateway) throws Exception{
        List keys = new ArrayList(hm.keySet());
        Collections.sort(keys);//支付宝要求参数必须按字母排序
        StringBuffer content = new StringBuffer();
        for (int i = 0; i < keys.size(); i++) {
            content.append((String) keys.get(i));
            content.append("=");
            content.append((String) hm.get((String) keys.get(i)));
            if (i != keys.size() - 1) {
                content.append("&");
            }
        }
        content.append(securityCode);
        String sign = md5(content.toString(),charset);
        content.delete(0,content.length());
        content.append(payGateway);
        for (int i = 0; i < keys.size(); i++) {
            content.append(keys.get(i));
            content.append("=");
            content.append(URLEncoder.encode((String) hm.get(keys.get(i)), charset));
            content.append("&");
        }
        content.append("sign=");
        content.append(sign);
        content.append("&sign_type=MD5");
        keys.clear();
        keys = null;
        return content.toString();
    }
  
    /**
     * 生成md5编码字符串.
     * @param str 源字符串
     * @param charset 编码方式
     * @return
     *
     */
    public static String md5(String str,String charset) {
        if (str == null)
            return null;
        char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
                'a', 'b', 'c', 'd', 'e', 'f' };
      
        MessageDigest md5MessageDigest = null;
        byte[] md5Bytes = null;
        char md5Chars[] = null;
        byte[] strBytes = null;
        try {
            strBytes = str.getBytes(charset);
            md5MessageDigest = MessageDigest.getInstance("MD5");
            md5MessageDigest.update(strBytes);
            md5Bytes = md5MessageDigest.digest();
            int j = md5Bytes.length;
            md5Chars = new char[j * 2];
            int k = 0;
            for (int i = 0; i < j; i++) {
                byte md5Byte = md5Bytes[i];
                md5Chars[k++] = hexDigits[md5Byte >>> 4 & 0xf];
                md5Chars[k++] = hexDigits[md5Byte & 0xf];
            }
            return new String(md5Chars);
        } catch (NoSuchAlgorithmException e) {
            //Log.output(e.toString(), Log.STD_ERR);
            return null;
        } catch (UnsupportedEncodingException e) {
            //Log.output(e.toString(), Log.STD_ERR);
            return null;
        } finally {
            md5MessageDigest = null;
            strBytes = null;
            md5Bytes = null;
        }
    }


当客户通过接口url付款后,支付宝会自动的去调用前面提供的[notify_url]参数中的url.

(2)支付宝将付款信息返回给系统
当客户付款后,支付宝就会自动调用上面表单提供的[notify_url],下面是一个[notifyurl.jsp]的一个例子:
Html代码
<%@ page contentType="text/html;charset=UTF-8"%><%@ page import="com.soft4j.AlipayMgr"%><% 
    String ret = AlipayMgr.insert(request); 
    if(ret==null){ 
        out.print("success");//成功接收支付宝发来的付款信息 
    }else{ 
        out.print("fail");//出错 
    } 
%>

<%@ page contentType="text/html;charset=UTF-8"%><%@ page import="com.soft4j.AlipayMgr"%><%
String ret = AlipayMgr.insert(request);
if(ret==null){
out.print("success");//成功接收支付宝发来的付款信息
}else{
out.print("fail");//出错
}
%>

如果确认收到支付宝发来的客户付款信息,则返回"success",这样子支付宝就知道系统已经收到信息了;否则返回"fail",这样支付宝会过一段时间后再次发来。其实,只有当支付宝收到"success"的返回信息后才会停止发送付款信息,否则会自动的每隔一段时间就调用上面
的[notify_url]通信接口。

(3)系统处理支付宝发来的付款信息

Java代码
/*
* Created on 2005-6-12
* Author stephen
* Email zhoujianqiang AT gmail DOT com
* CopyRight(C)2005-2008 , All rights reserved.
*/
package com.soft4j; 

import java.sql.Connection; 
import java.sql.SQLException; 
import java.util.Enumeration; 
import java.util.Vector; 
import javax.servlet.http.HttpServletRequest; 

/**
* 支付宝付款通知接口.

* @author stephen
* @version 1.0.0
*/
public final class NotifyUrlMgr { 
     
     
    public static String insert(HttpServletRequest httpRequest) { 
         
        //定义变量和进行必要的初始化工作 
        Enumeration parameterNames = null; 
        String parameterName = null; 
        String parameterValue = null; 
        int count = 0; 
        Vector[] params = null; 
        Vector vParameterName = new Vector(); 
        Vector vParameterValue = new Vector(); 
         
        try { 
            String orderId = httpRequest.getParameter("out_trade_no");//订单号 
            if(orderId==null||"".equals(orderId)) orderId="-1"; 
            parameterNames = httpRequest.getParameterNames(); 
            boolean isPrint = false; 
            while (parameterNames.hasMoreElements()) {//循环收取支付宝发来的所有参数信息 
                parameterName = (String) parameterNames.nextElement(); 
                parameterValue = httpRequest.getParameter(parameterName); 
                if(parameterValue==null) parameterValue=""; 
                vParameterName.add(parameterName); 
                vParameterValue.add(parameterValue); 
                count++; 
            } 
             
            //这里添加对收到信息的处理:一般是将这些信息存入数据库,然后对客户的订单进行处理. 
             
            return null; 
        } catch (Exception e) { 
            return e.toString(); 
        } finally { 
            // 
        } 
    } 

}

/*
* Created on 2005-6-12
* Author stephen
* Email zhoujianqiang AT gmail DOT com
* CopyRight(C)2005-2008 , All rights reserved.
*/
package com.soft4j;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.Enumeration;
import java.util.Vector;
import javax.servlet.http.HttpServletRequest;

/**
* 支付宝付款通知接口.
*
* @author stephen
* @version 1.0.0
*/
public final class NotifyUrlMgr {


    public static String insert(HttpServletRequest httpRequest) {
      
        //定义变量和进行必要的初始化工作
        Enumeration parameterNames = null;
        String parameterName = null;
        String parameterValue = null;
        int count = 0;
        Vector[] params = null;
        Vector vParameterName = new Vector();
        Vector vParameterValue = new Vector();
      
        try {
            String orderId = httpRequest.getParameter("out_trade_no");//订单号
            if(orderId==null||"".equals(orderId)) orderId="-1";
            parameterNames = httpRequest.getParameterNames();
            boolean isPrint = false;
            while (parameterNames.hasMoreElements()) {//循环收取支付宝发来的所有参数信息
                parameterName = (String) parameterNames.nextElement();
                parameterValue = httpRequest.getParameter(parameterName);
                if(parameterValue==null) parameterValue="";
                vParameterName.add(parameterName);
                vParameterValue.add(parameterValue);
                count++;
            }
          
            //这里添加对收到信息的处理:一般是将这些信息存入数据库,然后对客户的订单进行处理.
          
            return null;
        } catch (Exception e) {
            return e.toString();
        } finally {
            //
        }
    }

}



这样系统可以在客户使用支付宝付款后,自动的根据支付宝发来的付款信息确认客户的付款情况,并进行相应的后续操作.

分享到:
评论

相关推荐

    支付宝接口支付宝接口源代码

    支付宝接口是支付宝为开发者提供的一系列API,用于集成支付宝支付、账户管理、营销活动等多种功能。这些源代码通常包括...对于初学者,可以通过官方文档、开发指南以及社区资源来学习和掌握支付宝接口的使用技巧。

    支付宝接口开发案例

    支付宝接口开发是现代电商、移动应用以及各类在线服务不可或缺的一部分,它使得商家能够...通过学习官方文档、实践操作案例和理解开发源码,开发者可以逐步掌握并熟练运用支付宝接口,为用户提供安全、便捷的支付体验。

    C#.net 支付宝接口

    在IT行业中,支付宝接口是支付服务提供商为开发者提供的API,用于在各种应用程序中集成支付宝支付功能。本项目专注于使用C#.net编程语言实现这一接口,从而使得开发者能够为他们的.NET平台应用添加支付宝支付的支持...

    支付宝接口对接流程

    ### 支付宝接口对接流程详解 在当前数字化经济的大背景下,支付接口的对接成为许多企业和商家必须掌握的一项技能。本文将详细介绍一个餐饮系统与支付宝API接口对接的具体步骤及注意事项,帮助读者更好地理解和掌握...

    thinkPHP仿华为商城带支付宝接口.zip

    虽然该项目的代码年代较早,对于支付宝接口的部分可能已过时,但其核心思路和设计模式依然具有学习价值。 一、ThinkPHP框架介绍 ThinkPHP是一款国内广泛使用的开源PHP框架,它采用了MVC(Model-View-Controller)...

    支付宝接口集成指南。

    支付宝接口集成指南是针对开发者和网站运营者提供的一份详细文档,旨在帮助他们将支付宝的支付功能无缝地整合到自己的网站或应用中。这涉及到一系列的技术步骤和注意事项,旨在确保安全、高效的在线交易流程。 首先...

    php支付宝接口开发

    在PHP中进行支付宝接口开发是为了实现在线支付和资金管理功能,这通常涉及到多个接口的集成。...通过以上知识点的学习和实践,开发者可以熟练地在PHP环境中集成支付宝接口,实现充值、退款和发货等电商关键功能。

    支付宝接口大全 ASP版

    总之,支付宝接口大全 ASP版为ASP开发者提供了全面的支付宝支付功能实现示例,通过学习和理解这些示例,开发者能够更好地集成支付宝支付功能到自己的网站或应用中,提供安全、便捷的在线支付体验。

    淘宝支付宝接口程序/支付宝接口代码/php

    在IT行业中,支付宝接口程序和相关的PHP代码是电商网站与支付宝进行支付交互的关键技术。...通过不断学习和实践,开发者可以熟练地使用PHP来构建与淘宝支付宝接口的无缝对接,提升电商平台的支付效率和用户体验。

    asp.net实现的支付宝接口

    在本项目中,"asp.net 2.0实现的支付宝接口"是核心内容,我们可以从以下几个方面来理解和学习相关知识点: 1. **支付宝开放平台文档**: 在实现支付宝接口前,开发者需要熟悉支付宝开放平台提供的官方文档。这些...

    支付宝接口开发源代码可直接运行测试效果

    支付宝接口开发是现代电子商务系统中的重要组成部分,它允许商家与支付宝平台进行交互,实现支付、退款、查询交易状态等功能。本资源提供了一套可以直接运行的支付宝接口开发源代码,名为"alipaydemo",这对于开发者...

    支付宝接口开发asp代码

    支付宝接口开发ASP代码是针对使用Active Server Pages (ASP)技术构建支付...通过以上这些知识点的学习和实践,开发者可以使用ASP来搭建一个能够与支付宝接口无缝对接的支付系统,从而为用户提供便捷的在线支付服务。

    支付宝沙箱接口调用

    通过学习和实践这些内容,开发者可以熟悉支付宝接口的使用,确保在正式上线前,应用能够正确无误地处理各种交易场景。在开发过程中,建议频繁使用沙箱环境进行测试,以减少上线后的故障率。同时,积极与其他开发者...

    springboot+vue+对接支付宝接口+二维码扫描支付功能(沙箱环境)

    然后对于编程爱好者而言,想学习这一点就有点难,因为要想使用支付宝接口,必须前提是使用软件应用程序,软件应用程序需要向支付宝申请,提交一系列资料,这一点是实现不了的。这就对开发者增加了一定的难度,因为...

    支付宝支付接口DEMO

    1. **支付宝接口介绍**: 支付宝提供了一系列的API接口,让开发者能够在自己的应用或网站上实现支付功能。这些接口通常包括但不限于订单创建、支付请求、支付结果查询、退款处理等关键步骤。 2. **iOS集成**: ...

    jsp支付宝接口源码

    通过深入学习和理解这个JSP支付宝接口源码,开发者可以掌握如何在自己的项目中实现支付宝支付功能,从而提高用户体验,促进交易顺利完成。同时,这也是学习Java Web开发和第三方支付集成的一个实用案例。

    支付宝网银等支付接口

    支付宝接口技术文档通常包含了开发者需要的所有信息,如API调用规范、请求参数、响应格式、签名机制以及错误代码等。开发人员需要按照文档中的指引,将支付宝提供的SDK集成到自己的系统中,以便处理支付请求、查询...

    支付宝批量付款到支付宝账号接口集成教程_java版本

    支付宝接口调用时,必须对请求参数进行签名,以确保数据安全。通常使用RSA或MD5算法进行签名。你需要按照文档提供的方法生成私钥和公钥,并在调用接口时使用私钥对请求参数签名,而支付宝则使用公钥验证响应的签名...

    支付宝 双接口 示例 文档

    5. **回调处理**:支付宝接口在处理完请求后,会发送一个通知(Notify)到商户设定的回调URL。开发者需要实现这个URL上的处理逻辑,如确认支付成功后更新订单状态,处理退款结果等。 6. **SDK使用**:为了简化开发...

    PHP支付宝各种接口教程与示例

    当涉及到在线支付系统时,PHP与支付宝接口的整合...通过学习和实践这些教程,PHP开发者可以掌握支付宝接口的使用,从而为网站或应用程序添加安全可靠的支付功能。这不仅可以提升用户体验,也有助于商业运营的顺利进行。

Global site tag (gtag.js) - Google Analytics