我正在开发基于XMPP的ios项目.我想发送消息,但我无法发送消息.表示接收方不会收到该消息.这是我的代码.
- (IBAction)sendMessageNow:(id)sender
{
NSString *messageStr =messageField.text;
if([messageStr length] > 0)
{
NSLog(@"Message sending fron Gmail");
NSXMLElement *body = [NSXMLElement elementWithName:@"body"];
[body setStringValue:messageStr];
NSXMLElement *message = [NSXMLElement elementWithName:@"message"];
[message addAttributeWithName:@"type" stringValue:@"chat"];
[message addAttributeWithName:@"to" stringValue:@"destination address"];
[message addChild:body];
NSLog(@"message1%@",message);
[[self appDelegate].xmppStream sendElement:message];
}
NSDate *date = [NSDate date];
NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
[formatter setDateFormat:@"hh:mm a"];
//[self sendMessage];
if ([self.messageField.text length]>0) {
if (isfromMe)
{
NSString *rowNum=[NSString stringWithFormat:@"%d",(int)sphBubbledata.count];
[self adddMediaBubbledata:kTextByme mediaPath:self.messageField.text mtime:[formatter stringFromDate:date] thumb:@"" downloadstatus:@"" sendingStatus:kSending msg_ID:[self genRandStringLength:7]];
[self performSelector:@selector(messageSent:) withObject:rowNum afterDelay:1];
isfromMe=NO;
}
else
{
[self adddMediaBubbledata:kTextByOther mediaPath:self.messageField.text mtime:[formatter stringFromDate:date] thumb:@"" downloadstatus:@"" sendingStatus:kSent msg_ID:[self genRandStringLength:7]];
isfromMe=YES;
}
self.messageField.text=@"";
[self.chattable reloadData];
[self scrollTableview];
}
}
Run Code Online (Sandbox Code Playgroud)
这是appdelegate.m中的senderdidreceivemessage方法
- (void)xmppStream:(XMPPStream *)sender didReceiveMessage:(XMPPMessage *)message
{
DDLogVerbose(@"%@: %@", THIS_FILE, THIS_METHOD);
[[self xmppStream] sendElement:message];
UILocalNotification *localNotification = [[UILocalNotification alloc] init];
localNotification.alertAction = @"OK";
localNotification.fireDate = [NSDate date];
// localNotification.alertBody = xmppmessage;
localNotification.soundName = UILocalNotificationDefaultSoundName;
[[UIApplication sharedApplication] presentLocalNotificationNow:localNotification];
// A simple example of inbound message handling.
if ([message isChatMessageWithBody])
{
XMPPUserCoreDataStorageObject *user = [xmppRosterStorage userForJID:[message from]
xmppStream:xmppStream
managedObjectContext:[self managedObjectContext_roster]];
NSString *body = [[message elementForName:@"body"] stringValue];
NSString *displayName = [user displayName];
if ([[UIApplication sharedApplication] applicationState] == UIApplicationStateActive)
{
UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:displayName
message:body
delegate:nil
cancelButtonTitle:@"Ok"
otherButtonTitles:nil];
[alertView show];
}
else
{
// We are not active, so use a local notification instead
UILocalNotification *localNotification = [[UILocalNotification alloc] init];
localNotification.alertAction = @"Ok";
localNotification.alertBody = [NSString stringWithFormat:@"From: %@\n\n%@",displayName,body];
[[UIApplication sharedApplication] presentLocalNotificationNow:localNotification];
}
}
}
Run Code Online (Sandbox Code Playgroud)
编辑
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *L_CellIdentifier = @"SPHTextBubbleCell";
static NSString *R_CellIdentifier = @"SPHMediaBubbleCell";
SPH_PARAM_List *feed_data=[[SPH_PARAM_List alloc]init];
feed_data=[sphBubbledata objectAtIndex:indexPath.row];
if ([feed_data.chat_media_type isEqualToString:kTextByme]||[feed_data.chat_media_type isEqualToString:kTextByOther])
{
SPHTextBubbleCell *cell = (SPHTextBubbleCell *) [tableView dequeueReusableCellWithIdentifier:L_CellIdentifier];
if (cell == nil)
{
cell = [[SPHTextBubbleCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:L_CellIdentifier];
}
XMPPUserCoreDataStorageObject *user = [[self fetchedResultsController] objectAtIndexPath:indexPath];
//cell.textLabel.text = user.displayName;
//[self configurePhotoForCell:cell user:user];
cell.bubbletype=([feed_data.chat_media_type isEqualToString:kTextByme])?@"LEFT":@"RIGHT";
cell.textLabel.text = user.displayName;
cell.textLabel.tag=indexPath.row;
cell.timestampLabel.text = @"02:20 AM";
cell.CustomDelegate=self;
cell.AvatarImageView.image=([feed_data.chat_media_type isEqualToString:kTextByme])?[UIImage imageNamed:@"ProfilePic"]:[UIImage imageNamed:@"person"];
// cell.AvatarImageView.image=[
[self configurePhotoForCell:cell user:user] ;
return cell;
}
SPHMediaBubbleCell *cell = (SPHMediaBubbleCell *) [tableView dequeueReusableCellWithIdentifier:R_CellIdentifier];
if (cell == nil)
{
cell = [[SPHMediaBubbleCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:R_CellIdentifier];
}
cell.bubbletype=([feed_data.chat_media_type isEqualToString:kImagebyme])?@"LEFT":@"RIGHT";
cell.textLabel.text = feed_data.chat_message;
cell.messageImageView.tag=indexPath.row;
cell.CustomDelegate=self;
cell.timestampLabel.text = @"02:20 AM";
cell.AvatarImageView.image=([feed_data.chat_media_type isEqualToString:kImagebyme])?[UIImage imageNamed:@"ProfilePic"]:[UIImage imageNamed:@"person"];
return cell;
}
Run Code Online (Sandbox Code Playgroud)
并配置照片方法
- (void)configurePhotoForCell:(UITableViewCell *)cell user:(XMPPUserCoreDataStorageObject *)user
{
// Our xmppRosterStorage will cache photos as they arrive from the xmppvCardAvatarModule.
// We only need to ask the avatar module for a photo, if the roster doesn't have it.
if (user.photo != nil)
{
cell.imageView.image = user.photo;
}
else
{
NSData *photoData = [[[self appDelegate] xmppvCardAvatarModule] photoDataForJID:user.jid];
if (photoData != nil)
cell.imageView.image = [UIImage imageWithData:photoData];
else
cell.imageView.image = [UIImage imageNamed:@"user2"];
}
}
Run Code Online (Sandbox Code Playgroud)
编辑
两者都是由我发送但它看起来在同一个窗口,当我点击一次发送按钮时,它在发送者消息中查找,第二次查看接收者消息.和接收者不会收到消息.

编辑
点击发送按钮后,这是响应.
功能: - [ChathistryViewController sendMessageNow:] line:414内容:Gmail功能发送消息: - [ChathistryViewController sendMessageNow:] line:421 content:message1ghfhxfghh 2015-06-12 13:03:22:071 projectname [7556:2f03] SEND :ghfhxfghh 2015-06-12 13:03:22:389 projectname [7556:7347] RECV:ghfhxfghh 2015-06-12 13:03:22:390 CloseChat [7556:2f03]发送:ghfhxfghh 2015-06-12 13 :03:22.393 projectname [7556:49110]试图安排本地通知{fire date =(null),time zone =(null),repeat interval = 0,repeat count = UILocalNotificationInfiniteRepeatCount,next fire date = Friday,June 12, 2015在1:03:22 PM印度标准时间,用户信息=(null)}声音但未获得用户播放声音的许可2015-06-12 13:03:22:697 CloseChat [7556: 7347] RECV:2015-06-12 13:03:23:004 projectname [7556:7347]发送:2015-06-12 13:03:23:004 projectname [7556:7347]发送:http:// etherx. jabber.org/streams'version ='1.0'to ='jwchat.org'> 2015-06-12 13:03:23:619 proje ctname [7556:7347] RECV:2015-06-12 13:03:23:619 projectname [7556:7347] RECV:2015-06-12 13:03:23:619 CloseChat [7556:7347]发送:2015- 06-12 13:03:23:925 projectname [7556:7347] RECV:2015-06-12 13:03:23:926 projectname [7556:7347]发送:http://etherx.jabber.org/streams' version ='1.0'to ='jwchat.org'> 2015-06-12 13:03:25:063 projectname [7556:7627] RECV:2015-06-12 13:03:25:064 projectname [7556:7347 ] RECV:PLAINDIGEST-MD5SCRAM-SHA-1 2015-06-12 13:03:25:065 CloseChat [7556:607]发送:biwsbj1jaGlyYWcscj1EMjUxMEQ2NC05MzZFLTQxMkUtQjY1Ri0zM0VFQjE1ODcxRjc = 2015-06-12 13:03:25:306 projectname [7556:7347] RECV:cj1EMjUxMEQ2NC05MzZFLTQxMkUtQjY1Ri0zM0VFQjE1ODcxRjdXVnB5eEp3b2lCRC9rUThvRkdhbGdRPT0scz1DZVZpSFFXNW9XRDVVNU90WUNMWExnPT0saT00MDk2 2015年6月12日13:03:25:321的projectname [7556:7347] SEND:Yz1iaXdzLHI9RDI1MTBENjQtOTM2RS00MTJFLUI2NUYtMzNFRUIxNTg3MUY3V1ZweXhKd29pQkQva1E4b0ZHYWxnUT09LHA9TWlsaW5TczI4b2VBd1dtQ3pWY21TWXZQWEFnPQ == 2015年6月12日13:03:25:562的projectname [7556:7627] RECV:dj1WeVdSaWRTTHVxYzhkV0E2 aEg3OW9mU0FpYmc9 2015-06-12 13:03:25:562 projectname [7556:7627]发送:http://etherx.jabber.org/streams'version ='1.0'to ='jwchat.org'> 2015-06- 12 13:03:25:871 projectname [7556:7627] RECV:2015-06-12 13:03:25:871 projectname [7556:7627] RECV:2015-06-12 13:03:25:872 projectname [ 7556:7627]发送:2015-06-12 13:03:26:178 projectname [7556:7347] RECV:chirag@jwchat.org/341204969114349440629043 2015-06-12 13:03:26:179 projectname [7556:7347 ]发送:2015-06-12 13:03:26:485 projectname [7556:7347] RECV:2015-06-12 13:03:26:486 projectname [7556:7627]发送:2015-06-12 13: 03:26:487 projectname [7556:7347]发送:2015-06-12 13:03:26:488 projectname [7556:7627]发送:2015-06-12 13:03:26:714 projectname [7556:7347 ] RECV:2015-06-12 13:03:26:946 projectname [7556:7347] RECV:2015-06-12 13:03:26:947 projectname [7556:6e13]发送:2015-06-12 13: 03:26:948 projectname [7556:6e13] RECV:2015-06-12 13:03:27:180 projectname [7556:7627] RECV:
| 归档时间: |
|
| 查看次数: |
1426 次 |
| 最近记录: |