asp 支付宝 企业版 接口 支持网银接口 ,网银直接支付 只是多了一个defalutbank的参数。具体看
open.alipay.com
<%
' 类名:AlipaySubmit
' 功能:支付宝各接口请求提交类
' 详细:构造支付宝各接口表单HTML文本,获取远程HTTP数据
' 版本:3.3
' 修改日期:2012-07-13
' 说明:
' 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。
' 该代码仅供学习和研究支付宝接口使用,只是提供一个参考
%>
<!--#include file="alipay_config.asp"-->
<!--#include file="alipay_core.asp"-->
<%
'支付宝网关地址(新)
GATEWAY_NEW = "https://mapi.alipay.com/gateway.do?"
Class AlipaySubmit
''
' 生成签名结果
' param sParaSort 待签名的数组
' return 签名结果字符串
Private Function BuildRequestMysign(sParaSort)
'把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串
prestr = CreateLinkstring(sParaSort)
'获得签名结果
Select Case sign_type
Case "MD5" BuildRequestMysign = Md5Sign(prestr,key,input_charset)
Case Else BuildRequestMysign = ""
End Select
End Function
''
' 生成要请求给支付宝的参数数组
' param sParaTemp 请求前的参数数组
' return 要请求的参数数组
Private Function BuildRequestPara(sParaTemp)
Dim mysign
'过滤签名参数数组
sPara = FilterPara(sParaTemp)
'对请求参数数组排序
sParaSort = SortPara(sPara)
'获得签名结果
mysign = BuildRequestMysign(sParaSort)
'签名结果与签名方式加入请求提交参数组中
nCount = ubound(sParaSort)
Redim Preserve sParaSort(nCount+1)
sParaSort(nCount+1) = "sign="&mysign
Redim Preserve sParaSort(nCount+2)
sParaSort(nCount+2) = "sign_type="&sign_type
BuildRequestPara = sParaSort
End Function
''
' 生成要请求给支付宝的参数数组字符串
' param sParaTemp 请求前的参数数组
' return 要请求的参数数组字符串
Private Function BuildRequestParaToString(sParaTemp)
Dim sRequestData
'待签名请求参数数组
sPara = BuildRequestPara(sParaTemp)
'把参数组中所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串,并且对其做urlencode编码处理
sRequestData = CreateLinkStringUrlEncode(sPara)
BuildRequestParaToString = sRequestData
End Function
''
' 建立请求,以表单HTML形式构造(默认)
' param sParaTemp 请求前的参数数组
' param sMethod 提交方式。两个值可选:post、get
' param sButtonValue 确认按钮显示文字
' return 提交表单HTML文本
Public Function BuildRequestForm(sParaTemp, sMethod, sButtonValue)
Dim sHtml, nCount
'待请求参数数组
sPara = BuildRequestPara(sParaTemp)
sHtml = "<form id='alipaysubmit' name='alipaysubmit' action='"& GATEWAY_NEW &"_input_charset="&input_charset&"' method='"&sMethod&"'>"
nCount = ubound(sPara)
For i = 0 To nCount
'把sPara的数组里的元素格式:变量名=值,分割开来
iPos = Instr(sPara(i),"=") '获得=字符的位置
nLen = Len(sPara(i)) '获得字符串长度
sItemName = left(sPara(i),iPos-1) '获得变量名
sItemValue = right(sPara(i),nLen-iPos)'获得变量的值
sHtml = sHtml & "<input type='hidden' name='"& sItemName &"' value='"& sItemValue &"'/>"
next
'submit按钮控件请不要含有name属性
'submit按钮默认设置为不显示
sHtml = sHtml & "<input type='submit' value='"&sButtonValue&"' style='display:none;'></form>"
sHtml = sHtml & "<script>document.forms['alipaysubmit'].submit();</script>"
BuildRequestForm = sHtml
End Function
Public Function BuildRequestFormbank( trade_no , subject , total_fee ,body ,show_url )
Dim sHtml
sHtml = "<form name=alipayment action=alipayapi.asp method=post>"
sHtml = sHtml & " <input size=""30"" name=""WIDout_trade_no"" type='hidden' value="""& trade_no &"""/>"
sHtml = sHtml & " <input size=""30"" name=""WIDsubject"" type='hidden' value="""& subject &"""/>"
sHtml = sHtml & " <input size=""30"" name=""WIDtotal_fee"" type='hidden' value="""& total_fee &"""/>"
sHtml = sHtml & " <input size=""30"" name=""WIDbody"" type='hidden' value="""& body &"""/>"
sHtml = sHtml & " <input size=""30"" name=""WIDshow_url"" type='hidden' value="""& show_url &"""/>"
sHtml = sHtml & " <style>"
sHtml = sHtml & " ul.bank { padding:0px;margin-left:30px;}"
sHtml = sHtml & " ul.bank li { list-style:none; float:left; padding:5px;}"
sHtml = sHtml & " </style>"
sHtml = sHtml & ""
sHtml = sHtml & " <UL class=""bank fix"">"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""ICBCB2C"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""中国工商银行"" align=""middle"" src=""images/bank_gsyh2.gif"">"
sHtml = sHtml & " </LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""CMB"" type=""radio""> <IMG alt=""招商银行"""
sHtml = sHtml & " align=""middle"""
sHtml = sHtml & " src=""images/bank_zsyh2.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""CCB"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""中国建设银行"" align=""middle"""
sHtml = sHtml & " src=""images/bank_jsyh2.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""ABC"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""中国农业银行"" align=""middle"""
sHtml = sHtml & " src=""images/bank_nyyh2.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""BOCB2C"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""中国银行"" align=""middle"""
sHtml = sHtml & " src=""images/bank_zgyh2.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""COMM-DEBIT"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""交通银行"" align=""middle"" src=""images/bank_jtyh.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""CIB"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""兴业银行"" align=""middle"" src=""images/bank_xyyh.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""CMBC"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""中国民生银行"" align=""middle"" src=""images/bank_msyh2.gif"">"
sHtml = sHtml & " </LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""GDB"" type=""radio""> <IMG alt=""广东发展银行"""
sHtml = sHtml & " align=""middle"""
sHtml = sHtml & " src=""images/bank_gdfz.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""SPABANK"" type=""radio""> "
sHtml = sHtml & " 平安银行"
sHtml = sHtml & " </LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""SPDB"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""上海浦东发展银行"" align=""middle"""
sHtml = sHtml & " src=""images/bank_pfyh.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""CITIC"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""中信银行"" align=""middle"" src=""images/bank_zxyh.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""DEBIT"" type=""radio""> "
sHtml = sHtml & " <IMG alt=""光大银行"" align=""middle"" src=""images/bank_gdyh.gif""></LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""FDB"" type=""radio""> 富滇银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""HZCBB2C"" type=""radio""> 杭州银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""SHBANK"" type=""radio""> 上海银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""NBBANK"" type=""radio""> 宁波银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""POSTGC"" type=""radio""> 中国邮政储蓄银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""BJBANK"" type=""radio""> 北京银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""SHRCB"" type=""radio""> 上海农商银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""WZCBB2C-DEBIT "" type=""radio""> 温州银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""BJRCB"" type=""radio""> 北京农村商业银行</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""abc1003"" type=""radio""> visa</LI>"
sHtml = sHtml & " <LI><INPUT name=""WIDdefaultbank"" value=""abc1004"" type=""radio""> master</LI>"
sHtml = sHtml & " </UL>"
sHtml = sHtml & " <br><UL class=""bank fix"" style=""clear:both""><button class=""new-btn-login"" type=""submit"" style=""text-align:center;background-color: #ff8c00; color: #FFFFFF; font-weight: bold; "
sHtml = sHtml &"border: medium none; width:82px;height:28px;"">确 认</button></UL>"
'submit按钮控件请不要含有name属性
'submit按钮默认设置为不显示
'sHtml = sHtml & "<input type='submit' value='"&sButtonValue&"' style='display:none;'></form>"
sHtml = sHtml & "</form>"
BuildRequestFormbank = sHtml
End Function
''
' 建立请求,以HTML形式构造(默认)
' param sParaTemp 请求前的参数数组
' param sMethod 提交方式。两个值可选:post、get
' param sButtonValue 确认按钮显示文字
' return 提交表单HTML文本
Public Function BuildRequestUrl(sParaTemp, sMethod, sButtonValue)
Dim sHtml, nCount
'待请求参数数组
sPara = BuildRequestPara(sParaTemp)
sHtml = GATEWAY_NEW
nCount = ubound(sPara)
For i = 0 To nCount
'把sPara的数组里的元素格式:变量名=值,分割开来
iPos = Instr(sPara(i),"=") '获得=字符的位置
nLen = Len(sPara(i)) '获得字符串长度
sItemName = left(sPara(i),iPos-1) '获得变量名
sItemValue = right(sPara(i),nLen-iPos)'获得变量的值
sHtml = sHtml & "&"& sItemName &"="& sItemValue
next
BuildRequestUrl= sHtml
End Function
''
' 建立请求,以模拟远程HTTP的GET请求方式构造并获取支付宝XML类型处理结果
' param sParaTemp 请求前的参数数组
' param sParaNode 要输出的XML节点名
' return 支付宝返回XML指定节点内容
Public Function BuildRequestHttpXml(sParaTemp, sParaNode)
Dim sUrl, objHttp, objXml, nCount, sParaXml()
nCount = ubound(sParaNode)
'待请求参数数组字符串
sRequestData = BuildRequestParaToString(sParaTemp)
'构造请求地址
sUrl = GATEWAY_NEW & sRequestData
'获取远程数据
Set objHttp=Server.CreateObject("Microsoft.XMLHTTP")
'如果Microsoft.XMLHTTP不行,那么请替换下面的两行行代码尝试
'Set objHttp = Server.CreateObject("Msxml2.ServerXMLHTTP.3.0")
'objHttp.setOption 2, 13056
objHttp.open "GET", sUrl, False, "", ""
objHttp.send()
Set objXml=Server.CreateObject("Microsoft.XMLDOM")
objXml.Async=true
objXml.ValidateOnParse=False
objXml.Load(objHttp.ResponseXML)
Set objHttp = Nothing
set objXmlData = objXml.getElementsByTagName("alipay").item(0)
If Isnull(objXmlData.selectSingleNode("alipay")) Then
Redim Preserve sParaXml(1)
sParaXml(0) = "错误:非法XML格式数据"
Else
If objXmlData.selectSingleNode("is_success").text = "T" Then
For i = 0 To nCount
Redim Preserve sParaXml(i+1)
sParaXml(i) = objXmlData.selectSingleNode(sParaNode(i)).text
Next
Else
Redim Preserve sParaXml(1)
sParaXml(0) = "错误:"&objXmlData.selectSingleNode("error").text
End If
End If
BuildRequestHttpXml = sParaXml
End Function
''
' 建立请求,以模拟远程HTTP的GET请求方式构造并获取支付宝纯文字类型处理结果
' param sParaTemp 请求前的参数数组
' return 支付宝处理结果
Public Function BuildRequestHttpWord(sParaTemp)
Dim sUrl, objHttp, sResponseTxt
'待请求参数数组字符串
sRequestData = BuildRequestParaToString(sParaTemp)
'构造请求地址
sUrl = GATEWAY_NEW & sRequestData
'获取远程数据
Set objHttp=Server.CreateObject("Microsoft.XMLHTTP")
'如果Microsoft.XMLHTTP不行,那么请替换下面的两行行代码尝试
'Set objHttp = Server.CreateObject("Msxml2.ServerXMLHTTP.3.0")
'objHttp.setOption 2, 13056
objHttp.open "GET", sUrl, False, "", ""
objHttp.send()
sResponseTxt = objHttp.ResponseText
Set objHttp = Nothing
BuildRequestHttpWord = sResponseTxt
End Function
''
' 用于防钓鱼,调用支付宝防钓鱼接口(query_timestamp)来获取时间戳的处理函数
' 注意:远程解析XML出错,与IIS服务器配置有关
' return 时间戳字符串
Public Function Query_timestamp()
Dim sUrl, encrypt_key
sUrl = GATEWAY_NEW &"service=query_timestamp&partner="&partner&"&_input_charset="&input_charset
encrypt_key = ""
Dim objHttp, objXml
Set objHttp=Server.CreateObject("Microsoft.XMLHTTP")
'如果Microsoft.XMLHTTP不行,那么请替换下面的两行行代码尝试
'Set objHttp = Server.CreateObject("Msxml2.ServerXMLHTTP.3.0")
'objHttp.setOption 2, 13056
objHttp.open "GET", sUrl, False, "", ""
objHttp.send()
Set objXml=Server.CreateObject("Microsoft.XMLDOM")
objXml.Async=true
objXml.ValidateOnParse=False
objXml.Load(objHttp.ResponseXML)
Set objHttp = Nothing
Set objXmlData = objXml.getElementsByTagName("encrypt_key") '节点的名称
If Isnull(objXml.getElementsByTagName("encrypt_key")) Then
encrypt_key = ""
Else
encrypt_key = objXmlData.item(0).childnodes(0).text
End If
Query_timestamp = encrypt_key
End Function
End Class
%>
如有疑问请加QQ群 348615323 网店系统开发群