微信支付被骗488元微信转账被骗能追回吗吗

佛山街坊注意!微信扫码支付要限额!4月1日起实施佛山街坊注意!微信扫码支付要限额!4月1日起实施
佛山发布03-14 15:56
跟贴 8 条 如今,使用微信、支付宝扫码付款已经成为生活的常态。然而你知道吗?用微信、支付宝等应用扫码付款将正式迎来额度限制。日前,人民银行发布《中国人民银行关于印发&条码支付业务规范(试行)&的通知》(银发〔号),配套印发了《条码支付安全技术规范(试行)》和《条码支付受理终端技术规范(试行)》(银办发〔号发布),自日起实施。新规为条码支付立了“规矩”:若使用静态扫码支付,同一客户银行或支付机构单日累计交易金额应不超过500元,使用动态扫码支付的最高不限额,该新规从今年4月1日开始正式施行。什么是静态条码支付?我们常见的路边摊、菜市、杂货店等贴在墙上或者打印好的二维码就属于静态条码,我们买完东西付款时,出示付款码供收银员来扫的属于动态条码。央行规定,使用静态条码进行支付的,风险防范能力为D级,无论使用何种交易验证方式,同一客户银行或支付机构单日累计交易金额应不超过500元。例如,消费者在使用微信钱包扫描静态条码支付时,单日使用零钱包支付的上限不超过500元,同时微信关联的所有银行卡还可以再独立获得500元的支付上限。对于使用动态条码(如手机上实时生成的条码)进行支付的,风险防范能力根据交易验证方式不同分为A、B、C三级,同一客户单日累计交易限额分别为自主约定、5000元、1000元。同时,规定要求:静态条码应由后台服务器加密生成,宜采用防伪纸张展示条码;展示静态条码的介质应放置在商户收银员视线范围内,商户应定期对介质进行检查;静态条码应采用防护罩等物理防护手段避免被覆盖或替换;在静态条码介质显著位置明显展示收款方信息,便于用户核对。
打开网易新闻 查看更多精彩图片
为什么要限额?近年来条码支付业务快速发展,成为移动支付发展的重要体现形式,然而条码支付虽然便民,仍存在着不少隐患。静态条码极易被篡改或变造,易携带木马或病毒,其风险防范能力被认定为D级。同时,条码支付的技术实现方式和业务风险相对传统银行卡支付具有其特殊性,部分市场机构在业务开展中也存在扰乱公平竞争秩序、支付风险防范不到位等问题。
对消费者有何影响?消费超过500元怎么办?很多人会问是不是新规实施后,用微信或支付宝扫一扫,每天只能花500元了?其实并不是这样,新规实施后,消费者在街头商贩扫静态条码小额支付不受影响。举例来说,如果在饭店里吃了顿600元的大餐,扫静态条码付款就有困难了,这时可以让收银员扫消费者手机上生成的动态条码,而且这样更安全。动态条码如下:
中国支付清算协会副秘书长亢林表示,我们日常使用的支付宝和微信,一般使用两个以上,比如说指纹、密码这两个以上的要素,单日限额是5000元。对消费者来讲,不会带来任何不便。对店家有何影响?新规实施后,或许对街头的小商家有些影响。比如对于卖煎饼的老板来说,一天收入超过500元后,就需要单独扫每位顾客的码,如果遇到赶时间的上班族,则会带来一些不便。除此之外,如果每天收入超过500元,这些店家还需要自己准备扫码枪一类的设备,可能会给小商家增加一些压力。
警方提醒1.要使用官方渠道App扫码软件,不扫不明二维码;2.仔细辨别真伪,核对信息,确认二维码安全有效;3.对常见的二维码也应保持适度警惕,保管好自己的付款二维码;4.手机上最好安装一些正规安全软件,增加手机安全系数,防止不法分子将病毒镶嵌在二维码里,盗取公民个人重要信息。消息来源|佛山发布
原标题:央行出手,微信扫码支付要限额!4月1日起最多这个数……大家都在看分享成功热门推荐我刚刚在微信里面加了一好友跟他交易显示的价格只要4.88结果支付扣取的金额488--在线法律咨询|律师365(64365.com)
大家都在搜:
微信扫一扫 免费问律师手机扫一扫 法律兜里装
我刚刚在微信里面加了一好友跟他交易显示的价格只要4.88结果支付扣取的金额488
我刚刚在微信里面加了一好友跟他交易显示的价格只要4.88结果支付扣取的金额488元这种情况该怎么办
1229人阅读
ask****325
1分钟提交法律咨询 2000多位 信得过的好律师 为您提供专业解答
其他人都在看
无锡其他律师
相关法律咨询
热门其他法律百科
今天为大家解读养老保险个人缴费比例基数的相关知识,那么养老保险个人缴费比例基数,上海养老保险手续,上海养老保险缴纳比例是什么,更多内容尽在律师365百科栏目,希望对你有所帮助,和小编一起来了解一下吧!
其他相关知识
其他相关专题
周边专业律师
扫描二维码
更多惊喜等着您!
1分钟提问,免费短信提醒
律师365,优质法律服务平台
400-64365-60服务时间:周一至周六8:00~22:00
服务指南平台保障律师入驻
|||||Copyright(C) 成都六四三六五科技有限公司 版权所有 蜀ICP备号 增值电信业务经营许可证(川B2-)免费发布咨询,坐等律师在线服务
需求发布后
10分钟内收到律师在线回复
平均有多个律师参与回复
得到了圆满解决
您的位置: &
我微信付款时他写4.80元,实里面暗臧488.00元。所以我被坑近500还能追回来吗?
我微信付款时他写4.80元,实里面暗臧488.00元。所以我被坑近500.00元。还能追回来吗?
无锡推荐律师女子刷单尝到五元甜头 岂料最后被骗43198元
原标题:女子刷单尝到五元甜头 岂料最后被骗43198元
华龙网2月1日12时50分讯 近年来,打着刷单赚外快的幌子诈骗的事件屡见不鲜,这不市民姚女士(化名)就因为误信谗言而被骗43198元。1月31日,意识到被骗的姚某向渝北区公安分局仙桃派出所报了警。
日,姚某在家里聊微信,无意中看到自己加入的一个微信聊天群中,一个群友在群里发消息称京东天猫等商城急招网络兼职人员,每天可收入150元至280元,还发布了QQ号让有意向的朋友加他好友。日下午的时候,姚某出于好奇就用自己的QQ号加了对方为好友,一开始两人在QQ上闲聊很久,对方称让姚某在网上帮商家刷单,完成后不仅退还本金,还会支付每笔5%的佣金,而且每单交易10分钟左右就能完成。抱着试试看的心情,姚某在网上通过微信刷了第一笔,对方给姚某发了一个二维码过来还在网上教姚某如何操作,姚某根据对方的要求刷了价值100元的衣服,不一会儿对方就按照约定给姚某返回了连本带息105元。
接着,为了诱骗姚某继续刷单,对方又在QQ上和姚某聊了一些鼓励和合作的客套话,让姚某连续交易三单,并告知姚某完成三单任务后才能支付本息。第一单对方给姚某发了一个二维码,让姚某刷了4次,共计2600元,后来微信提示姚某不能继续付款了,于是姚某就通过支付宝刷了两个488元,前后共计3596元。第二单对方又让姚某用支付宝刷了两笔481元,一共962元,后来支付宝也无法继续操作了,于是对方就给姚某发了一个银行卡账户,姚某分别向该卡转了2000元和640元,第二单一共转了3602元。最后,第三单姚某分成两笔给一个叫罗某的银行卡号转了两笔12000元,给汪某的银行卡号分别转了10500元和1500元,一共36000元。三单一共转了43198元,对方还以各种借口要求姚某继续转账,姚某感觉自己已经付出很多也开始要求对方返钱,但对方百般推脱,此时姚某发现不对劲了,马上拨打了110报警,然后急忙赶到渝北区公安分局仙桃派出所协助调查。
目前,该案仙桃派出所已按相关程序立案受理,案件正在进一步的侦办当中。
渝北警方提醒市民:网络购物已经成为拉动社会消费、推动经济增长的重要方式,刷单问题也引起社会大众的关注,通过刷单取得竞争有利地位,损害消费者知情权和自由选择权的行为本身就是不可取的,同时也衍生出很多类似文中案例的违法犯罪现象。民警特别提醒,春节将近,广大市民朋友要提高防骗意识,捂紧钱包,不要让自己的辛勤劳动成果付之东流。
责任编辑人:凤凰号
释放进入手凤首页iOS之支付 - 简书
iOS支付分为两类,第三方支付和应用内支付(内购)。
第三方支付包括:支付宝支付、微信支付、银联支付、百度钱包、京东支付等等。
应用内支付(In-App Purchase):在应用程序内购买虚拟商品。如果你在App Store上销售的应用程序,将收到支付金额的70%。
第三方支付
有些第三方支付没有安装客户端,可以直接弹出网页进行支付。(比如支付宝)
手机中安装了客户端可以跳转到APP中进行支付。微信支付只能调用App进行支付。
支付宝支付
支付宝开放平台(SDK&开发文档):
移动支付集成:
商户服务平台(与支付宝签约需要填写的公司资料):
在商户服务平台先与支付宝签约,获得商户ID(partner)和账号ID(seller),需要提供公司资质或者营业执照,个人无法申请。
文档地址:
生成并下载相应的公钥私钥文件(加密签名用)
文档地址:
下载支付宝SDK:
生成订单信息
调用支付宝客户端,由支付宝客户端跟支付宝安全服务器打交道
支付完毕后返回支付结果给商户客户端和服务器
SDK里有集成支付宝功能的一个Demo,集成支付功能的具体操作方式,可以参考Demo。
代码集成流程
参考文档地址:
下载官方SDK
下载地址:
本Demo使用的SDK是从官方Demo整理出来的,整理的SDK版本:。
下载地址:
目录结构如下:
├── AlipaySDK.bundle
├── AlipaySDK.framework
├── Order.h
├── Order.m
├── Util
├── libcrypto.a
├── libssl.a
└── openssl
AlipaySDK.bundle和AlipaySDK.framework是支付宝SDK
Order类:定义订单信息
Util、libcrypto.a、libssl.a、openssl:数据签名,对订单信息进行加密
添加依赖库
其中,需要注意的是:
如果是Xcode 7.0之后的版本,需要添加libc++.tbd、libz.tbd;
如果是Xcode 7.0之前的版本,需要添加libc++.dylib、libz.dylib。
创建prefix header filePCH文件,添加#import &Foundation/Foundation.h&
在Build Settings中的prefix header设置pch文件路径
在Build Settings中Header Search Paths添加头文件引用路径,[文件路径]/AlipaySDK/
在需要调用AlipaySDK的文件中,增加头文件引用。
&AlipaySDK/AlipaySDK.h&
#import "Order.h"
#import "DataSigner.h"
生成订单信息及签名
//将商品信息赋予AlixPayOrder的成员变量
Order *order = [[Order alloc] init];
order.partner = PartnerID; // 商户ID
order.seller = SellerID; // 账号ID
order.tradeNO = @""; //订单ID(由商家自行制定)
order.productName = @"iPhone6s"; //商品标题
order.productDescription = @"新年打折"; //商品描述
order.amount = @"0.01"; //商品价格(单位:元)
order.notifyURL =
@"http://www.chaosky.me"; //回调URL,支付成功或者失败回调通知自己的服务器进行订单状态变更
order.service = @"mobile.securitypay.pay";
order.paymentType = @"1";
order.inputCharset = @"utf-8";
order.itBPay = @"30m";
order.showUrl = @"m.alipay.com";
// 应用注册scheme,在AlixPayDemo-Info.plist定义URL types
NSString *appScheme = @"AliPayDemo";
//将商品信息拼接成字符串
NSString *orderSpec = [order description];
NSLog(@"orderSpec = %@",orderSpec);
//获取私钥并将商户信息签名,外部商户可以根据情况存放私钥和签名,只需要遵循RSA签名规范,并将签名字符串base64编码和UrlEncode
id&DataSigner& signer = CreateRSADataSigner(PartnerPrivKey);
NSString *signedString = [signer signString:orderSpec];
//将签名成功字符串格式化为订单字符串,请严格按照该格式
NSString *orderString =
if (signedString != nil) {
orderString = [NSString stringWithFormat:@"%@&sign=\"%@\"&sign_type=\"%@\"",
orderSpec, signedString, @"RSA"];
[[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary * resultDic) {
NSLog(@"reslut = %@",resultDic);
Xcode设置URL scheme
iPhone SDK可以把你的App和一个自定义的URL Scheme绑定。该URL Scheme可用来从浏览器或别的App启动你的App。
配置方法:打开info.plist文件,找到或者添加如图所示的键值对:
URL Scheme值为代码中对应的值,必须一致。
配置支付宝客户端返回url处理方法
AppDelegate.m文件中,增加引用代码:
#import &AlipaySDK/AlipaySDK.h&
在@implementation AppDelegate中增加如下代码:
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
//如果极简开发包不可用,会跳转支付宝钱包进行支付,需要将支付宝钱包的支付结果回传给开发包
if ([url.host isEqualToString:@"safepay"]) {
[[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary * resultDic) {
//【由于在跳转支付宝客户端支付的过程中,商户app在后台很可能被系统kill了,所以pay接口的callback就会失效,请商户对standbyCallback返回的回调结果进行处理,就是在这个方法里面处理跟callback一样的逻辑】
NSLog(@"result = %@",resultDic);
if ([url.host isEqualToString:@"platformapi"]){//支付宝钱包快登授权返回authCode
[[AlipaySDK defaultService] processAuthResult:url standbyCallback:^(NSDictionary * resultDic) {
//【由于在跳转支付宝客户端支付的过程中,商户app在后台很可能被系统kill了,所以pay接口的callback就会失效,请商户对standbyCallback返回的回调结果进行处理,就是在这个方法里面处理跟callback一样的逻辑】
NSLog(@"result = %@",resultDic);
return YES;
需要提供公司资质或者营业执照,个人无法申请。
微信开放平台:
微信支付商户平台:
微信公众平台:
向微信注册你的应用程序id
开发者应用登记页面 进行登记,登记并选择移动应用进行设置后,将获得AppID,可立即用于开发。但应用登记完成后还需要提交审核,只有审核通过的应用才能正式发布使用。
微信APP支付接入商户服务中心
参考文档链接:
下载微信SDK文件,如果在项目中应使用SDK的最新版。
官方资源下载地址:
本Demo使用的SDK是从官方Demo整理出来的,整理的SDK版本:1.6.1。
下载地址:
目录结构如下:
├── SDKExport
├── WXApi.h
├── WXApiObject.h
├── libWeChatSDK.a
└── read_me.txt
└── lib
├── ApiXml.h
├── ApiXml.mm
├── WXUtil.h
├── WXUtil.mm
├── payRequsestHandler.h
└── payRequsestHandler.mm
SDKExport文件夹:SDK文件
lib文件夹:工具类
添加依赖库
SystemConfiguration.framework
libz.dylib
libsqlite3.dylib
libc++.dylib
CoreTelephony.framework
CoreGraphics.framework
在需要调用WeChatSDK的文件中,增加头文件引用。
#import "WXApi.h"
#import "payRequsestHandler.h"
生成订单信息及签名
#pragma mark - 微信支付
- (void)wechatPayAction:(UIButton *) sender
// 判断用户是否安装微信
if (![WXApi isWXAppInstalled]) {
UIAlertView * alertView = [[UIAlertView alloc] initWithTitle:@"提示" message:@"请安装微信客户端" delegate:nil cancelButtonTitle:@"确定" otherButtonTitles:nil];
[alertView show];
// 实现支付
[self sendPay_demo];
- (void)sendPay_demo
//本实例只是演示签名过程, 请将该过程在商户服务器上实现
// 配置微信支付的参数
//创建支付签名对象
payRequsestHandler *req = [[payRequsestHandler alloc] init];
//初始化支付签名对象
[req init:__WXappID mch_id:__WXmchID];
//设置密钥
[req setKey:__WXpaySignKey];
//获取到实际调起微信支付的参数后,在app端调起支付
NSMutableDictionary *dict = [req sendPay_demo];
if(dict == nil){
//错误提示
NSString *debug = [req getDebugifo];
[self alert:@"提示信息" msg:debug];
NSLog(@"%@\n\n",debug);
NSLog(@"%@\n\n",[req getDebugifo]);
//[self alert:@"确认" msg:@"下单成功,点击OK后调起支付!"];
NSMutableString *stamp
= [dict objectForKey:@"timestamp"];
//调起微信支付
PayReq* req
= [[PayReq alloc] init];
req.openID
= [dict objectForKey:@"appid"];
req.partnerId
= [dict objectForKey:@"partnerid"];
req.prepayId
= [dict objectForKey:@"prepayid"];
req.nonceStr
= [dict objectForKey:@"noncestr"];
req.timeStamp
= stamp.intV
req.package
= [dict objectForKey:@"package"];
= [dict objectForKey:@"sign"];
// 调用微信支付
[WXApi sendReq:req];
//客户端提示信息
- (void)alert:(NSString *)title msg:(NSString *)msg
UIAlertView *alter = [[UIAlertView alloc] initWithTitle:title message:msg delegate:nil cancelButtonTitle:@"OK" otherButtonTitles:nil];
[alter show];
Xcode设置URL scheme
在Xcode中,选择你的工程设置项,选中“TARGETS”一栏,在“info”标签栏的“URL type“添加“URL scheme”为你所注册的应用程序id(如下图所示)。
在你需要使用微信终端API的文件中import WXApi.h 头文件,并增加 WXApiDelegate 协议。
// 微信所有的API接口
#import "WXApi.h"
// APP端签名相关头文件
#import "payRequsestHandler.h"
@interface AppDelegate ()&WXApiDelegate&
要使你的程序启动后微信终端能响应你的程序,必须在代码中向微信终端注册你的id。(如下图所示,在 AppDelegate 的 didFinishLaunchingWithOptions 函数中向微信注册id)。
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// Override point for customization after application launch.
//向微信注册
[WXApi registerApp:APP_ID withDescription:@"demo 2.0"];
return YES;
重写AppDelegate的handleOpenURL和openURL方法:
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
return [WXApi handleOpenURL:url delegate:self];
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
return [WXApi handleOpenURL:url delegate:self];
现在,你的程序要实现和微信终端交互的具体请求与回应,因此需要实现WXApiDelegate协议的两个方法:
-(void) onReq:(BaseReq*)req
if([req isKindOfClass:[GetMessageFromWXReq class]])
// 微信请求App提供内容, 需要app提供内容后使用sendRsp返回
NSString * strTitle = [NSString stringWithFormat:@"微信请求App提供内容"];
NSString * strMsg = @"微信请求App提供内容,App要调用sendResp:GetMessageFromWXResp返回给微信";
UIAlertView * alert = [[UIAlertView alloc] initWithTitle:strTitle message:strMsg delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil, nil];
alert.tag = 1000;
[alert show];
else if([req isKindOfClass:[ShowMessageFromWXReq class]])
ShowMessageFromWXReq *
temp = (ShowMessageFromWXReq*)
WXMediaMessage * msg = temp.
//显示微信传过来的内容
WXAppExtendObject * obj = msg.mediaO
NSString * strTitle = [NSString stringWithFormat:@"微信请求App显示内容"];
NSString * strMsg = [NSString stringWithFormat:@"标题:%@ \n内容:%@ \n附带信息:%@ \n缩略图:%lu bytes\n\n", msg.title, msg.description, obj.extInfo, msg.thumbData.length];
UIAlertView * alert = [[UIAlertView alloc] initWithTitle:strTitle message:strMsg delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil, nil];
[alert show];
else if([req isKindOfClass:[LaunchFromWXReq class]])
//从微信启动App
NSString * strTitle = [NSString stringWithFormat:@"从微信启动"];
NSString * strMsg = @"这是从微信启动的消息";
UIAlertView * alert = [[UIAlertView alloc] initWithTitle:strTitle message:strMsg delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil, nil];
[alert show];
onReq是微信终端向第三方程序发起请求,要求第三方程序响应。第三方程序响应完后必须调用sendRsp返回。在调用sendRsp返回时,会切回到微信终端程序界面。
-(void) onResp:(BaseResp*)resp
NSString * strMsg = [NSString stringWithFormat:@"errcode:%d", resp.errCode];
NSString * strT
if([resp isKindOfClass:[SendMessageToWXResp class]])
strTitle = [NSString stringWithFormat:@"发送媒体消息结果"];
if([resp isKindOfClass:[PayResp class]]){
//支付返回结果,实际支付结果需要去微信服务器端查询
strTitle = [NSString stringWithFormat:@"支付结果"];
switch (resp.errCode) {
case WXSuccess:
strMsg = @"支付结果:成功!";
NSLog(@"支付成功-PaySuccess,retcode = %d", resp.errCode);
strMsg = [NSString stringWithFormat:@"支付结果:失败!retcode = %d, retstr = %@", resp.errCode,resp.errStr];
NSLog(@"错误,retcode = %d, retstr = %@", resp.errCode,resp.errStr);
UIAlertView * alert = [[UIAlertView alloc] initWithTitle:strTitle message:strMsg delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil, nil];
[alert show];
如果第三方程序向微信发送了sendReq的请求,那么onResp会被回调。sendReq请求调用后,会切到微信终端程序界面。
应用内购买(In-App Purchase)
在应用程序内购买虚拟商品。如果你在App Store上销售的应用程序,将收到支付金额的70%。
配置App ID
为应用建立建立一个不带通配符的App ID
用该App ID生成和安装相应的Provisioning Profile文件。
配置iTunes Connect
填写相关的税务,银行,联系人信息
参考链接:
添加一个用于在sandbox付费的测试用户
用该App ID创建一个新的应用。
创建应用内付费项目,选择付费类型。
App 内购买项目摘要填写
主要代码实现
在工程中引入 StoreKit.framework 和#import &StoreKit/StoreKit.h&
获得所有的付费Product ID列表。这个可以用常量存储在本地,也可以由自己的服务器返回。
//在内购项目中创建的商品单号
#define ProductID_IAP_FTHJ @"com.1000phone.IAPDemo.fthj_purple" // 方天画戟 488元
#define ProductID_IAP_XYJ @"com.1000phone.IAPDemo.xyj" // 轩辕剑 6,498元
#define ProductID_IAP_JB @"com.1000phone.IAPDemo.jb" // 金币 6元=6金币
制作界面,展示所有的应用内付费项目。这些应用内付费项目的价格和介绍信息可以从App Store服务器请求,也可以是自己的服务器返回。向App Store查询速度非常慢,通常需要2-3秒钟,最好从服务器请求。
- (void)createViews
NSArray * buttonNames = @[@"轩辕剑 6498元", @"方天画戟 488元", @"金币6元=6金币"];
__weak typeof(self) weakSelf =
[buttonNames enumerateObjectsUsingBlock:^(NSString * buttonName, NSUInteger idx, BOOL * stop) {
UIButton * button = [UIButton buttonWithType:UIButtonTypeSystem];
[weakSelf.view addSubview:button];
button.frame = CGRectMake(100, 100 + idx
* 60, 150, 50);
button.titleLabel.font = [UIFont systemFontOfSize:18];
[button setTitle:buttonName forState:UIControlStateNormal];
// 设置tag值
button.tag = PAY_BUTTON_BEGIN_TAG +
[button addTarget:self action:@selector(buyProduct:) forControlEvents:UIControlEventTouchUpInside];
- (void)buyProduct:(UIButton *) sender
当用户点击了一个IAP项目,我们先查询用户是否允许应用内付费。
- (void)buyProduct:(UIButton *) sender
self.buyType = sender.tag - PAY_BUTTON_BEGIN_TAG;
if ([SKPaymentQueue canMakePayments]) {
// 执行下面提到的第5步:
[self requestProductData];
NSLog(@"允许程序内付费购买");
NSLog(@"不允许程序内付费购买");
UIAlertView *alerView =
[[UIAlertView alloc] initWithTitle:@"提示"
message:@"您的手机没有打开程序内付费购买"
delegate:nil cancelButtonTitle:NSLocalizedString(@"关闭",nil) otherButtonTitles:nil];
[alerView show];
我们先通过该IAP的ProductID向AppStore查询,获得SKPayment实例,然后通过SKPaymentQueue的 addPayment方法发起一个购买的操作。
// 下面的ProductId应该是事先在itunesConnect中添加好的,已存在的付费项目。否则查询会失败。
- (void)requestProductData {
NSLog(@"---------请求对应的产品信息------------");
NSArray *product =
switch (self.buyType) {
product = [NSArray arrayWithObject:ProductID_IAP_XYJ];
product = [NSArray arrayWithObject:ProductID_IAP_FTHJ];
product = [NSArray arrayWithObject:ProductID_IAP_JB];
NSSet *nsset = [NSSet setWithArray:product];
SKProductsRequest *request=[[SKProductsRequest alloc] initWithProductIdentifiers: nsset];
request.delegate=
[request start];
#pragma mark - SKProductsRequestDelegate
// 收到的产品信息回调
- (void)productsRequest:(SKProductsRequest *)request didReceiveResponse:(SKProductsResponse *)response{
NSLog(@"-----------收到产品反馈信息--------------");
NSArray *myProduct = response.
if (myProduct.count == 0) {
NSLog(@"无法获取产品信息,购买失败。");
NSLog(@"产品Product ID:%@",response.invalidProductIdentifiers);
NSLog(@"产品付费数量: %d", (int)[myProduct count]);
// populate UI
for(SKProduct *product in myProduct){
NSLog(@"product info");
NSLog(@"SKProduct 描述信息%@", [product description]);
NSLog(@"产品标题 %@" , product.localizedTitle);
NSLog(@"产品描述信息: %@" , product.localizedDescription);
NSLog(@"价格: %@" , product.price);
NSLog(@"Product id: %@" , product.productIdentifier);
SKPayment * payment = [SKPayment paymentWithProduct:myProduct[0]];
NSLog(@"---------发送购买请求------------");
[[SKPaymentQueue defaultQueue] addPayment:payment];
//弹出错误信息
- (void)request:(SKRequest *)request didFailWithError:(NSError *)error{
NSLog(@"-------弹出错误信息----------");
UIAlertView *alerView =
[[UIAlertView alloc] initWithTitle:NSLocalizedString(@"Alert",NULL) message:[error localizedDescription]
delegate:nil cancelButtonTitle:NSLocalizedString(@"Close",nil) otherButtonTitles:nil];
[alerView show];
-(void) requestDidFinish:(SKRequest *)request
NSLog(@"----------反馈信息结束--------------");
在viewDidLoad方法中,将购买页面设置成购买的Observer。
- (void)viewDidLoad {
[super viewDidLoad];
[self createViews];
// 监听购买结果
[[SKPaymentQueue defaultQueue] addTransactionObserver:self];
- (void)dealloc
[[SKPaymentQueue defaultQueue] removeTransactionObserver:self];
当用户购买的操作有结果时,就会触发下面的回调函数,相应进行处理即可。
#pragma mark - SKPaymentTransactionObserver
// 处理交易结果
- (void)paymentQueue:(SKPaymentQueue *)queue updatedTransactions:(NSArray *)transactions {
for (SKPaymentTransaction *transaction in transactions)
switch (transaction.transactionState)
case SKPaymentTransactionStatePurchased://交易完成
NSLog(@"transactionIdentifier = %@", transaction.transactionIdentifier);
[self completeTransaction:transaction];
case SKPaymentTransactionStateFailed://交易失败
[self failedTransaction:transaction];
case SKPaymentTransactionStateRestored://已经购买过该商品
[self restoreTransaction:transaction];
case SKPaymentTransactionStatePurchasing:
//商品添加进列表
NSLog(@"商品添加进列表");
// 交易完成
- (void)completeTransaction:(SKPaymentTransaction *)transaction {
NSString * productIdentifier = transaction.payment.productI
NSString * receipt = [transaction.transactionReceipt base64EncodedString];
if ([productIdentifier length] & 0) {
// 向自己的服务器验证购买凭证
// Remove the transaction from the payment queue.
[[SKPaymentQueue defaultQueue] finishTransaction: transaction];
// 交易失败
- (void)failedTransaction:(SKPaymentTransaction *)transaction {
if(transaction.error.code != SKErrorPaymentCancelled) {
NSLog(@"购买失败");
NSLog(@"用户取消交易");
[[SKPaymentQueue defaultQueue] finishTransaction: transaction];
// 已购商品
- (void)restoreTransaction:(SKPaymentTransaction *)transaction {
// 对于已购商品,处理恢复购买的逻辑
[[SKPaymentQueue defaultQueue] finishTransaction: transaction];
服务器验证凭证(Optional)。如果购买成功,我们需要将凭证发送到服务器上进行验证。考虑到网络异常情况,iOS端的发送凭证操作应该进行持久化,如果程序退出,崩溃或网络异常,可以恢复重试。
苹果支付(? Pay)
苹果支付是一种在应用内运行的具有隐秘性和安全性非接触式的支付方式。它允许触摸付款,你可以用来购买实体商品和服务。
Apple 不会存储或共享客户的实际信用卡和借记卡卡号,因此商家和 App 开发者无需负责管理和保护实际的信用卡和借记卡卡号。
除了使用 PassKit 框架实施 Apple Pay 之外,您还必须:
通过设置一个帐户。
通过“”(“Certificates, Identifiers & Profiles”)注册一个商家 ID。
生成一个 ,用于加密和解密付款令牌。
在您的 App 中包括一个 Apple Pay 授权。
遵循“应用审核准则”的第 29 节中列出的要求。
遵循(“App Review Guidelines”)第 29 节中列出的要求。
? Pay VS In-App Purchase
In-App Purchase
实体商品(如食品杂货、服装和电器)和服务(如俱乐部会员、酒店预订和活动门票)
销售虚拟商品,如适用于您的 App 的优质内容及订阅数字内容;程序内的内容和功能性;程序内货币服务;数码订阅
自己的支付平台处理付款
苹果公司处理付款
我用日不弄怂的青春,书写怪米日眼的人生。
iOS支付 iOS支付分为两类,第三方支付和应用内支付(内购)。 第三方支付包括:支付宝支付、微信支付、银联支付、百度钱包、京东支付等等。 应用内支付(In-App Purchase):在应用程序内购买虚拟商品。如果你在App Store上销售的应用程序,将收到支付金额的7...
在我们应用开发中我们经常在自己的项目中使用到支付,下面我们来谈谈iOS这块的支付;iOS支付主要分为两类,第三方支付和应用内支付(内购);第三方支付包括:支付宝支付、微信支付、银联支付、百度钱包、京东支付等等。应用内支付(In-App- Purchase):在应用程序内购买...
iOS支付 iOS支付分为两类,第三方支付和应用内支付(内购)。 第三方支付包括:支付宝支付、微信支付、银联支付、百度钱包、京东支付等等。 应用内支付(In-App Purchase):在应用程序内购买虚拟商品。如果你在App Store上销售的应用程序,将收到支付金额的7...
最近实现了支付宝sdk导入的视线功能,那么现在就讲一下实现的整个流程。(其实并没有想象中那么难) 一:第一步 需要倒入第三方sdk的官方demo官方demo的下载地址: https://doc.open.alipay.com/docs/doc.htm?spm=a219a.7...
iOS支付 iOS支付分为两类,第三方支付和应用内支付(内购)。 第三方支付包括:支付宝支付、微信支付、银联支付、百度钱包、京东支付等等。 应用内支付(In-App Purchase):在应用程序内购买虚拟商品。如果你在App Store上销售的应用程序,将收到支付金额的7...
1 母亲说,当你真正的喜欢上一个男人的时候,只要他有担当,有血性,那么你就不要去衡量他现有的财富值是否配得上你的爱情,你甚至还要在他沮丧的时候安慰他:不要怕,对于一切,我陪你,从无到有。 九二年,国内经济萧条,乡下地方真正受过教育的人很少,像母亲这样受过正统教育的女孩子更为...
自2012年到2016年,电子商务市场呈现井喷式的发展态势,极大地促进了ERP行业的发展,ERP产商如雨后春笋,迅速生长。 那什么是ERP系统呢?所谓的ERP是Enterprise Resource Planning的缩写,是一套企业资源管理系统。ERP建立在信息技术基础上...
和师师认识快两天了,都没怎么说过话。 她邀我一起去放孔明灯,拖着从茶山下来还没缓解的疲惫,随之。 距离澜沧江边还有几百米,那点点星光,如萤火虫般,在夜空飘动。 少女心瞬间燃起,10元3个,路边买了孔明灯,大步流星的奔向目的地。 江边已经聚集了很多人,大都三两成群。 卖灯的、...
1.局部变量 定义在函数,代码块和函数形参列表中的变量,我们称之为局部变量 特点:1.相同的作用域范围内不能出现同名的局部变量 2.不同的作用域出现同名的局部变量,那么内部的局部变量会覆盖外部的局部变量 存储位置:局部变量存储在栈中,当作用域结束时系统会自动释放栈中的局部变...
日记日记就是要天天记,每每落下一天,就感觉自己欠了什么东西,心里放不下。祝福自己要天天坚持!}

我要回帖

更多关于 微信被骗红包能追回吗 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信