乱码大全(二)

 

2. Xxencode

    提到Uuencode不可能不提Xxencode, Xxencode的编码算法和 Uuencode基本相同,但是使用的是不同的字符集。XxEncode编码使用的字符是:

“+-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz”与 Uuencode 相比,它的特殊字符更少。很多支持 Uuencode 编解码的工具都同时支持 Xxencode

    这种编码的特征是:每一行开头用“h”标志。下面是Xxencode的一个例子:

begin 644 mogao.txt

h0EY760+U684qkh90uwjXhuWowwWfcPQB0UbLxxLTCapjNq3jcumkpxH4iwOu

hpxKycuVoNKliNLEu9mwmA16iAH2m9X6k9X2nAXcmAuCdgwbIgO4X1Ec760+U

h60+Ul8esrwXhjDutdBTrmh8XiaVoR5+u9mxhPqRVPmtWNKtoOLJi9atZR+o8

h0EY7FKpVOKloPndhPqRVPo+nBn2iPaJo1Ec760+U8Wce8Wce8Wce8Wce8Wce

h8Wce8Wce8Wce8Wce8Wce8Wce8Wce8Wce8Wce8Wce60+U60+U60+U60+U60+U

h1Ec760+U8W0nzQ59jATGtAemkvGqj98vhDXLruCggzr-mxTXj8D8ggCohfmm

hiw5onw6e1Ec760+U8Wce8Wce8Wce8Wce8Wce8Wce8Wce8Wce8Wce8Wce8Wce

A8Wce8Wce8Wce8Wce

+

end

 

    你可以把它单独存成一个文件:mogao.xxe,然后用Winzip打开,解压即得mogao.txt。

    Xxencode的编码算法和Uuencode基本相同,实现起来则更为简单,在此就不详述了。

    下面给出Xxencode编码和解码的C语言描述:

/*Xxencode编码*/

 void Xxe(unsigned char chasc[3],unsigned char chxxe[4])

/*

chasc:未编码的二进制代码

chxxe:编码过的Xxe代码

*/

{int i;

 static char set[]=

  "+-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";

 chxxe[0]=chasc[0]>>2;

 chxxe[1]=(chasc[0]<<4)&48|(chasc[1]>>4)&15;

 chxxe[2]=(chasc[1]<<2)&60|(chasc[2]>>6)&3;

 chxxe[3]=chasc[2]&63;

 for(i=0;i<4;i++) chxxe[i]=set[chxxe[i]];                  /*查表*/

}

/*需注意的是,Xxencode文件正文部分中每一行的第一个字母是:从源文件中实际                 读取的字符数的ASCII值取后六位后用set[]查表得到的。*/

/*Xxencode解码*/

unsigned char set(unsigned char ch)                           /*查表函数*/

{if(ch==43) ch=0;

 else if(ch==45) ch=1;

 else if(ch>=48&&ch<=57) ch-=46;

 else if(ch>=65&&ch<=90) ch-=53;

 else if(ch>=97&&ch<=122) ch-=59;

 return ch;

}

 

void unXxe(unsigned char chxxe[4],unsigned char chasc[3])

/*

chxxe:未解码的Xxe代码

chasc:解码过的二进制代码

*/

{int k=2 ,i;

 unsigned char t;

 t=NULL;

 *chxxe=set(*chxxe);

 for(i=0;i<3;i++)

 {*(chxxe+i+1)=set(*(chxxe+i+1));

  (chhex+i)=*(chxxe+i)<<k;

  k+=2;

  t=*(chxxe+i+1)>>8-k;

  *(chhex+i)|=t;

 }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
UG次开发中文乱码问题可能由以下原因引起: 1. 字符集设置问题:在UG次开发时,需要确保使用的字符集与系统或文件本身的字符集一致。如果字符集不匹配,就会导致中文乱码问题。因此,可以尝试在代码中设置正确的字符集,如UTF-8或GBK。 2. 文件编码问题:如果在UG次开发中涉及到读取或写入文件,需要注意文件的编码格式。如果文件编码格式与读取或写入时指定的格式不匹配,就会导致中文乱码问题。可以尝试使用正确的文件编码格式,如UTF-8或GBK。 3. 程序逻辑问题:有时候,中文乱码问题可能是由于程序逻辑上的错误导致的。例如,在处理字符串时没有正确地转换字符编码,或者没有正确地设置字符集。需要仔细检查代码中涉及到中文处理的部分,确保逻辑正确。 4. 环境配置问题:UG次开发可能需要在特定的开发环境中进行,例如Eclipse、Visual Studio等。在安装和配置开发环境时,需要确保正确地设置编码格式和字符集。如果环境配置不正确,就会导致中文乱码问题。 为解决中文乱码问题,可以按照以下步骤进行操作: 1. 检查代码中的字符集设置,确保使用的字符集与系统或文件的字符集一致。 2. 如果涉及到文件操作,检查文件的编码格式,并在读取或写入时指定正确的编码格式。 3. 仔细检查代码中的中文处理部分,确保逻辑正确,包括字符编码的转换和字符集的设置等。 4. 确认开发环境的正确配置,包括编码格式和字符集的设置。 如果以上方法仍未解决中文乱码问题,可以参考UG开发文档或向UG开发社区寻求更多帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值