友盟分享
-
首先注冊友盟賬號 SDK下載
- 友盟個人中心中創(chuàng)建一個應(yīng)用程序
- 新建項目 將友盟的庫拖入工程中
- 配置項目環(huán)境跟添加需要的第三方庫
- 在 AppDelegate文件內(nèi)設(shè)置你的AppKey:
#import "UMSocial.h"
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
[UMSocialData setAppKey:@"507fcab25270157b37000010"];
}
- 在你的控制器View添加分享按鈕 關(guān)聯(lián)Action
- 在分享的方法里實現(xiàn)代碼
#import "UMSocial.h"
[UMSocialData defaultData].extConfig.title = @"友盟分享測試";
// 這里設(shè)置是點擊微信分享的內(nèi)容進(jìn)入的URL
[UMSocialData defaultData].extConfig.wechatSessionData.url = @"http://www.chemayi.com";
/**
* self代表在哪個控制器彈出默認(rèn)的分享界面
*/
[UMSocialSnsService presentSnsIconSheetView:self // 在哪個控制器的View顯示分享
appKey:@"5762b194e0f55a8a740001a5"
shareText:@"人生要有要有夢想"
shareImage:[UIImage imageNamed:@"1"]
shareToSnsNames:@[UMShareToWechatSession,UMShareToWechatTimeline,UMShareToSina,UMShareToQQ,UMShareToQzone, UMShareToEmail,UMShareToQQ, UMShareToFacebook, UMShareToYXSession, UMShareToLWSession, UMShareToAlipaySession, UMShareToDouban]
delegate:nil];
}
注意: 默認(rèn)情況下微信跟朋友圈一些分享圖標(biāo)是不會顯示出來的
通常點擊彈出對應(yīng)的分享的icon后,進(jìn)入時一個webView,也就是需要OAuth2.0授權(quán),需要用戶輸入賬戶名跟密碼進(jìn)行授權(quán),但是目前一般App很少直接讓用戶輸入密碼跟賬號,都是采取SSO授權(quán)
SSO授權(quán)
本質(zhì)還是OAuth2.0 例如我們微信分享,當(dāng)用戶手機(jī)上已將安裝微信客戶端以后,點擊微信分享后,自動通過已登錄的微信賬號進(jìn)行授權(quán)分享
-
SSO授權(quán)通常配置的步驟(額外需要添加的步驟)
- 拿新浪微博舉例
解壓下載文件夾圾亏,將SinaSSO文件夾添加到工程译荞。
在other linker flags增加-ObjC 選項岩睁,并添加ImageIO 系統(tǒng)framework
-
配置URL schemes
- 在你的工程設(shè)置項,targets 一欄下,選中自己的 target,在 Info->URL Types 中添加 URL Schemes,格式為“wb”+新浪appkey澄惊,例如“wb126663232”
- 配置微博APPkey
#import "UMSocialSinaSSOHandler.h"
//第一個參數(shù)為新浪appkey,第二個參數(shù)為新浪secret世分,第三個參數(shù)是新浪微博回調(diào)地址岛马,這里必須要和你在新浪微博后臺設(shè)置的回調(diào)地址一致。
[UMSocialSinaSSOHandler openNewSinaSSOWithAppKey:@"3921700954"
secret:@"04b48b094faeb16683c32669824ebdad"
RedirectURL:@"http://sns.whalecloud.com/sina2/callback"];
注意: 回調(diào)URL必須和后臺保持一致届案,否則會返回錯誤碼21322
- 添加系統(tǒng)回調(diào)
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
BOOL result = [UMSocialSnsService handleOpenURL:url];
if (result == FALSE) {
//調(diào)用其他SDK庵楷,例如支付寶SDK等
}
return result;
}
- 這樣配置以后,我們在點擊分享就直接進(jìn)入新浪客戶端
微信分享
- 注冊微信平臺賬號(需要審核)
- 管理賬號
- 點擊查看
- 添加相關(guān)文件
- 添加SDK依賴的系統(tǒng)庫文件。(如果已經(jīng)添加過就不需要添加了)
- 在新發(fā)布的iOS9系統(tǒng)上圍繞用戶數(shù)據(jù)的安全性和體驗新增了一些安全特性楣颠,同時也影響了應(yīng)用的實現(xiàn)以及集成方式尽纽,為了保證良好的穩(wěn)定性和體驗,需要做如下處理:
- 以iOS9 SDK編譯的工程會默認(rèn)以SSL安全協(xié)議進(jìn)行網(wǎng)絡(luò)傳輸童漩,即HTTPS弄贿,如果依然使用HTTP協(xié)議請求網(wǎng)絡(luò)會報系統(tǒng)異常并中斷請求。目前可用如下兩種方式保持用HTTP進(jìn)行網(wǎng)絡(luò)連接:
- A矫膨、在info.plist中加入安全域名白名單(右鍵info.plist用source code打開)
<key>NSAppTransportSecurity</key>
<dict>
<key>NSExceptionDomains</key>
<dict>
<key>log.umsns.com</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSTemporaryExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSTemporaryExceptionMinimumTLSVersion</key>
<string>TLSv1.1</string>
</dict>
<key>sns.whalecloud.com</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSTemporaryExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSTemporaryExceptionMinimumTLSVersion</key>
<string>TLSv1.1</string>
</dict>
<!-- 集成新浪微博對應(yīng)的HTTP白名單-->
<key>sina.cn</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<key>weibo.cn</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<key>weibo.com</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<key>sinaimg.cn</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<key>sinajs.cn</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<key>sina.com.cn</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<!-- 新浪微博-->
<!-- 集成微信差凹、QQ、Qzone豆拨、騰訊微博授權(quán)對應(yīng)的HTTP白名單-->
<key>qq.com</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<!-- 騰訊授權(quán)-->
<!-- 集成人人授權(quán)對應(yīng)的HTTP白名單-->
<key>renren.com</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
<true/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<!-- 人人授權(quán)-->
<!-- 集成Facebook授權(quán)對應(yīng)的HTTP白名單-->
<key>facebook.com</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<key>fbcdn.net</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<key>akamaihd.net</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<!-- Facebook授權(quán)-->
<!-- 集成Twitter授權(quán)對應(yīng)的HTTP白名單-->
<key>twitter.com</key>
<dict>
<key>NSIncludesSubdomains</key>
<true/>
<key>NSExceptionRequiresForwardSecrecy</key>
<false/>
</dict>
<!-- Twitter授權(quán)-->
</dict>
</dict>
注:以上部分平臺官方未給出相應(yīng)白名單直奋,由技術(shù)人員測試各個平臺所收集而來,如果有所遺漏施禾,請自行加入并向客服說明脚线,我們會進(jìn)一步補(bǔ)充名單。
- B弥搞、在info.plist的NSAppTransportSecurity下新增NSAllowsArbitraryLoads并設(shè)置為YES邮绿,指定所有HTTP連接都可正常請求
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
- 應(yīng)用跳轉(zhuǎn)(SSO等)
- 如果你的應(yīng)用使用了如SSO授權(quán)登錄或跳轉(zhuǎn)分享功能,在iOS9下就需要增加一個可跳轉(zhuǎn)的白名單攀例,指定對應(yīng)跳轉(zhuǎn)App的URL Scheme船逮,否則將在第三方平臺判斷是否跳轉(zhuǎn)時用到的canOpenURL時返回NO,進(jìn)而只進(jìn)行webview授權(quán)或授權(quán)/分享失敗粤铭。
- 同樣在info.plist增加:
<key>LSApplicationQueriesSchemes</key>
<array>
<!-- 微信 URL Scheme 白名單-->
<string>wechat</string>
<string>weixin</string>
<!-- 新浪微博 URL Scheme 白名單-->
<string>sinaweibohd</string>
<string>sinaweibo</string>
<string>sinaweibosso</string>
<string>weibosdk</string>
<string>weibosdk2.5</string>
<!-- QQ挖胃、Qzone URL Scheme 白名單-->
<string>mqqapi</string>
<string>mqq</string>
<string>mqqOpensdkSSoLogin</string>
<string>mqqconnect</string>
<string>mqqopensdkdataline</string>
<string>mqqopensdkgrouptribeshare</string>
<string>mqqopensdkfriend</string>
<string>mqqopensdkapi</string>
<string>mqqopensdkapiV2</string>
<string>mqqopensdkapiV3</string>
<string>mqzoneopensdk</string>
<string>wtloginmqq</string>
<string>wtloginmqq2</string>
<string>mqqwpa</string>
<string>mqzone</string>
<string>mqzonev2</string>
<string>mqzoneshare</string>
<string>wtloginqzone</string>
<string>mqzonewx</string>
<string>mqzoneopensdkapiV2</string>
<string>mqzoneopensdkapi19</string>
<string>mqzoneopensdkapi</string>
<string>mqqbrowser</string>
<string>mttbrowser</string>
<!-- 支付寶 URL Scheme 白名單-->
<string>alipay</string>
<string>alipayshare</string>
<!-- 人人 URL Scheme 白名單-->
<string>renrenios</string>
<string>renrenapi</string>
<string>renren</string>
<string>renreniphone</string>
<!-- 來往 URL Scheme 白名單-->
<string>laiwangsso</string>
<!-- 易信 URL Scheme 白名單-->
<string>yixin</string>
<string>yixinopenapi</string>
<!-- instagram URL Scheme 白名單-->
<string>instagram</string>
<!-- whatsapp URL Scheme 白名單-->
<string>whatsapp</string>
<!-- line URL Scheme 白名單-->
<string>line</string>
<!-- Facebook URL Scheme 白名單-->
<string>fbapi</string>
<string>fb-messenger-api</string>
<string>fbauth2</string>
<string>fbshareextension</string>
</array>
注:以上部分平臺官方未給出相應(yīng)白名單,由技術(shù)人員測試各個平臺所收集而來,如果有所遺漏酱鸭,請自行加入并向客服說明吗垮,我們會進(jìn)一步補(bǔ)充名單。
- 應(yīng)用瘦身(App Thining)
iOS9 SDK新增了對App瘦身的功能凹髓,詳情見App Thining烁登。目前各個第三方平臺正在進(jìn)行App thining的支持,所以為了正常使用第三方SDK及分享SDK蔚舀,需要在Build Setting中將Enable bitcode關(guān)閉,或設(shè)置編譯標(biāo)識ENABLE_BITCODE=NO饵沧。
注:bitcode僅在Xcode7以上顯示并默認(rèn)開啟。
- 在你的程序APPdelegate入口方法添加下面的代碼
//設(shè)置微信AppId赌躺、appSecret狼牺,分享url
[UMSocialWechatHandler setWXAppId:@"wxe030296d5c5968b4" appSecret:@"0cde569ce201db3701b558fd2405ec0b" url:@"http://www.hao123.com"];
return YES;
- 注意:如果不添加上面的代碼,則分享列表中不會出現(xiàn)微信及朋友圈圖標(biāo)
- URL必須為http鏈接
- 配置URL schemes
- 添加系統(tǒng)回調(diào)
- 在APPdelegate中實現(xiàn)下面兩個系統(tǒng)回調(diào)方法:
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
BOOL result = [UMSocialSnsService handleOpenURL:url];
if (result == FALSE) {
//調(diào)用其他SDK寿谴,例如支付寶SDK等
}
return result;
}
- ViewController.m
- (void)viewDidLoad {
[super viewDidLoad];
}
- (IBAction)share:(id)sender {
[UMSocialData defaultData].extConfig.title = @"友盟分享測試";
[UMSocialData defaultData].extConfig.wechatSessionData.url = @"http://www.chemayi.com";
/**
* self代表在哪個控制器彈出默認(rèn)的分享界面
*/
[UMSocialSnsService presentSnsIconSheetView:self // 在哪個控制器的View顯示分享
appKey:@"5762b194e0f55a8a740001a5"
shareText:@"人生要有要有夢想"
shareImage:[UIImage imageNamed:@"1"]
shareToSnsNames:@[UMShareToWechatSession,UMShareToWechatTimeline,UMShareToSina,UMShareToQQ,UMShareToQzone, UMShareToEmail,UMShareToQQ, UMShareToFacebook, UMShareToYXSession, UMShareToLWSession, UMShareToAlipaySession, UMShareToDouban]
delegate:nil];
}
@end