loadrunner base64函数的应用

void GetBase64Encode(const char*in_str,char*out_str)
{
   static unsigned char base64[]="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
   int curr_out_len= 0;
   int i= 0;
   int in_len=strlen(in_str);
   unsigned char a, b, c;
    out_str[0]= '\0';
   if(in_len> 0)
    {
      while(i<in_len)
       {
        a=in_str[i];
        b=(i+ 1 >=in_len)? 0 :in_str[i+ 1];
        c=(i+ 2 >=in_len)? 0 :in_str[i+ 2];
       if(i+ 2 <in_len)
        {
         out_str[curr_out_len++]=(base64[(a>> 2)& 0x3F]);
         out_str[curr_out_len++]=(base64[((a<< 4)& 0x30)+((b>> 4)& 0xf)]);
         out_str[curr_out_len++]=(base64[((b<< 2)& 0x3c)+((c>> 6)& 0x3)]);
         out_str[curr_out_len++]=(base64[c& 0x3F]);
        }
       else if(i+ 1 <in_len)
        {
         out_str[curr_out_len++]=(base64[(a>> 2)& 0x3F]);
         out_str[curr_out_len++]=(base64[((a<< 4)& 0x30)+((b>> 4)& 0xf)]);
         out_str[curr_out_len++]=(base64[((b<< 2)& 0x3c)+((c>> 6)& 0x3)]);
         out_str[curr_out_len++]= '=';
        }
       else
        {
         out_str[curr_out_len++]=(base64[(a>> 2)& 0x3F]);
         out_str[curr_out_len++]=(base64[((a<< 4)& 0x30)+((b>> 4)& 0xf)]);
         out_str[curr_out_len++]= '=';
         out_str[curr_out_len++]= '=';
        }
        i+= 3;
       }
       out_str[curr_out_len]= '\0';
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值