亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

iOS實現(xiàn)第三方微信登錄方式實例解析(最新最全)

 更新時間:2016年12月07日 16:41:37   作者:iOS_developer_zhong  
這篇文章主要介紹了iOS實現(xiàn)第三方微信登錄方式實例解析(最新最全),非常不錯,具有參考借鑒價值,需要的朋友可以參考下

項目地址 : https://github.com/zhonggaorong/weixinLoginDemo

最新版本的微信登錄實現(xiàn)步驟實現(xiàn):

1.在進行微信OAuth2.0授權(quán)登錄接入之前,在微信開放平臺注冊開發(fā)者帳號,并擁有一個已審核通過的移動應(yīng)用,并獲得相應(yīng)的AppID和AppSecret,申請微信登錄且通過審核后,可開始接入流程。 地址: 點擊打開鏈接

2. 下載最新的SDK 地址: 點擊打開鏈接

SDK內(nèi)容如下:

結(jié)構(gòu)解析:

從上到下依次說明:

1. 靜態(tài)庫,直接拖入工程。

2. ready.text自己看

3. 授權(quán)SDK。

4. 登錄方法所在類。

5. 一些常用的對象類。

iOS微信登錄注意事項:

1、目前移動應(yīng)用上微信登錄只提供原生的登錄方式,需要用戶安裝微信客戶端才能配合使用。

2、對于Android應(yīng)用,建議總是顯示微信登錄按鈕,當(dāng)用戶手機沒有安裝微信客戶端時,請引導(dǎo)用戶下載安裝微信客戶端。

3、對于iOS應(yīng)用,考慮到iOS應(yīng)用商店審核指南中的相關(guān)規(guī)定,建議開發(fā)者接入微信登錄時,先檢測用戶手機是否已安裝微信客戶端(使用sdk中isWXAppInstalled函數(shù) ),對未安裝的用戶隱藏微信登錄按鈕,只提供其他登錄方式(比如手機號注冊登錄、游客登錄等)。

iOS微信登錄大致流程:

1. 第三方發(fā)起微信授權(quán)登錄請求,微信用戶允許授權(quán)第三方應(yīng)用后,微信會拉起應(yīng)用或重定向到第三方網(wǎng)站,并且?guī)鲜跈?quán)臨時票據(jù)code參數(shù);

2. 通過code參數(shù)加上AppID和AppSecret等,通過API換取access_token;

3. 通過access_token進行接口調(diào)用,獲取用戶基本數(shù)據(jù)資源或幫助用戶實現(xiàn)基本操作。

示意圖:

接下來就進入正題:

1.配置工程

1. 新建一個工程。

2. 把下載下來的sdk中的.h文件與靜態(tài)庫全部拖入工程。

3. 加入依賴庫

4. URL - Types (加入 appid)

target - Info - URL Types

5. 白名單

當(dāng)程序出現(xiàn)此錯誤

-canOpenURL: failed for URL: "weixin://app/wx5efead4057f98bc0/" - error: "This app is not allowed to query for scheme weixin"

就說明沒有針對iOS9 增加白名單。在info.plist文件中加入 LSApplicationQueriesSchemes

App Transport Security 這個是讓程序還是用http進行請求。

LSApplicationQueriesSchemes 這個是增加微信的白名單。

6. 現(xiàn)在編譯應(yīng)該是沒有問題了。

2. 終于到令人興奮的代碼部分了。 直接上代碼。

