if ([[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:weixin_location_url]]) {
成都創(chuàng)新互聯(lián)公司致力于互聯(lián)網(wǎng)品牌建設(shè)與網(wǎng)絡(luò)營銷,包括網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)、SEO優(yōu)化、網(wǎng)絡(luò)推廣、整站優(yōu)化營銷策劃推廣、電子商務(wù)、移動互聯(lián)網(wǎng)營銷等。成都創(chuàng)新互聯(lián)公司為不同類型的客戶提供良好的互聯(lián)網(wǎng)應(yīng)用定制及解決方案,成都創(chuàng)新互聯(lián)公司核心團(tuán)隊(duì)10多年專注互聯(lián)網(wǎng)開發(fā),積累了豐富的網(wǎng)站經(jīng)驗(yàn),為廣大企業(yè)客戶提供一站式企業(yè)網(wǎng)站建設(shè)服務(wù),在網(wǎng)站建設(shè)行業(yè)內(nèi)樹立了良好口碑。
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:weixin_location_url]];
}else{
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"http://weixin、qq、com/r/4HVfUETEcnoNh1UznyDE"]];
}
這個代碼是判斷機(jī)器是否安裝了該應(yīng)用,如果安裝了該應(yīng)用,就直接打開應(yīng)用,如果沒裝打開下載頁面。
兩個鏈接都需要自己賦值,另外要打開應(yīng)用的話鏈接應(yīng)該是該APP內(nèi)置支持的跳轉(zhuǎn)鏈接。
8月17日消息,騰訊QQ iOS測試版升級到8.8.20版本,部分用戶開始支持蘋果CallKit功能。
CallKit是iOS 10推出的開發(fā)框架,它能實(shí)現(xiàn)VoIP應(yīng)用程序集成到iPhone的用戶界面。比如在手機(jī)鎖屏狀態(tài)下,當(dāng)QQ發(fā)來語音或通話邀請,用戶可以像接聽電話那樣,在不比解鎖手機(jī)的情況下,直接接聽。
據(jù)了解,2018年開始國行蘋果手機(jī)取消了CallKit。QQ、微信等應(yīng)用也下架了相應(yīng)功能。
Snapchat的Call Kit功能
(7748349)
開啟了簡潔模式。
蘋果仍沒有宣布任何讓iPhone運(yùn)行Java的計(jì)劃。但太陽微系統(tǒng)已宣布其將會發(fā)布能在iPhone上運(yùn)行的Java虛擬機(jī)(JVM)的計(jì)劃,它是基于Java的Micro Edition版本。這將讓用Java應(yīng)用程序得以在iPhone和iPod Touch上運(yùn)行。
在這個計(jì)劃發(fā)表之后,熟悉iOS軟件開發(fā)協(xié)議的程序員們相信雖然iOS軟件開發(fā)協(xié)議不允許應(yīng)用程序后臺運(yùn)行(比如說在接電話的時候仍然運(yùn)行程序), 但卻允許自帶的應(yīng)用程序從其他的來源下載代碼,而且它們還能與第三方應(yīng)用程序相互作用(比如說Safari和Java虛擬機(jī)), 這可能會阻礙不與蘋果合作的Java虛擬機(jī)的發(fā)展。 很明顯,在iPhone運(yùn)行的Java在iOS軟件開發(fā)協(xié)議所規(guī)定的范疇以外。
使用一臺設(shè)備來繼續(xù)處理在其他設(shè)備上未完成的操作。許多Apple?app支持“接力”功能,如:“郵件”、Safari?瀏覽器、Pages?文稿、Numbers?表格、Keynote?講演、“地圖”、“信息”、“提醒事項(xiàng)”、“日歷”和“通訊錄”,甚至部分第三方app也支持。
即時聊天通用的協(xié)議是 XMPP,基于這個協(xié)議有一套java開源的服務(wù)端 openfire,可以快速的搭建一套即時聊天服務(wù)端。
但是現(xiàn)在有不少云即時通訊服務(wù)。例如
容聯(lián)云通訊、云之訊、環(huán)信、融云
這些云服務(wù)提供了api,我們基于他的api開發(fā)很容易實(shí)現(xiàn)自己的即時聊天軟件。服務(wù)端,服務(wù)器都不用我們自己管了,極大的節(jié)省了成本和開發(fā)周期。而且這些云服務(wù)基礎(chǔ)服務(wù)都是免費(fèi)的。
建議用第三方的云服務(wù)實(shí)現(xiàn)。
1.使用XMPPFramework前的準(zhǔn)備,獲取XmppStream和激活要用的組件,在AppDelegate添加代碼。以后要用xmppStream時,要通過AppDelegate獲取。下面的代碼是在AppDelegate.m中進(jìn)行的相關(guān)組件的初始化,代碼如下
(1)實(shí)例化XMPPStream
//創(chuàng)建xmppstream
self.xmppStream = [[XMPPStream alloc]init];
(2)創(chuàng)建重連組件,并在xmppStream中激活
1 //創(chuàng)建重寫連接組件
2 xmppReconnect= [[XMPPReconnect alloc] init];
3 //使組件生效
4 [xmppReconnect activate:self.xmppStream];
(3)創(chuàng)建message部分的內(nèi)容,接受的消息我們保存在本地?cái)?shù)據(jù)庫中,我們要顯示的時候是從數(shù)據(jù)庫中獲取的。在初始化消息組件的時候,要指定保存策略,一般可以選的是CoreData還是內(nèi)存。指定完保存策略后實(shí)例化Message是要關(guān)聯(lián)保存策略,之后也是需要在XMPPStream中進(jìn)行激活的,最后要獲取CoreData的上下文。代碼如下:
復(fù)制代碼
1 //創(chuàng)建消息保存策略(規(guī)則,規(guī)定)
2 messageStorage = [XMPPMessageArchivingCoreDataStorage sharedInstance];
3 //用消息保存策略創(chuàng)建消息保存組件
4 xmppMessageArchiving = [[XMPPMessageArchiving alloc]initWithMessageArchivingStorage:messageStorage];
5 //使組件生效
6 [xmppMessageArchiving activate:self.xmppStream];
7 //提取消息保存組件的coreData上下文
8 self.xmppManagedObjectContext = messageStorage.mainThreadManagedObjectContext;
復(fù)制代碼
(4),初始化獲取好友列表的相關(guān)組件并指定保存策略,和上面的代碼步驟極為相似。這也能看出來在XMPPFramework中進(jìn)行組件的初始化步驟是差不多的。下面我們設(shè)定自動獲取花名冊,代碼如下:
復(fù)制代碼
1 xmppRosterStorage = [[XMPPRosterCoreDataStorage alloc] init];
2 xmppRoster = [[XMPPRoster alloc] initWithRosterStorage:xmppRosterStorage];
3 //自動獲取用戶列表
4 xmppRoster.autoFetchRoster = YES;
5 xmppRoster.autoAcceptKnownPresenceSubscriptionRequests = YES;
6
7 [xmppRoster activate:self.xmppStream];
8 self.xmppRosterManagedObjectContext = xmppRosterStorage.mainThreadManagedObjectContext;
復(fù)制代碼
2.登陸模塊的實(shí)現(xiàn)
登陸時就是用戶輸入JID和Password,然后連接服務(wù)器和驗(yàn)證密碼,如果認(rèn)證成功則跳轉(zhuǎn)到好友列表才Controller,同時把JID和Password存儲到UserDefaults中便于下次自動連接。下面的代碼就是登陸部分的代碼(LoginViewController.m):
(1).通過應(yīng)用代理獲取XMPPStream,并注冊回調(diào),代碼如下:
復(fù)制代碼
1 -(void) initXmpp
2 {
3 //獲取應(yīng)用的xmppSteam(通過Application中的單例獲取)
4 UIApplication *application = [UIApplication sharedApplication];
5 id delegate = [application delegate];
6 self.xmppStream = [delegate xmppStream];
7
8 //注冊回調(diào)
9 [self.xmppStream addDelegate:self delegateQueue:dispatch_get_main_queue()];
10 }
復(fù)制代碼
(2).創(chuàng)建JID連接服務(wù)器
復(fù)制代碼
1 //連接服務(wù)器
2 -(void) xmppConnect
3 {
4 if (![self.userNameTextFiled.text isEqualToString:@""] self.userNameTextFiled.text != nil)
5 {
6 //1.創(chuàng)建JID
7 XMPPJID *jid = [XMPPJID jidWithUser:self.userNameTextFiled.text domain:MY_DOMAIN resource:@"iPhone"];
8
9 //2.把JID添加到xmppSteam中
10 [self.xmppStream setMyJID:jid];
11
12 //連接服務(wù)器
13 NSError *error = nil;
14 [self.xmppStream connectWithTimeout:10 error:error];
15 if (error)
16 {
17 NSLog(@"連接出錯:%@",[error localizedDescription]);
18 }
19
20 }
21 else
22 {
23 UIAlertView *alter = [[UIAlertView alloc] initWithTitle:@"提示" message:@"用戶名不能為空" delegate:nil cancelButtonTitle:@"取消" otherButtonTitles:nil];
24 [alter show];
25 }
26 }
復(fù)制代碼
(3).連接成后需要認(rèn)證密碼,代碼如下:
復(fù)制代碼
1 //連接后的回調(diào)
2 -(void)xmppStreamDidConnect:(XMPPStream *)sender
3 {
4 if (![self.passwordTextFiled.text isEqualToString:@""] self.passwordTextFiled.text != nil)
5 {
6 //連接成功后認(rèn)證用戶名和密碼
7 NSError *error = nil;
8 [self.xmppStream authenticateWithPassword:self.passwordTextFiled.text error:error];
9 if (error)
10 {
11 NSLog(@"認(rèn)證錯誤:%@",[error localizedDescription]);
12 }
13 }
14 else
15 {
16 UIAlertView *alter = [[UIAlertView alloc] initWithTitle:@"提示" message:@"密碼不能為空" delegate:self cancelButtonTitle:@"取消" otherButtonTitles:nil];
17 [alter show];
18 }
19 }
復(fù)制代碼
(4)密碼認(rèn)證成功后的回調(diào)
復(fù)制代碼
1 //認(rèn)證成功后的回調(diào)
2 -(void)xmppStreamDidAuthenticate:(XMPPStream *)sender
3 {
4 NSLog(@"登陸成功");
5
6 //密碼進(jìn)入userDefault
7 NSUserDefaults *userDefult = [NSUserDefaults standardUserDefaults];
8 [userDefult setObject:self.userNameTextFiled.text forKey:@"username"];
9 [userDefult setObject:self.passwordTextFiled.text forKey:@"password"];
10
11 //設(shè)置在線狀態(tài)
12 XMPPPresence * pre = [XMPPPresence presence];
13 [self.xmppStream sendElement:pre];
14
15 UIStoryboard *storybard = [UIStoryboard storyboardWithName:@"Main" bundle:[NSBundle mainBundle]];
16 UIViewController *viewController = [storybard instantiateViewControllerWithIdentifier:@"mainController"];
17 [self presentViewController:viewController animated:YES completion:^{
18 }];
19 }
復(fù)制代碼
(5)密碼認(rèn)證失敗后的回調(diào)
1 //認(rèn)證失敗的回調(diào)
2 -(void)xmppStream:sender didNotAuthenticate:(DDXMLElement *)error
3 {
4 NSLog(@"認(rèn)證失敗");
5 }
(6),二次登陸自動連接代碼:
復(fù)制代碼
1 // 如果已登錄就直接填充密碼登陸
2 NSUserDefaults *userDefult = [NSUserDefaults standardUserDefaults];
3
4 NSString *userName = [userDefult objectForKey:@"username"];
5 NSString *password = [userDefult objectForKey:@"password"];
6 NSLog(@"%@,%@",userName,password);
7 if (userName != nil password != nil ![userName isEqualToString:@""] ![password isEqualToString:@""])
8 {
9 self.userNameTextFiled.text = userName;
10 self.passwordTextFiled.text = password;
11 [self xmppConnect];
12 }
復(fù)制代碼
3.獲取好友列表的XMPPFramework的代碼實(shí)現(xiàn)
在獲取用戶列表的代碼中就會用到我們之前注冊的Roster的內(nèi)容,因?yàn)槲覀冊趯?shí)例化Roster的時候指定的保存策略是用CoreData進(jìn)行保存的,并且是自動獲取好友列表。所以在獲取好友列表的TableViewController中我們只需要通過CoreData來獲取好友列表即可。下面將給出獲取好友列表的核心代碼:
(1),獲取Roster對應(yīng)的上下文,用于獲取存儲在Roster相應(yīng)實(shí)體中的數(shù)據(jù)
1 //獲取Roster的上下文
2 UIApplication *application = [UIApplication sharedApplication];
3 id delegate = [application delegate];
4 self.xmppRosterManagedObjectContext = [delegate xmppRosterManagedObjectContext];
(2).獲取FetchRequst對象,并指定CoreData實(shí)體類,之后添加排序規(guī)則,代碼如下:
復(fù)制代碼
1 //從CoreData中獲取數(shù)據(jù)
2 //通過實(shí)體獲取FetchRequest實(shí)體
3 NSFetchRequest *request = [[NSFetchRequest alloc] initWithEntityName:NSStringFromClass([XMPPUserCoreDataStorageObject class])];
4 //添加排序規(guī)則
5 NSSortDescriptor * sortD = [NSSortDescriptor sortDescriptorWithKey:@"jidStr" ascending:YES];
6 [request setSortDescriptors:@[sortD]];
復(fù)制代碼
(3).獲取FetchedResultController并注冊回調(diào),用于自動刷新TableView,代碼如下:
1 //獲取FRC
2 self.fetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:request managedObjectContext:self.xmppRosterManagedObjectContext sectionNameKeyPath:nil cacheName:nil];
3 self.fetchedResultsController.delegate = self;
(4)獲取存儲的內(nèi)容
復(fù)制代碼
1
2 //獲取內(nèi)容
3 NSError * error;
4 ;
5 if (![self.fetchedResultsController performFetch:error])
6 {
7 NSLog(@"%s %@",__FUNCTION__,[error localizedDescription]);
8 }
復(fù)制代碼
至于如何在TableView上顯示FetchedResultController獲取的數(shù)據(jù),請參考之前的博客:IOS開發(fā)之表視圖愛上CoreData。
最近聯(lián)系人的代碼和歷史表情的代碼類似,請參考之前的博客:iOS開發(fā)之微信聊天工具欄的封裝
聊頁面的實(shí)現(xiàn)請參考之前的博客:iOS開發(fā)之微信聊天頁面實(shí)現(xiàn)
今天的XMPPFramework就先到這兒吧,內(nèi)容也挺多的了,其實(shí)XMPPFramework中的組件使用方法都差不多,首先第初始化內(nèi)存,然后進(jìn)行相關(guān)配置,在后就是在XMPPStream中激活,最后就是如何使用了。
作者:青玉伏案
在很多項(xiàng)目中都會使用第三方登錄,登錄方式大致都是QQ、微信、微博這三個爸爸。下面的文章將會簡單介紹一下個人在項(xiàng)目中集成QQ登錄與分享功能的流程以及在過程中遇到的問題。
開發(fā)時,我使用的是Xcode 8以及iOS 8+環(huán)境。
SDK中還可以實(shí)現(xiàn)其他功能,在這里不一一詳述,有需求大家可以仔細(xì)閱讀文檔,或者查看官方Demo中的API。
如有不正,感謝指出。
感謝開源?。。?/p>
網(wǎng)站名稱:qqios開發(fā),ios免費(fèi)下載
文章位置:http://weahome.cn/article/dsgccie.html