1.流程图:
2.java代码(可增加对iosData使用记录的查询,防止重复使用,提高支付服务安全):
//走ios内购验证
//iosData = {"receipt-data" : "MIIVDAYJKoZIhvcNAQcCoIIU/T..."}
// 苹果支付沙箱验证地址,可以真机模拟支付
String url = "https://sandbox.itunes.apple.com/verifyReceipt";
// 苹果支付正式验证地址
// String url = "https://buy.itunes.apple.com/verifyReceipt";
JSONObject param = JSON.parseObject(iosData);
JSONObject result = JSON.parseObject(HttpUtil.URLPost(url, param));//封装的httpclient post请求方法
Integer status = result.getInteger("status");//0 成功的
if (status!=0) return "内购失败,状态吗:"+status;
3.status类型: * 0 SUCCESS * 21000 App Store不能读取你提供的JSON对象 * 21002 receipt-data域的数据有问题 * 21003 receipt无法通过验证 * 21004 提供的shared secret不匹配你账号中的shared secret * 21005 receipt服务器当前不可用 * 21006 receipt合法,但是订阅已过期。服务器接收到这个状态码时,receipt数据仍然会解码并一起发送 * 21007 receipt是Sandbox receipt,但却发送至生产系统的验证服务 * 21008 receipt是生产receipt,但却发送至Sandbox环境的验证服务