3

そのため、コンパイルして実行中の Siphon アプリがありますが、呼び出しが行われません。私は得る:

登録エラー - デフォルトのエラー メッセージ。

完全なエラーは次のとおりです。

15:04:02.032 pjsua_call.c acc #0 で sip:6476805821@voip5-2.acanac.com に電話をかけています 15:04:02.032 pjsua_call.c .アカウントが無効なため電話をかけられません: 無効な操作 (PJ_EINVALIDOP) [status=70013] 15:04:05.580 call.m 発信エラー: 無効な操作 (PJ_EINVALIDOP) [status=70013]

しかし、別の SIP アプリで同じアカウントを使用すると、問題なく動作します。

pjsip が sip_dial_with_uri(_sip_acc_id, [url UTF8String], &call_id); を呼び出すと、

_sip_acc_id は 0 です。これは、サイフォンの設定にある 0 番目のアカウントだと思われるためです。url は、ダイヤルしようとしている正しい電話番号ですが、sip:62304892@url.com のようなものを示しています。また、通話 ID は単なる参照であるため、重要かどうかはわかりません。

他の voip アプリを見ると、登録プロセスがあります。ユーザー名、パスワード、sip サーバーのドメインまたは IP を入力する場所。

Siphon の場合、これは設定ファイルで行われます。ただし、「登録またはログイン」がサイフォンのコードで行われるかどうかはわかりません。それが問題でしょうか?

これは、実際の呼び出しを試みるコードです。

/** FIXME plutôt à mettre dans l'objet qui gère les appels **/
-(void) dialup:(NSString *)phoneNumber number:(BOOL)isNumber
{
  pjsua_call_id call_id;
  pj_status_t status;
  NSString *number;

  UInt32 hasMicro, size;

  // Verify if microphone is available (perhaps we should verify in another place ?)
  size = sizeof(hasMicro);
  AudioSessionGetProperty(kAudioSessionProperty_AudioInputAvailable,
                          &size, &hasMicro);
  /*if (!hasMicro)
  {
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:NSLocalizedString(@"No Microphone Available", @"SiphonApp")
                                                    message:NSLocalizedString(@"Connect a microphone to phone", @"SiphonApp")
                                                   delegate:nil 
                                          cancelButtonTitle:NSLocalizedString(@"OK", @"SiphonApp")
                                          otherButtonTitles:nil];
    [alert show];
    [alert release];
    return;
  }*/

  if (isNumber)
    number = [self normalizePhoneNumber:phoneNumber];
  else
    number = phoneNumber;

  if ([[NSUserDefaults standardUserDefaults] boolForKey:@"removeIntlPrefix"])
  {
    number = [number stringByReplacingOccurrencesOfString:@"+"
                                               withString:@"" 
                                                     options:0 
                                                       range:NSMakeRange(0,1)];
  }
  else
  {
  NSString *prefix = [[NSUserDefaults standardUserDefaults] stringForKey:
                      @"intlPrefix"];
  if ([prefix length] > 0)
  {
    number = [number stringByReplacingOccurrencesOfString:@"+"
                                                   withString:prefix 
                                                      options:0 
                                                        range:NSMakeRange(0,1)];
  }
  }

  // Manage pause symbol
  NSArray * array = [number componentsSeparatedByString:@","];
  [callViewController setDtmfCmd:@""];
  if ([array count] > 1)
  {
    number = [array objectAtIndex:0];
    [callViewController setDtmfCmd:[array objectAtIndex:1]];
  }

  if (!isConnected && [self wakeUpNetwork] == NO)
  {
    _phoneNumber = [[NSString stringWithString: number] retain];
    if (isIpod)
    {
      UIAlertView *alertView = [[[UIAlertView alloc] initWithTitle:nil 
                                                           message:NSLocalizedString(@"You must enable Wi-Fi or SIP account to place a call.",@"SiphonApp") 
                                                          delegate:nil 
                                                 cancelButtonTitle:NSLocalizedString(@"OK",@"SiphonApp")
                                                 otherButtonTitles:nil] autorelease];
      [alertView show];
    }
    else
    {
      UIActionSheet *actionSheet = [[[UIActionSheet alloc] initWithTitle:NSLocalizedString(@"The SIP server is unreachable!",@"SiphonApp") 
                                                               delegate:self 
                                                      cancelButtonTitle:NSLocalizedString(@"Cancel",@"SiphonApp") 
                                                 destructiveButtonTitle:nil 
                                                      otherButtonTitles:NSLocalizedString(@"Cellular call",@"SiphonApp"),
                                     nil] autorelease];
      actionSheet.actionSheetStyle = UIActionSheetStyleDefault;
      [actionSheet showInView: self.window];
    }
    return;
  }

  if ([self sipConnect])
  {
    NSRange range = [number rangeOfString:@"@"];
      NSLog(@"%i", _sip_acc_id);
    if (range.location != NSNotFound)
    {
      status = sip_dial_with_uri(_sip_acc_id, [[NSString stringWithFormat:@"sip:%@", number] UTF8String], &call_id);
    }
    else
    status = sip_dial(_sip_acc_id, [number UTF8String], &call_id);
    if (status != PJ_SUCCESS)
    {
      // FIXME
      //[self displayStatus:status withTitle:nil];
      const pj_str_t *str = pjsip_get_status_text(status);
      NSString *msg = [[NSString alloc]
                       initWithBytes:str->ptr 
                       length:str->slen 
                       encoding:[NSString defaultCStringEncoding]];
      [self displayError:msg withTitle:@"registration error"];
    }
  }
}

