eXosip REGISTER认证过程

eXosip_add_authentication_info 
eXosip_register_build_initial_register 
eXosip_register_send_register 发送

发送一个注册包
eXosip_clear_authentication_info();
eXosip_add_authentication_info(m_userid,m_userid,m_passwd,"MD5",NULL)) 添加认证信息
osip_message_t *reg;
m_localurl.Format("sip:%s@%s",m_userid,SIP_SERVER);
m_nRegisterID = eXosip_register_build_initial_register(m_localurl,m_sipserverurl,NULL,300,&reg);初始化一个注册ID 并产生一个注册包
eXosip_register_send_register(m_nRegisterID,reg)
这样就发出了一个注册请求

服务器会回一个401注册挑战
在EXOSIP_REGISTRATION_FAILURE中处理中 判断event->response->status_code是否为401

然后 使用event的rid 重现产生一个注册包

osip_message_t *reg;
eXosip_register_build_register(event->rid, 300, &reg);//
//取回认证的字符串authorization
{
    osip_authorization_t * auth;
    char *strAuth=NULL;
    osip_message_get_authorization(reg,0,&auth);
    osip_authorization_to_str(auth,&strAuth);
    strcpy(m_strAuth,strAuth);//保存认证字符串
    delete []strAuth;
}
eXosip_register_send_register(event->rid,reg);


在拿到认证字符串后 发送心跳时就不用每次都产生挑战信息了

发送心跳的方法 
osip_message_t *msg=NULL;
eXosip_register_build_register(m_nRegisterID, 300, &msg); //根据以前的RegisterID 重新产生一个注册包
{//将认证字符串添加入REGISTER消息中
    osip_header_t *pMsgHeader=NULL;
    osip_message_header_get_byname(msg,(const char *)"authorization",0,&pMsgHeader);
    if (pMsgHeader==NULL)
         osip_message_set_header(msg,(const char *)"authorization",m_strAuth);
    else
         strcpy(pMsgHeader->hvalue,m_strAuth);
}
eXosip_register_send_register(m_nRegisterID,msg);


注销的方法与心跳包处理方法相投

不过是 expires为0罢了

osip_message_t *msg=NULL;
eXosip_register_build_register(m_nRegisterID,   0, &msg); //根据以前的RegisterID 重新产生一个注册包
{//将认证字符串添加入REGISTER消息中
    osip_header_t *pMsgHeader=NULL;
    osip_message_header_get_byname(msg,(const char *)"authorization",0,&pMsgHeader);
    if (pMsgHeader==NULL)
         osip_message_set_header(msg,(const char *)"authorization",m_strAuth);
    else
         strcpy(pMsgHeader->hvalue,m_strAuth);
}
eXosip_register_send_register(m_nRegisterID,msg);

你可能感兴趣的:(register,SIP)