1、接口文档

1.1 无gmc界面接口 (dll/ocx)

dll调用(posinf.dll)函数名为:int bankall (char * request,char *response),其中第一个参数为传入参数。

ocx调用(umsocx.ocx):trans(),传入参数为:bankrequest

请求参数格式说明如下:

内容

格式

长度

描述

POS机号

ANS

8

不足右补空格

POS员工号

ANS

8

不足右补空格

交易类型标志

N

2

'00'-消费        '01'-撤消

'02'-退货        '03'-查余额

'04'-重打印      '05'-签到

'06'-结算        '07'-重打结算单

'08'-全民付(总)   '55'-换班统计

72'-'78':全民付类交易

'10'-积分消费        '11'-积分撤消

'12'-分期消费        '13'-分期撤销

'21'-预授权         '23'-预授权完成请求

'24'-预授权完成通知  '25'-预授权撤销

'26'-预授权完成撤销  '27'-离线结算

'28'-结算调整

金额

N

12

信用卡消费金额,char(12),没有小数点".",精确到分,最后两位为小数位,不足左补0。

原交易日期

N

8

yyyymmdd格式,退货时用,其他交易空格

原交易参考号

N

12

退货时用,其他交易空格

原凭证号

N

6

撤消时用,其他交易空格

LRC校验

ANS

3

3位随机数字

全民付(行业信息)

N

100

行业信息(非全民付类交易无需送此项)(全民付类不送此项,则为键盘输入)

dll调用(posinf.dll)函数名为:int bankall (char * request,char *response),其中第二个参数为应答参数。

ocx调用函数名为:trans(),传入参数为:BankResponse

应答参数格式说明如下:

内容

格式

长度

描   述

返回码

N

2

00 表示成功,其它表示失败

银行行号

N

4

发卡行代码

卡号

N

20

卡号(屏蔽部分,保留前6后4)

凭证号

N

6

金额

N

12

错误说明

ANS

40

中文解释

商户号

N

15

终端号

N

8

批次号

N

6

交易日期

N

4

交易时间

N

6

交易参考号

N

12

授权号

N

6

清算日期

N

4

LRC校验

ANS

3

三位数字,应该和请求一致

1.2 符号定义

数据元类型如下所列:

00001—— A 字母向左靠,右部多余部分填空格。

00002—— AN 字母和/或数字,左靠,右部多余部分填空格。

00003—— ANS 字母、数字和/或特殊符号,左靠,右部多余部分填空格。

00004—— N 数值,右靠,首位有效数字前充零。若表示金额,则最右二位为角分。

00005—— MM 月。

00006—— DD 日。

00007—— hh 时。

00008—— mm 分。

00009—— ss 秒。

注意:本接口文档中信息交换数据,均为定长,注意按照要求补足空格。

2、代码实现如下:

