源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

iOS实现第三方微信登录方式实例解析(最新最全)

  • 时间:2021-08-21 09:23 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:iOS实现第三方微信登录方式实例解析(最新最全)
项目地址 : [url=https://github.com/zhonggaorong/weixinLoginDemo]https://github.com/zhonggaorong/weixinLoginDemo[/url] [b]最新版本的微信登录实现步骤实现:[/b] 1.在进行微信OAuth2.0授权登录接入之前,在微信开放平台注册开发者帐号,并拥有一个已审核通过的移动应用,并获得相应的AppID和AppSecret,申请微信登录且通过审核后,可开始接入流程。 地址: 点击打开链接 2. 下载最新的SDK 地址: [url=https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419319164&token=&lang=zh_CN]点击打开链接[/url] [img]http://files.jb51.net/file_images/article/201612/2016120716420243.jpg[/img] SDK内容如下: [img]http://files.jb51.net/file_images/article/201612/2016120716420244.jpg[/img] [b]结构解析:[/b] 从上到下依次说明: 1. 静态库,直接拖入工程。 2. ready.text自己看 3. 授权SDK。 4. 登录方法所在类。 5. 一些常用的对象类。 [b]iOS微信登录注意事项:[/b] 1、目前移动应用上微信登录只提供原生的登录方式,需要用户安装微信客户端才能配合使用。 2、对于Android应用,建议总是显示微信登录按钮,当用户手机没有安装微信客户端时,请引导用户下载安装微信客户端。 3、对于iOS应用,考虑到iOS应用商店审核指南中的相关规定,建议开发者接入微信登录时,先检测用户手机是否已安装微信客户端(使用sdk中isWXAppInstalled函数 ),对未安装的用户隐藏微信登录按钮,只提供其他登录方式(比如手机号注册登录、游客登录等)。 iOS微信登录大致流程: 1. 第三方发起微信授权登录请求,微信用户允许授权第三方应用后,微信会拉起应用或重定向到第三方网站,并且带上授权临时票据code参数; 2. 通过code参数加上AppID和AppSecret等,通过API换取access_token; 3. 通过access_token进行接口调用,获取用户基本数据资源或帮助用户实现基本操作。 示意图: [img]http://files.jb51.net/file_images/article/201612/2016120716420245.png[/img] [b]接下来就进入正题:[/b] [b]1.配置工程[/b] 1. 新建一个工程。 2. 把下载下来的sdk中的.h文件与静态库全部拖入工程。 3. 加入依赖库 [img]http://files.jb51.net/file_images/article/201612/2016120716420246.jpg[/img] 4. URL - Types (加入 appid) [img]http://files.jb51.net/file_images/article/201612/2016120716420247.jpg[/img] [code]target - Info - URL Types[/code] 5. 白名单 当程序出现此错误 -canOpenURL: failed for URL: "weixin://app/wx5efead4057f98bc0/" - error: "This app is not allowed to query for scheme weixin" 就说明没有针对iOS9 增加白名单。在info.plist文件中加入 LSApplicationQueriesSchemes [img]http://files.jb51.net/file_images/article/201612/2016120716420248.jpg[/img] App Transport Security 这个是让程序还是用http进行请求。 LSApplicationQueriesSchemes 这个是增加微信的白名单。 6. 现在编译应该是没有问题了。 [b]2. 终于到令人兴奋的代码部分了。 直接上代码。[/b]
// 
// AppDelegate.m 
// weixinLoginDemo 
// 
// Created by 张国荣 on 16/6/20. 
// Copyright © 2016年 BateOrganization. All rights reserved. 
// 
#import "AppDelegate.h" 
#import "WXApi.h" 
//微信开发者ID 
#define URL_APPID @"app id" 
@end 
@implementation AppDelegate 
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { 
//向微信注册应用。 
[WXApi registerApp:URL_APPID withDescription:@"wechat"]; 
return YES; 
} 
-(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString *,id> *)options{ 
/*! @brief 处理微信通过URL启动App时传递的数据 
* 
* 需要在 application:openURL:sourceApplication:annotation:或者application:handleOpenURL中调用。 
* @param url 微信启动第三方应用时传递过来的URL 
* @param delegate WXApiDelegate对象,用来接收微信触发的消息。 
* @return 成功返回YES,失败返回NO。 
*/ 
return [WXApi handleOpenURL:url delegate:self]; 
} 
/*! 微信回调,不管是登录还是分享成功与否,都是走这个方法 @brief 发送一个sendReq后,收到微信的回应 
* 
* 收到一个来自微信的处理结果。调用一次sendReq后会收到onResp。 
* 可能收到的处理结果有SendMessageToWXResp、SendAuthResp等。 
* @param resp具体的回应内容,是自动释放的 
*/ 
-(void) onResp:(BaseResp*)resp{ 
NSLog(@"resp %d",resp.errCode); 
/* 
enum WXErrCode { 
WXSuccess = 0, 成功 
WXErrCodeCommon = -1, 普通错误类型 
WXErrCodeUserCancel = -2, 用户点击取消并返回 
WXErrCodeSentFail = -3, 发送失败 
WXErrCodeAuthDeny = -4, 授权失败 
WXErrCodeUnsupport = -5, 微信不支持 
}; 
*/ 
if ([resp isKindOfClass:[SendAuthResp class]]) { //授权登录的类。 
if (resp.errCode == 0) { //成功。 
//这里处理回调的方法 。 通过代理吧对应的登录消息传送过去。 
if ([_wxDelegate respondsToSelector:@selector(loginSuccessByCode:)]) { 
SendAuthResp *resp2 = (SendAuthResp *)resp; 
[_wxDelegate loginSuccessByCode:resp2.code]; 
} 
}else{ //失败 
NSLog(@"error %@",resp.errStr); 
UIAlertView *alert = [[UIAlertView alloc]initWithTitle:@"登录失败" message:[NSString stringWithFormat:@"reason : %@",resp.errStr] delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil nil]; 
[alert show]; 
} 
} 
} 
@end
下面是登录的类。
// 
// ViewController.m 
// weixinLoginDemo 
// 
// Created by 张国荣 on 16/6/20. 
// Copyright © 2016年 BateOrganization. All rights reserved. 
// 
#import "ViewController.h" 
#import "WXApi.h" 
#import "AppDelegate.h" 
//微信开发者ID 
#define URL_APPID @"appid" 
#define URL_SECRET @"app secret" 
#import "AFNetworking.h" 
@interface ViewController ()<WXDelegate> 
{ 
AppDelegate *appdelegate; 
} 
@end 
@implementation ViewController 
- (void)viewDidLoad { 
[super viewDidLoad]; 
// Do any additional setup after loading the view, typically from a nib. 
} 
#pragma mark 微信登录 
- (IBAction)weixinLoginAction:(id)sender { 
if ([WXApi isWXAppInstalled]) { 
SendAuthReq *req = [[SendAuthReq alloc]init]; 
req.scope = @"snsapi_userinfo"; 
req.openID = URL_APPID; 
req.state = @"1245"; 
appdelegate = [UIApplication sharedApplication].delegate; 
appdelegate.wxDelegate = self; 
[WXApi sendReq:req]; 
}else{ 
//把微信登录的按钮隐藏掉。 
} 
} 
#pragma mark 微信登录回调。 
-(void)loginSuccessByCode:(NSString *)code{ 
NSLog(@"code %@",code); 
__weak typeof(*&self) weakSelf = self; 
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager]; 
manager.requestSerializer = [AFJSONRequestSerializer serializer];//请求 
manager.responseSerializer = [AFHTTPResponseSerializer serializer];//响应 
manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"text/html",@"application/json", @"text/json",@"text/plain", nil nil]; 
//通过 appid secret 认证code . 来发送获取 access_token的请求 
[manager GET:[NSString stringWithFormat:@"https://api.weixin.qq.com/sns/oauth2/access_token?appid=%@&secret=%@&code=%@&grant_type=authorization_code",URL_APPID,URL_SECRET,code] parameters:nil progress:^(NSProgress * _Nonnull downloadProgress) { 
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) { //获得access_token,然后根据access_token获取用户信息请求。 
NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil]; 
NSLog(@"dic %@",dic); 
/* 
access_token 接口调用凭证 
expires_in access_token接口调用凭证超时时间,单位(秒) 
refresh_token 用户刷新access_token 
openid 授权用户唯一标识 
scope 用户授权的作用域,使用逗号(,)分隔 
unionid 当且仅当该移动应用已获得该用户的userinfo授权时,才会出现该字段 
*/ 
NSString* accessToken=[dic valueForKey:@"access_token"]; 
NSString* openID=[dic valueForKey:@"openid"]; 
[weakSelf requestUserInfoByToken:accessToken andOpenid:openID]; 
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) { 
NSLog(@"error %@",error.localizedFailureReason); 
}]; 
} 
-(void)requestUserInfoByToken:(NSString *)token andOpenid:(NSString *)openID{ 
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager]; 
manager.requestSerializer = [AFJSONRequestSerializer serializer]; 
manager.responseSerializer = [AFHTTPResponseSerializer serializer]; 
[manager GET:[NSString stringWithFormat:@"https://api.weixin.qq.com/sns/userinfo?access_token=%@&openid=%@",token,openID] parameters:nil progress:^(NSProgress * _Nonnull downloadProgress) { 
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) { 
NSDictionary *dic = (NSDictionary *)[NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil]; 
NSLog(@"dic ==== %@",dic); 
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) { 
NSLog(@"error %ld",(long)error.code); 
}]; 
} 
- (void)didReceiveMemoryWarning { 
[super didReceiveMemoryWarning]; 
// Dispose of any resources that can be recreated. 
} 
@end
以上所述是小编给大家介绍的iOS实现第三方微信登录方式实例解析(最新最全),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部