// 
// AppDelegate.m 
// weixinLoginDemo 
// 
// Created by 張國榮 on 16/6/20. 
// Copyright © 2016年 BateOrganization. All rights reserved. 
// 
#import "AppDelegate.h" 
#import "WXApi.h" 
//微信開發(fā)者ID 
#define URL_APPID @"app id" 
@end 
@implementation AppDelegate 
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { 
//向微信注冊應(yīng)用。 
[WXApi registerApp:URL_APPID withDescription:@"wechat"]; 
return YES; 
} 
-(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString *,id> *)options{ 
/*! @brief 處理微信通過URL啟動App時傳遞的數(shù)據(jù) 
* 
* 需要在 application:openURL:sourceApplication:annotation:或者application:handleOpenURL中調(diào)用。 
* @param url 微信啟動第三方應(yīng)用時傳遞過來的URL 
* @param delegate WXApiDelegate對象,用來接收微信觸發(fā)的消息。 
* @return 成功返回YES,失敗返回NO。 
*/ 
return [WXApi handleOpenURL:url delegate:self]; 
} 
/*! 微信回調(diào),不管是登錄還是分享成功與否,都是走這個方法 @brief 發(fā)送一個sendReq后,收到微信的回應(yīng) 
* 
* 收到一個來自微信的處理結(jié)果。調(diào)用一次sendReq后會收到onResp。 
* 可能收到的處理結(jié)果有SendMessageToWXResp、SendAuthResp等。 
* @param resp具體的回應(yīng)內(nèi)容,是自動釋放的 
*/ 
-(void) onResp:(BaseResp*)resp{ 
NSLog(@"resp %d",resp.errCode); 
/* 
enum WXErrCode { 
WXSuccess = 0, 成功 
WXErrCodeCommon = -1, 普通錯誤類型 
WXErrCodeUserCancel = -2, 用戶點擊取消并返回 
WXErrCodeSentFail = -3, 發(fā)送失敗 
WXErrCodeAuthDeny = -4, 授權(quán)失敗 
WXErrCodeUnsupport = -5, 微信不支持 
}; 
*/ 
if ([resp isKindOfClass:[SendAuthResp class]]) { //授權(quán)登錄的類。 
if (resp.errCode == 0) { //成功。 
//這里處理回調(diào)的方法 。 通過代理吧對應(yīng)的登錄消息傳送過去。 
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" 
//微信開發(fā)者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 微信登錄回調(diào)。 
-(void)loginSuccessByCode:(NSString *)code{ 
NSLog(@"code %@",code); 
__weak typeof(*&self) weakSelf = self; 
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager]; 
manager.requestSerializer = [AFJSONRequestSerializer serializer];//請求 
manager.responseSerializer = [AFHTTPResponseSerializer serializer];//響應(yīng) 
manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"text/html",@"application/json", @"text/json",@"text/plain", nil nil]; 
//通過 appid secret 認證code . 來發(fā)送獲取 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,然后根據(jù)access_token獲取用戶信息請求。 
NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil]; 
NSLog(@"dic %@",dic); 
/* 
access_token 接口調(diào)用憑證 
expires_in access_token接口調(diào)用憑證超時時間,單位(秒) 
refresh_token 用戶刷新access_token 
openid 授權(quán)用戶唯一標(biāo)識 
scope 用戶授權(quán)的作用域,使用逗號(,)分隔 
unionid 當(dāng)且僅當(dāng)該移動應(yīng)用已獲得該用戶的userinfo授權(quán)時,才會出現(xiàn)該字段 
*/ 
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實現(xiàn)第三方微信登錄方式實例解析(最新最全),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • iOS中block的定義與使用

    iOS中block的定義與使用

    蘋果官方文檔聲明,block是objc對象。下面這篇文章主要給大家介紹了關(guān)于iOS中block的定義與使用,文中通過示例代碼介紹的非常詳細,對各位iOS開發(fā)者具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • iOS中設(shè)置view圓角化的四種方法示例

    iOS中設(shè)置view圓角化的四種方法示例

    最近因為工作的原因,遇到view圓角優(yōu)化的問題,所以將實現(xiàn)的幾種方法總結(jié)分享出來,下面這篇文章主要給大家介紹了關(guān)于iOS中設(shè)置view圓角化的四種方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • iOS 將系統(tǒng)自帶的button改裝成上圖片下文字的樣子

    iOS 將系統(tǒng)自帶的button改裝成上圖片下文字的樣子

    這篇文章主要介紹了 iOS 將系統(tǒng)自帶的button改裝成上圖片下文字的樣子,代碼是通過繼承UIButton,然后再重寫layoutSubviews方法,對自帶的圖片和titleLabel進行重新的layout。下面通過本文給大家分享下實現(xiàn)代碼
    2016-12-12
  • iOS block循環(huán)引用詳解及常見誤區(qū)

    iOS block循環(huán)引用詳解及常見誤區(qū)

    這篇文章主要介紹了iOS block循環(huán)引用詳解和應(yīng)用,常見誤區(qū)詳解,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2021-08-08
  • IOS 中UIImageView響應(yīng)點擊事件

    IOS 中UIImageView響應(yīng)點擊事件

    這篇文章主要介紹了IOS 中UIImageView響應(yīng)點擊事件的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下
    2017-09-09
  • iOS常見宏理解及使用方法

    iOS常見宏理解及使用方法

    這篇文章主要給大家介紹了關(guān)于iOS常見宏理解及使用方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Swift和Objective-C 混編注意事項

    Swift和Objective-C 混編注意事項

    這篇文章主要介紹了Swift和Objective-C 混編注意事項的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • iOS自定義UICollectionViewLayout實現(xiàn)瀑布流布局

    iOS自定義UICollectionViewLayout實現(xiàn)瀑布流布局

    這篇文章主要為大家詳細介紹了iOS自定義UICollectionViewLayout實現(xiàn)瀑布流布局,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • iOS實現(xiàn)水平方向瀑布流

    iOS實現(xiàn)水平方向瀑布流

    這篇文章主要為大家詳細介紹了iOS實現(xiàn)水平方向瀑布流的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • iOS開發(fā)中class和#import的區(qū)別介紹

    iOS開發(fā)中class和#import的區(qū)別介紹

    這篇文章主要介紹了iOS開發(fā)中class和#import的區(qū)別,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2018-02-02

最新評論