欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

iconv库的移植

程序员文章站 2024-01-16 21:58:04
...

1. 需求

    如果你在系统中涉及到字符编码集的时候,比如网页端一般使用字符编码是 utf-8,迪文屏一般支持的字符编码是 GB2312...对于字符编码间的转换在一些时候是一个绕不过的坎。那此篇文章对你可能有所有帮助。

    如果你的程序在ubuntu中,在程序中包括 #include <iconv.h>,使用iconv集就能正常实现字符编码的转换,但如果是在arm板中,简单的包含头文件,iconv函数集是不能运行的,需要我们单独的移植 libiconv 库。


2. 正文

    (1)交叉编译libiconv库

        ①下载:我们先从官网下载libiconv库源码文件, 我此次选择的版本是 libiconv-1.10.tar.gz

        ②解压

        ③编译前配置

> ./configure --prefix="你自己想要存放编译出来的文件夹" --host=arm-linux --CC=“交叉编译工具同交叉编译选项/设置全部变量情况下,此CC省略”

 

        ④编译和整理到指定的文件中

> make

> make install


    (2)使用方法

有两种方法:

        ①配置系统文件,支持libiconv库

在 /etc/profile 文件中添加

export LD_PRELOAD="preloadable_libiconv.so文件存放的位置"

相应的对应上边的操作,我们需要把编译出来的文件中找到此文件,放到相应位置上。

此方法在开机启动的程序中使用,不能保证每次重启后都能加载成功的现象,因此,此方法暂时抛弃。

        ②使用动态库

将生成的库文件中的 libiconv.so、libiconv.so.2、libiconv.so.2.3.0 拷贝到arm板的根文件系统的库文件夹下,如果cp的话要加 -a 选项,保留软连接特性。

在要使用的程序中,我们将 iconv.h 头文件添加到工程中,Makefile中添加 -liconv 链接选项,在使用到iconv函数集的文件中包含进头文件 #include "iconv.h" 。即可。

特殊说明,如果不包含iconv.h文件,是不成功的。不能使用 #include <iconv.h>


3. iconv函数集使用例子

/*
* 将UTF8转到GB2312,遇到不能转的,找到邻近的继续转换
* 转换后,结果放到s_outbuffer中,其中存放的字符的长度是函数的返回值
*/
int ConvertUTF8ToASCII( const char* inbuffer, char *s_outbuffer  )
{
    const char* srcStart = inbuffer;
    char* tempOutBuffer = s_outbuffer;
    size_t srcLen = strlen(inbuffer);
    size_t outLen = 218;

    if (srcLen == 0) return 0;
    iconv_t cd = iconv_open("GB2312//TRANSLIT", "UTF-8"); // UTF8 -> GB2312
    if (cd == (iconv_t)(-1)) {
        perror("iconv_open is error");
    }
    int ret = iconv(cd, (char **)&srcStart, &srcLen, &tempOutBuffer, &outLen);
    if (ret < 0) {
        printf("ret is %d\n", ret);
        perror("iconv");
    }
    iconv_close(cd);
    return 218-outLen;
}

注意函数中 outLen = 218 参数,根据你要转的buf的容限来更改,并相应的更改return中的218的值。