- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在开发一个基于 Spring 的 Java 应用程序,我能够在其中成功集成 paypal。因此,我们有一个基于类(class)注册的网站,用户正在该网站上注册。现在我已经稍微修改了付款方式,所以从前端我也会收到哪个学生正在尝试为哪个类(class)付款。检查类(class)费用的数据库,我可以设置费用,并执行付款。
问题是,哪个用户付了钱,这是我还不知道的。有什么办法可以在 Paypal 的请求和响应中添加自定义整数字段,这样我就可以提取该信息并执行后续步骤以确保学生在我的后端也被标记为“已付款”。请让我知道...
支付宝代码:
public Payment createPayment(HttpServletRequest req, HttpServletResponse resp, String abc) {
System.out.println("String abc is "+abc);
InputStream is = TestPayment.class
.getResourceAsStream("/sdk_config.properties");
try {
PayPalResource.initConfig(is);
} catch (PayPalRESTException e) {
LOGGER.fatal(e.getMessage());
}
Payment createdPayment = null;
APIContext apiContext = null;
String accessToken = null;
try {
accessToken = GenerateAccessToken.getAccessToken();
apiContext = new APIContext(accessToken);
} catch (PayPalRESTException e) {
req.setAttribute("error", e.getMessage());
}
if (req.getParameter("PayerID") != null) {
Payment payment = new Payment();
if (req.getParameter("guid") != null) {
payment.setId(map.get(req.getParameter("guid")));
}
PaymentExecution paymentExecution = new PaymentExecution();
paymentExecution.setPayerId(req.getParameter("PayerID"));
try {
createdPayment = payment.execute(apiContext, paymentExecution);
//ResultPrinter.addResult(req, resp, "Executed The Payment", Payment.getLastRequest(), Payment.getLastResponse(), null);
} catch (PayPalRESTException e) {
// ResultPrinter.addResult(req, resp, "Executed The Payment", Payment.getLastRequest(), null, e.getMessage());
}
} else {
Details details = new Details();
details.setShipping("1");
details.setSubtotal("5");
details.setTax("1");
Amount amount = new Amount();
amount.setCurrency("EUR");
// Total must be equal to sum of shipping, tax and subtotal.
amount.setTotal("7");
amount.setDetails(details);
// ###Transaction
// A transaction defines the contract of a
// payment - what is the payment for and who
// is fulfilling it. Transaction is created with
// a `Payee` and `Amount` types
Transaction transaction = new Transaction();
transaction.setAmount(amount);
transaction
.setDescription("This is the payment transaction description.");
// ### Items
Item item = new Item();
item.setName("Online Market").setQuantity("1").setCurrency("EUR").setPrice("5");
ItemList itemList = new ItemList();
List<Item> items = new ArrayList<Item>();
items.add(item);
itemList.setItems(items);
transaction.setItemList(itemList);
// The Payment creation API requires a list of
// Transaction; add the created `Transaction`
// to a List
List<Transaction> transactions = new ArrayList<Transaction>();
transactions.add(transaction);
// ###Payer
// A resource representing a Payer that funds a payment
// Payment Method
// as 'paypal'
Payer payer = new Payer();
payer.setPaymentMethod("paypal");
// ###Payment
// A Payment Resource; create one using
// the above types and intent as 'sale'
Payment payment = new Payment();
payment.setIntent("sale");
payment.setPayer(payer);
payment.setTransactions(transactions);
// ###Redirect URLs
RedirectUrls redirectUrls = new RedirectUrls();
String guid = UUID.randomUUID().toString().replaceAll("-", "");
redirectUrls.setCancelUrl(req.getScheme() + "://"
+ req.getServerName() + ":" + req.getServerPort()
+ req.getContextPath() + "/paymentcancelled");
redirectUrls.setReturnUrl(req.getScheme() + "://"
+ req.getServerName() + ":" + req.getServerPort()
+ req.getContextPath() + "/successpayment");
payment.setRedirectUrls(redirectUrls);
// Create a payment by posting to the APIService
// using a valid AccessToken
// The return object contains the status;
try {
createdPayment = payment.create(apiContext);
/* LOGGER.info("Created payment with id = "
+ createdPayment.getId() + " and status = "
+ createdPayment.getState());*/
// ###Payment Approval Url
Iterator<Links> links = createdPayment.getLinks().iterator();
while (links.hasNext()) {
Links link = links.next();
if (link.getRel().equalsIgnoreCase("approval_url")) {
req.setAttribute("redirectURL", link.getHref());
}
}
// ResultPrinter.addResult(req, resp, "Payment with PayPal", Payment.getLastRequest(), Payment.getLastResponse(), null);
map.put(guid, createdPayment.getId());
} catch (PayPalRESTException e) {
// ResultPrinter.addResult(req, resp, "Payment with PayPal", Payment.getLastRequest(), null, e.getMessage());
}
}
return createdPayment;
}
请告诉我。多谢。
最佳答案
在交易对象中设置“自定义”字段
https://developer.paypal.com/webapps/developer/docs/release-notes/#updates-for-5-august-2014
关于java - Paypal : Checking out which user paid?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30458528/
我想在已付款状态时禁用付款按钮。 我的代码: Month DPS Amount Status
我正在开发一个基于 Spring 的 Java 应用程序,我能够在其中成功集成 paypal。因此,我们有一个基于类(class)注册的网站,用户正在该网站上注册。现在我已经稍微修改了付款方式,所以从
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我有一个应用程序的 2 个版本。精简版和付费版。我想要在 Lite 版本中有一个按钮,单击该按钮会在 iPhone 上打开 App Store 应用程序,并显示该应用程序的付费版本页面。 我该怎么做?
我在现有的常规 php Web 应用程序中使用 auth0。 我的网站上有免费用户和付费用户。对于免费用户的注册过程很简单,我调用了触发验证电子邮件的创建用户 api。 但对于付费用户,我有一个多步骤
我将发布一个具有免费精简版和付费专业版的应用。当然,Pro 付费版还有很多附加功能。 我的问题是:在 Lite 版本中,我应该显示附加功能(不活动,可能显示为灰色并显示“专业版”消息)还是隐藏它们更好
提交 SuiteScript 1.0 部署到发票后,我有一个用户事件,但我似乎无法触发它。我需要它在付款后运行,并且发票状态更新为“已全额付款”(假设付款后更新的发票是提交后事件?)如果我返回发票并编
据我所知,如果我想发布具有两种不同风格的应用程序,我需要区分它们的 applicationId。 这意味着可以在一台设备上同时安装免费和付费版本。我不想要这个。我想安装付费 flavor 以覆盖免费
我正在尝试生成一个将显示“已支付”发票的查询。我的查询不起作用,这意味着其中存在错误,或者我试图通过这种方式实现的目标是不可能的。 // paid $statement = "accounts_inv
我正处于一个棘手的位置,我正在努力找出继续进行的最佳方法。几个月前我发布了一款应用程序,并向数百人收取了 0.99 美元的费用。我现在有兴趣通过应用内购买使该应用免费。我怎样才能让已经付款的人不需要再
我正在开发一个应用程序,它将有一个付费(完整)版本和一个免费(精简)版本。 在为 Android 开发的另一个应用程序中,可以使用 flavors (productFlavors) 轻松管理这一点,我
我有一个关于 Google Analytics 如何解释不同 session 的问题。 假设客户通过点击 Google 搜索结果(付费搜索或自然搜索)中的链接访问我的网站。然后,客户将我的网站添加为书
我有一个成员(member)资格,每个用户每 30 天获得 100 个积分。所有成员(member)资格均需预先支付一到无限个月的费用。 我想每 30 天将积分余额重置为 100,无论用户是否使用他的
你们是我最后的希望...我用 wordpress 创建了一个网站,我正在使用 woocommerce 插件来销售我的书。我设置了所有内容(不是我的第一家商店,而是我的第一家 woocommerce 商
已结束。 这个问题是 off-topic .它目前不接受答案。 想要改进这个问题? Update the question所以它是on-topic堆栈溢出。 关闭 9 年前。 Improve this
我有 2 个版本的应用程序。精简版和付费版。我想在 Lite 版本中有一个按钮,单击该按钮会在 iPhone 上打开 App Store 应用程序并显示该应用程序的付费版本页面。 我该怎么做呢?我不想
摘要:我是否需要在 iTunesConnect 上接受 Apple 的“付费应用程序”契约(Contract)才能更新我的免费应用程序?如果没有,我应该遵循哪些步骤来更新我的免费应用程序? 细节: 我
我想为我的网站制作成员(member)内容。 我使用付费成员(member)专业插件来实现这一目标。 我注册了 paypal 并生成了 API 凭证。 现在,当我想在该成员(member)级别添加新用
我想在 AppStore 上发布我的 iOS 应用程序的两个版本。 一个是付费的,另一个是免费的。截至目前,我的付费应用程序代码已完成。现在我想为免费应用程序的 iAd 和 InAppPurchase
我要进入数组的 foreach 循环。当我尝试获取 key 时,它显示错误。 如果我显示整个原始数组,它会显示所有数据。 {{bal}} //显示 { "
我是一名优秀的程序员,十分优秀!