//外部函数声明
FUNCTION long bankall(string as_request, ref string as_response) LIBRARY "posinf.dll" //调用
string ls_content,ls_sellway,ls_money,ls_OldDate
string ls_posid,ls_casher,ls_rand
dec{} ldec_needpay, ldec_pay,ldec_consume
dec{} ldec_cnt,ldec_payed
string ls_cardid,ls_voucher,ls_consume
string ls_info,ls_refno,ls_OldRefno,ls_OldVoucher //'00'-消费'01'-撤消'02'-退货'03'-查余额'04'-重打印'05'-签到'06'-结算'07'-重打结算单
ls_sellway=left(sle_type.text,)
if pos('00/01/02/03/04/05/06/07',ls_sellway)=0 then
messagebox('提示','请录入正确的交易类型!')
sle_type.setfocus()
sle_type.selecttext(,len(sle_type.text))
return
end if ///交易金额
if ls_sellway='00' or ls_sellway='01' or ls_sellway='02' then
//'00'-消费'01'-撤消'02'-退货
ldec_needpay=abs(dec(sle_payamt.text))
if ldec_needpay= or (not IsNumber(sle_payamt.text)) then
messagebox('提示','请录入金额!')
sle_payamt.setfocus()
sle_payamt.selecttext(,len(sle_payamt.text))
return
end if
else
ldec_needpay=
end if //'02'-退货//原交易日期、原交易参考号
if ls_sellway='02' then
ls_OldDate=trim(sle_date.text)
if isnull(ls_OldDate) or ls_OldDate='' or len(ls_OldDate)<>8 then
messagebox('提示','请录入原交易日期(8位),格式为yyyymmdd!')
sle_date.setfocus()
sle_date.selecttext(,len(sle_date.text))
return
end if ls_OldRefno=trim(sle_refno.text)
if isnull(ls_OldRefno) or ls_OldRefno='' or len(ls_OldRefno)<>12 then
messagebox('提示','请录入原交易参考号(12位)!')
sle_refno.setfocus()
sle_refno.selecttext(,len(sle_date.text))
return
end if else
ls_OldDate=space()
ls_OldRefno=space()
end if //'01'-撤消//原凭证号
if ls_sellway='01' then
ls_OldVoucher=trim(sle_voucher.text)
if isnull(ls_OldVoucher) or ls_OldVoucher='' or len(ls_OldVoucher)<>6 then
messagebox('提示','请录入原凭证号(6位)!')
sle_voucher.setfocus()
sle_voucher.selecttext(,len(sle_date.text))
return
end if
else
ls_OldVoucher=space()
end if ls_posid='99'
ls_casher='1001'
ls_money=string(round(ldec_needpay,)*,'000000000000')
ls_rand=string(rand(),'000') ///3位随机数字
//传给银行卡刷卡系统的交易请求文件:
//POS机号(8位,不足右补空格)+POS员工号(8位,不足右补空格)+交易类型标志(2位)+金额(12位,不足左补0)+
//原交易日期(8位,yyyymmdd格式,退货时用,其他交易空格)
//原交易参考号(12位,退货时用,其他交易空格)
//原凭证号(6位,撤消时用,其他交易空格)
//备用()+LRC(3位随机数字)
ls_content=ls_posid+space( - len(ls_posid)) +ls_casher+space( - len(ls_casher)) +ls_sellway+ls_money+&
+ls_OldDate+ls_OldRefno+ls_OldVoucher+'000000'+ls_rand ls_info=space()
bankall(ls_content,ls_info) if left(ls_info,)='00' then //响应码2位, 00 表示成功,其它表示失败
ls_cardid =mid(ls_info,,) //卡号20位
ls_voucher=mid(ls_info,,) //凭证号6位
ls_consume=mid(ls_info,,) //金额12位
ls_refno =mid(ls_info,,) //交易参考号12
messagebox('提示',"交易成功,金额为"+string(dec(ls_consume)/100)+",~r~n凭证号是:"+ls_voucher+",交易参考号是:"+ls_refno)
else
messagebox('提示',"交易失败,返回值:"+left(ls_info,2)+",失败原因:"+mid(ls_info,45,40))
return
end if

