onvif server端鉴权函数

鉴权的原理:根据客户端发过来的账号密码,监测是否与服务端设置的账号密码是否正确

另外,客户端发过来的密码是加密的,具体是怎么加密的请参阅官方文档,这里直接用相应的函数实现与后端密码对比。经过测试是OK的。

客户端写错账号,或者不填,或者写错密码,都是可以提示错误的。

客户端测试软件:ONVIF Device Manager V2.2.250

int onvif_access_control(struct soap *soap)

{

    if (soap == NULL || soap->header == NULL || soap->header->wsse__Security == NULL)

    {

        printf ("no authentication,refuse it!\n");

        return 401;

    }

    _wsse__Security *pwsse  = soap->header->wsse__Security;

    struct _wsse__UsernameToken* ptoken = pwsse->UsernameToken;

    printf ("Username=%s\n", ptoken->Username);

    printf ("Nonce=%s\n", ptoken->Nonce);

    printf ("Password=%s\n", ptoken->Password->__item);

    printf ("PasswordType=%s\n", ptoken->Password->Type);

    printf ("wsu__Created=%s\n", ptoken->wsu__Created);

   

    if (strcmp(ptoken->Username, "admin") != 0)

    {

        printf("username is fault\r\n");

        return 401;

    }

    const char *password = "audfly2018";

    if (soap_wsse_verify_Password(soap,password))

    {

        soap_wsse_delete_Security(soap);

        printf("ERROR  Password is fault\r\n");

        return 401;

    }

    soap_wsse_delete_Security(soap);

    return SOAP_OK;

}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zanglengyu

敲碗要饭

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值