为SQLite3提供一个ANSI到UTF8的互转函数
在使用sqlite3时必须要用到的
使用方法:
char* src = "...";//待转换的ansi或utf8字符串
char* dst = null;//保存由函数内部分配的内存指针, 不需要传入内存缓冲区的
转换为utf-8:to_utf8(src, &dst);
转换为ansi:to_gb(src, &dst);
返回值:零 - 失败, 非零 - 成功.
注意:如果操作成功, 需要手动释放函数内部分配的空间:
if(dst)
{
free(dst);
dst = null;
}
代码:
#include <windows.h>
#include <stdio.h>int to_utf8(char* psrc, char** ppdst)
{
int ret,ret2;
wchar_t* pws = null;
char* putf = null;
ret = multibytetowidechar(cp_acp, 0, psrc, -1, null, 0);
if(ret<=0){
*ppdst = null;
return 0;
}
pws = (wchar_t*)malloc(ret*2);
if(!pws){
*ppdst = null;
return 0;
}
multibytetowidechar(cp_acp, 0, psrc, -1, pws, ret);
ret2 = widechartomultibyte(cp_utf8, 0, pws, -1, null, 0, null, null);
if(ret2<=0){
free(pws);
return 0;
}
putf = (char*)malloc(ret2);
if(!putf){
free(pws);
return 0;
}
if(widechartomultibyte(cp_utf8, 0, pws, ret, putf, ret2, null, null)){
*ppdst = putf;
free(pws);
return 1;
}else{
free(pws);
free(putf);
*ppdst = null;
return 0;
}
}
int to_gb(char* psrc, char** ppdst)
{
int ret, ret2;
wchar_t* pws = null;
char* pgb = null;
ret = multibytetowidechar(cp_utf8, 0, psrc, -1, null, 0);
if(ret<=0){
*ppdst = null;
return 0;
}
pws = (wchar_t*)malloc(ret*2);
if(!pws){
*ppdst = null;
return 0;
}
multibytetowidechar(cp_utf8, 0, psrc, -1, pws, ret);
ret2 = widechartomultibyte(cp_acp, 0, pws, -1, null, 0, null, null);
if(ret2<=0){
free(pws);
return 0;
}
pgb = (char*)malloc(ret2);
if(!pgb){
free(pws);
*ppdst = null;
return 0;
}
if(widechartomultibyte(cp_acp, 0, pws, -1, pgb, ret2, null, null)){
*ppdst = pgb;
free(pws);
return 1;
}else{*ppdst = 0;
free(pgb);
free(pws);
return 0;
}
}
by: 女孩不哭
上一篇: 保护你的Sqlite数据库(SQLite数据库安全秘籍)
下一篇: SQLite 内存数据库学习手册