gmc银联接口开发demo的更多相关文章

  1. 支付宝即时到账接口开发 - DEMO讲解

    支付宝即时到帐接口 环境要求 PHP5.0以上,且需要开启curl.openssl. 文档地址: https://doc.open.alipay.com/doc2/detail?treeId=62&a ...

  2. java 银联接口开发

    http://blog.sina.com.cn/s/blog_6c868c470100ys59.html 在线接口文档:http://wenku.baidu.com/link?url=EUgAuOKz ...

  3. php支付宝在线支付接口开发教程【转】

    php支付宝在线支付接口开发教程 这篇文章主要为大家详细介绍了php支付宝在线支付接口开发教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下   1.什么是第三方支付 所谓第三方支付,就是一些和各 ...

  4. php微信支付接口开发程序

    php微信支付接口开发程序讲解 微信支付接口现在也慢慢的像支付宝一个可以利用api接口来实现第三方网站或应用进行支付了, 下文整理了一个php微信支付接口开发程序并且己测试,有兴趣的朋友可进入参考. ...

  5. 支付宝WAP支付接口开发

    支付宝WAP支付接口开发 因项目需要,要增加支付宝手机网站支付功能,找了支付宝的样例代码和接口说明,折腾两天搞定,谨以此文作为这两天摸索的总结.由于公司有自己的支付接口,并不直接使用这个接口,所以晚些 ...

  6. JAVA微信支付接口开发——支付

    微信支付接口开发--支付 这几天在做支付服务,系统接入了支付宝.微信.银联三方支付接口.个人感觉支付宝的接口开发较为简单,并且易于测试. 关于数据传输,微信是用xml,所以需要对xml进行解析. 1. ...

  7. Asp.Net Core基于JWT认证的数据接口网关Demo

    近日,应一位朋友的邀请写了个Asp.Net Core基于JWT认证的数据接口网关Demo.朋友自己开了个公司,接到的一个升级项目,客户要求用Aps.Net Core做数据网关服务且基于JWT认证实现对 ...

  8. 支付宝(alipay)即时到账收款接口开发中的那些事儿

    不会做,看看也可以会,要做好就还是需要多学习 国庆回来就一直没状态,看完<银河护卫队>,印象最深的竟然是只有两句台词的呆萌groot,昨天才休息一天,大耍大吃,今天还是把昨天的知识学习一下 ...

  9. php微信支付接口开发程序(流程已通)

    php微信支付接口开发程序(流程已通) 来源:未知    时间:2014-12-11 17:11   阅读数:11843   作者:xxadmin [导读] 微信支付接口现在也慢慢的像支付宝一个可以利 ...

随机推荐

  1. [Android Pro] 判断Uri对应的ContentProvider所操作的数据库u存在,及DownloadManager的暂停,继续

    reference to : http://blog.csdn.net/u012858313/article/details/38821857 项目中遇到一个问题,就是用到DownloadManage ...

  2. SQL语句汇总

    1.查询出来数据保留小数点2位,并且0.01时候,不会展示为.01. select     to_char(0.1,'fm9999999990.00') from dual; 2.wm_concat ...

  3. PHP实现四种基本排序算法

    前提:分别用冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中的值按照从小到大的顺序进行排序. $arr(1,43,54,62,21,66,32,78,36,76,39); 1. 冒泡排序 思 ...

  4. Android -- Activity,Fragment lifecycle

    Activity Lifecyce Fragment Lifecycle: 程序运行: 09-16 13:59:22.883 19022-19022/com.example.android.archi ...

  5. MongoDB replication set副本集(主从复制)(8)(转)

    转载地址:http://www.cnblogs.com/huangxincheng/p/4870557.html replicattion set 就是多台服务器维护相同的数据副本,提高服务器的可用性 ...

  6. C#连接Oracle数据库(直接引用dll使用)

    转载至:http://www.cnblogs.com/gguozhenqian/p/4262813.html 项目中有个功能需要从一台Oracle数据库获取数据,本以为是很简单的事情,直接将原来的Sq ...

  7. Windows Server 2008 R2 DNS 服务器迁移

  8. jquery控制radio选中

    好久没写jquery了,昨天下午写一个效果,结果倒腾了半天还是没有解决,好在今天早上在网上询问到解决方法了,现在果断记录下. 要实现的效果就是交易方式选择时不同的交易方式下默认选中第一个选项. 如下: ...

  9. 【新手学Python】一、基础篇

    由于以前处理数据用Matlab和C,最近要处理大量文本文件,用C写实在是太繁琐,鉴于Python的强大文本处理能力,以及其在Deep Learning上有着很大优势,本人打算从即日起学习Python, ...

  10. MySQL Cluster搭建与测试

    MySQL Cluster是一个基于NDB Cluster存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和Oracle Real Cluster Ap ...