また、誰かが Siphon アプリのコードへのリンクを持っていて、それがより新しく、よりうまく機能する可能性がある場合は、それも感謝します。

より詳しい情報:

call.m ファイルでは、本質的にこれが呼び出されます。

status = pjsua_call_make_call(acc_id, &pj_uri, 0, NULL, NULL, call_id);

そしてここ

acc_id = 0

pj_uri = char *-> "sip:6476805821@voip5-2.acanac.com" pj_ssize_t -> 33

call_id = 803203976

4

2 に答える 2

6

私はこれを理解しました。結局、サイフォン アプリはアカウントを登録していませんでした。以下のコードは重要です。

pj_status_t sip_connect(pj_pool_t *pool, pjsua_acc_id *acc_id)
{

// ID
  acc_cfg.id.ptr = (char*) pj_pool_alloc(/*app_config.*/pool, PJSIP_MAX_URL_SIZE);
  if (contactname && strlen(contactname))
    acc_cfg.id.slen = pj_ansi_snprintf(acc_cfg.id.ptr, PJSIP_MAX_URL_SIZE, 
                                       "\"%s\"<sip:%s@%s>", contactname, uname, server);
  else
    acc_cfg.id.slen = pj_ansi_snprintf(acc_cfg.id.ptr, PJSIP_MAX_URL_SIZE, 
                                       "sip:%s@%s", uname, server);
  if ((status = pjsua_verify_sip_url(acc_cfg.id.ptr)) != 0) 
  {
    PJ_LOG(1,(THIS_FILE, "Error: invalid SIP URL '%s' in local id argument", 
      acc_cfg.id));
    [app displayParameterError: @"Invalid value for username or server."];
    return status;
  }

  // Registrar
  acc_cfg.reg_uri.ptr = (char*) pj_pool_alloc(/*app_config.*/pool, 
    PJSIP_MAX_URL_SIZE);
  acc_cfg.reg_uri.slen = pj_ansi_snprintf(acc_cfg.reg_uri.ptr, 
    PJSIP_MAX_URL_SIZE, "sip:%s", server);
  if ((status = pjsua_verify_sip_url(acc_cfg.reg_uri.ptr)) != 0) 
  {
    PJ_LOG(1,(THIS_FILE,  "Error: invalid SIP URL '%s' in registrar argument",
      acc_cfg.reg_uri));
    [app displayParameterError: @"Invalid value for server parameter."];
    return status;
  }

  ...
  more code here
  ...
}

ここで、アカウントが SIP サーバーに登録されます。以下に示すように、sip_connect 関数がメイン アプリケーション自体から呼び出されることを確認します。

/* */
- (BOOL)sipConnect
{
  pj_status_t status;

  if (![self sipStartup])
    return FALSE;

  //if ([self wakeUpNetwork] == NO)
  //  return NO;
    NSLog(@"%i", _sip_acc_id);
  //if (_sip_acc_id == PJSUA_INVALID_ID)
  //{
    self.networkActivityIndicatorVisible = YES;
    if ((status = sip_connect(_app_config.pool, &_sip_acc_id)) != PJ_SUCCESS)
    {
      self.networkActivityIndicatorVisible = NO;
      return FALSE;
    }
  //}

  return TRUE;
}

私の場合、_sip_acc_id は PJSUA_INVALID_ID と等しくなかったので、sip_connect は呼び出されませんでした。

頭の中で解決しようとしたすべての人に感謝しますか? :)

于 2012-09-07T20:18:42.770 に答える
2

コード スニペットエラー出力(少なくとも)を投稿しない限り、有用なヘルプが得られる可能性はほとんどありません。構成情報やネットワークの関連する側面など、より多くのコンテキストがあれば、可能性がさらに高まります。

(これを質問のコメントとして追加したはずですが、必要な評判はまだありません。)

于 2012-09-05T18:27:06.113 に答える