
你可能会注意到上面没有有效的Merchant ID,我们需要创建一个,访问苹果iOS 开发者中心的位于Identifiers >Merchant ID的页面。
然后随着流程指引,创建一个Merchant ID并注册它。
现在,我们需要给Merchant ID添加一个证书签名请求(Certificate Signing Request),以便加密支付令牌来保证其安全性。为达到这个目的,导航至你的Merchant ID,并点击Edit按钮来修改它。
现在,你需要创建一个证书。点击下面的Create Certificate按钮,并跟随苹果的流程指引完成创建。
现在Merchant ID设置好了,你可以回到Xcode并刷新Merchant ID区块,如果一切正常,你应当看到刚创建的ID出现在列表上。将它选中,然后可以进入下一部分。
编写代码
我们在Github上提供了一个集成Apple Pay的示例项目:cjbeauchamp/ApplePayDemo ,权限文件和App设置文件已经剥离出去了,可以放心将它添加到你自己的项目里。下面我们将讨论一些开发中的要点。
设置项目
Apple Pay使用了PassKit框架,所以你需要在适当的文件里导入头文件:
#import
你还需要接收Apple Pay处理信息的回调,所以确保将委托添加到接收类上:
@interface ViewController : UIViewController
创建支付请求
首先你需要确认设备是否支持Apple Pay支付,确认的代码是:
if([PKPaymentAuthorizationViewController canMakePayments]) {
...
}
在上面的代码块里,你能使用PKPayment类来创建支付请求。下面是相应的代码,你需要将其中一些信息修改成自己的,比如merchantIdentifier需要与你之前创建的Merchant ID相匹配。
PKPaymentRequest *request = [[PKPaymentRequest alloc] init]
request.countryCode = @"US"
request.currencyCode = @"USD"
request.supportedNetworks = @[PKPaymentNetworkAmex, PKPaymentNetworkMasterCard, PKPaymentNetworkVisa]
request.merchantCapabilities = PKMerchantCapabilityEMV
request.merchantIdentifier = @"merchant.com.myMerchantID"
添加物品到支付页
你可以使用PKPaymentSummaryItem来创建物品并显示,这个对象描述了一个物品和它的价格,数组最后的对象必须是总价格。
PKPaymentSummaryItem *widget1 = [PKPaymentSummaryItem summaryItemWithLabel:@"Widget 1" amount:[NSDecimalNumber decimalNumberWithString:@"0.99"]]
PKPaymentSummaryItem *widget2 = [PKPaymentSummaryItem summaryItemWithLabel:@"Widget 2" amount:[NSDecimalNumber decimalNumberWithString:@"1.00"]]
PKPaymentSummaryItem *total = [PKPaymentSummaryItem summaryItemWithLabel:@"Grand Total" amount:[NSDecimalNumber decimalNumberWithString:@"1.99"]]
request.paymentSummaryItems = @[widget1, widget2, total]
显示认证视图
最后,显示由PassKit框架提供的view controller,接下来它将自动处理认证。
PKPaymentAuthorizationViewController *paymentPane = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request]
paymentPane.delegate = self
[self presentViewController:paymentPane animated:TRUE completion:nil]
实现委托方法
被请求的委托方法是被认证成功和认证完成两个事件调用的。是否解除view controller,以及让用户知道认证是否成功都取决于你。方法的签名如下:
- (void)paymentAuthorizationViewController:didAuthorizePayment:completion:
- (void)paymentAuthorizationViewControllerDidFinish:
支付验证
在Apple Pay验证了支付之后,仍然需要开发者来完成交易,这可以用didAuthorizePayment委托方法来完成,它需要你连接服务器并上传支付令牌和 其他信息,以完成整个支付流程。在服务器呼叫结束后,你需要调用completion方法,摒弃提供success或failure标记的参数。你可以在 示例代码里找到具体实现。
监控并优化交易
Apple Pay是现有的结账流程非常棒的解决方案,在应用里使用它无疑会让用户们高兴。尽管Apple Pay让支付流程极端简化,仍然有许多变动地方,他们的表现将直接与app的营收挂钩。
交易监控
Crittercism公司的新Transaction Management是一种很棒的方法,用来监控各种交易确保它们工作正常。如果一个API端末或服务执行缓慢,或者如果用户决定取消交易,或者你的应用崩溃了,你需要知道这些信息才能更好的优化它们。你可以到Crittercism官方网站了解更多信息。
总结
希望这个入门教程让你更好的理解和使用Apple Pay。别忘了阅读苹果的指南和文档来了解如何与供应商集成,以及用户界面的指导规范。你可以在苹果Apple Pay的官网上找到它们。
java调用微信支付接口方法:RequestHandler requestHandler = new RequestHandler(super.getRequest(),super.getResponse())
//获取token //两小时内有效,两小时后重新获取
Token = requestHandler.GetToken()
//更新token 到应用中
requestHandler.getTokenReal()
System.out.println("微信支付获取token=======================:" +Token)
//requestHandler 初始化
requestHandler.init()
requestHandler.init(appid,appsecret, appkey,partnerkey, key)
// --------------------------------本地系统生成订单-------------------------------------
// 设置package订单参数
SortedMap<String, String>packageParams = new TreeMap<String, String>()
packageParams.put("bank_type", "WX")// 支付类型
packageParams.put("body", "xxxx")// 商品描述
packageParams.put("fee_type", "1")// 银行币种
packageParams.put("input_charset", "UTF-8")// 字符集
packageParams.put("notify_url", "http://xxxx.com/xxxx/wxcallback")// 通知地址 这里的通知地址使用外网地址测试,注意80端口是否打开。
packageParams.put("out_trade_no", no)// 商户订单号
packageParams.put("partner", partenerid)// 设置商户号
packageParams.put("spbill_create_ip", super.getRequest().getRemoteHost())// 订单生成的机器IP,指用户浏览器端IP
packageParams.put("total_fee", String.valueOf(rstotal))// 商品总金额,以分为单位
// 设置支付参数
SortedMap<String, String>signParams = new TreeMap<String, String>()
signParams.put("appid", appid)
signParams.put("noncestr", noncestr)
signParams.put("traceid", PropertiesUtils.getOrderNO())
signParams.put("timestamp", timestamp)
signParams.put("package", packageValue)
signParams.put("appkey", this.appkey)
// 生成支付签名,要采用URLENCODER的原始值进行SHA1算法!
String sign =""
try {
sign = Sha1Util.createSHA1Sign(signParams)
} catch (Exception e) {
e.printStackTrace()
}
// 增加非参与签名的额外参数
signParams.put("sign_method", "sha1")
signParams.put("app_signature", sign)
// api支付拼包结束------------------------------------
//获取prepayid
String prepayid = requestHandler.sendPrepay(signParams)
System.out.println("prepayid :" + prepayid)
// --------------------------------生成完成---------------------------------------------
//生成预付快订单完成,返回给android,ios 掉起微信所需要的参数。
SortedMap<String, String>payParams = new TreeMap<String, String>()
payParams.put("appid", appid)
payParams.put("noncestr", noncestr)
payParams.put("package", "Sign=WXPay")
payParams.put("partnerid", partenerid)
payParams.put("prepayid", prepayid)
payParams.put("appkey", this.appkey)
//这里除1000 是因为参数长度限制。
int time = (int) (System.currentTimeMillis() / 1000)
payParams.put("timestamp",String.valueOf(time))
System.out.println("timestamp:" + time)
//签名
String paysign =""
try {
paysign = Sha1Util.createSHA1Sign(payParams)
} catch (Exception e) {
e.printStackTrace()
}
payParams.put("sign", paysign)
//拼json 数据返回给客户端
BasicDBObject backObject = new BasicDBObject()
backObject.put("appid", appid)
backObject.put("noncestr", payParams.get("noncestr"))
backObject.put("package", "Sign=WXPay")
backObject.put("partnerid", payParams.get("partnerid"))
backObject.put("prepayid", payParams.get("prepayid"))
backObject.put("appkey", this.appkey)
backObject.put("timestamp",payParams.get("timestamp"))
backObject.put("sign",payParams.get("sign"))
String backstr = dataObject.toString()
System.out.println("backstr:" + backstr)
return backstr
====================到此为止,预付款订单已生成,并且已返回客户端====================
//坐等微信服务器通知,通知的地址就是生成预付款订单的notify_url
ResponseHandler resHandler = new ResponseHandler(request, response)
resHandler.setKey(partnerkey)
//创建请求对象
//RequestHandler queryReq = new RequestHandler(request, response)
//queryReq.init()
if (resHandler.isTenpaySign() == true) {
//商户订单号
String out_trade_no = resHandler.getParameter("out_trade_no")
System.out.println("out_trade_no:" + out_trade_no)
//财付通订单号
String transaction_id = resHandler.getParameter("transaction_id")
System.out.println("transaction_id:" + transaction_id)
//金额,以分为单位
String total_fee = resHandler.getParameter("total_fee")
//如果有使用折扣券,discount有值,total_fee+discount=原请求的total_fee
String discount = resHandler.getParameter("discount")
//支付结果
String trade_state = resHandler.getParameter("trade_state")
//判断签名及结果
if ("0".equals(trade_state)) {
//------------------------------
//即时到账处理业务开始
//------------------------------
System.out.println("----------------业务逻辑执行-----------------")
//——请根据您的业务逻辑来编写程序(以上代码仅作参考)——
System.out.println("----------------业务逻辑执行完毕-----------------")
System.out.println("success")// 请不要修改或删除
System.out.println("即时到账支付成功")
//给财付通系统发送成功信息,财付通系统收到此结果后不再进行后续通知
resHandler.sendToCFT("success")
//给微信服务器返回success 否则30分钟通知8次
return "success"
}else{
System.out.println("通知签名验证失败")
resHandler.sendToCFT("fail")
response.setCharacterEncoding("utf-8")
}
}else {
System.out.println("fail -Md5 failed")
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)