基于Poco的UTF8、UTF16、GBK、Hex之间的转换
- /******Encoding.h*******/
- #include "Poco/UnicodeConverter.h"
- #include "Poco/Exception.h"
- #include "Poco/DigestEngine.h"
- #define MyLib_API Foundation_API
- using namespace Poco;
- POCO_DECLARE_EXCEPTION(MyLib_API, EncodeException, Exception)
- class Encoding
- {
- public:
- enum ByteOrderType
- {
- BIG_ENDIAN_BYTE_ORDER,
- LITTLE_ENDIAN_BYTE_ORDER,
- UNKNOW
- };
- static void GBKToUTF16(const std::string& gbkString, std::wstring& utf16String) throw(EncodeException);
- static void UTF16ToGBK(const std::wstring& utf16String, std::string& gbkString) throw(EncodeException);
- static void UTF8ToUTF16(const std::string& utf8String, std::wstring& utf16String) throw(EncodeException);
- static void UTF16ToUTF8(const std::wstring& utf16String, std::string& utf8String) throw(EncodeException);
- static void UTF8ToGBK(const std::string& utf8String, std::string& gbkString) throw(EncodeException);
- static void GBKToUTF8(const std::string& gbkString, std::string& utf8String) throw(EncodeException);
- static void EncodeHexString(const std::string& bytes, std::string& hexString);
- static void DecodeHexString(const std::string& hexString, std::string& bytes);
- static void EncodeHexString(const std::wstring& bytes, std::string& hexString);
- static void DecodeHexString(const std::string& hexString, std::wstring& bytes);
- static ByteOrderType GetCurrentByteOrder();
- private:
- static Poco::UnicodeConverter _unicodeConverter;
- static ByteOrderType _currentByteOrder;
- };
- /********Encoding.cpp********/#include "Encoding.h"
- #include "Poco/NumberParser.h"
- Poco::UnicodeConverter Encoding::_unicodeConverter;
- Encoding::ByteOrderType Encoding::_currentByteOrder;
- POCO_IMPLEMENT_EXCEPTION(EncodeException, Poco::Exception, "Encoding error")
- void Encoding::GBKToUTF16(const std::string& gbkString, std::wstring& utf16String)
- {
- //获得需要分配的空间大小
- int size = MultiByteToWideChar(, , gbkString.c_str(), -, NULL, );
- std::vector<wchar_t> buff(size);
- if(MultiByteToWideChar(, , gbkString.c_str(), -, buff.data(), size) == )
- {
- //throw a exception
- throw EncodeException("GBK convert to UTF16 failed", GetLastError());
- }
- if(!utf16String.empty())
- utf16String.clear();
- utf16String.append(buff.data(), buff.size());
- }
- void Encoding::UTF16ToGBK(const std::wstring& utf16String, std::string& gbkString)
- {
- int size = ;
- //获得需要分配的空间大小
- size = WideCharToMultiByte(, , utf16String.c_str(), -, NULL, , NULL, NULL);
- std::vector<char> buff(size);
- if(WideCharToMultiByte(, , utf16String.c_str(), -, buff.data(), size, NULL, NULL) == )
- throw EncodeException("UTF16 convert to GBK failed", GetLastError());
- if(!gbkString.empty())
- gbkString.clear();
- gbkString.append(buff.data(), buff.size());
- }
- void Encoding::UTF8ToUTF16(const std::string& utf8String, std::wstring& utf16String)
- {
- std::string errorMessage;
- try
- {
- _unicodeConverter.toUTF16(utf8String, utf16String);
- }
- catch(Poco::Exception &e)
- {
- errorMessage.append("UTF8 convert to UTF16 failed, ");
- errorMessage.append(e.message());
- }
- if(!errorMessage.empty())
- throw EncodeException(errorMessage, GetLastError());
- }
- void Encoding::UTF16ToUTF8(const std::wstring& utf16String, std::string& utf8String)
- {
- std::string errorMessage;
- try
- {
- _unicodeConverter.toUTF8(utf16String, utf8String);
- }
- catch(Poco::Exception &e)
- {
- errorMessage.append("UTF8 convert to UTF16 failed, ");
- errorMessage.append(e.message());
- }
- if(!errorMessage.empty())
- throw EncodeException(errorMessage, GetLastError());
- }
- void Encoding::UTF8ToGBK(const std::string& utf8String, std::string& gbkString)
- {
- std::wstring utf16String;
- std::string errorMessage;
- try
- {
- _unicodeConverter.toUTF16(utf8String, utf16String);
- UTF16ToGBK(utf16String, gbkString);
- }
- catch(EncodeException)
- {
- errorMessage = "UTF8 convert to GBK failed";
- }
- catch(Poco::Exception &e)
- {
- errorMessage.append("UTF8 convert to UTF16 failed, ");
- errorMessage.append(e.message());
- }
- if(!errorMessage.empty())
- throw EncodeException(errorMessage, GetLastError());
- }
- void Encoding::GBKToUTF8(const std::string& gbkString, std::string& utf8String)
- {
- std::wstring utf16String;
- std::string errorMessage;
- try
- {
- GBKToUTF16(gbkString, utf16String);
- _unicodeConverter.toUTF8(utf16String, utf8String);
- }
- catch(EncodeException)
- {
- errorMessage = "GBK convert to UTF8 failed";
- }
- catch(Poco::Exception &e)
- {
- errorMessage.append("UTF8 convert to UTF16 failed, ");
- errorMessage.append(e.message());
- }
- if(!errorMessage.empty())
- throw EncodeException(errorMessage, GetLastError());
- }
- void Encoding::EncodeHexString(const std::string& bytes, std::string& hexString)
- {
- if(!hexString.empty())
- hexString.clear();
- Poco::DigestEngine::Digest digest(bytes.begin(), bytes.end());
- hexString = Poco::DigestEngine::digestToHex(digest);
- }
- void Encoding::DecodeHexString(const std::string& hexString, std::string& bytes)
- {
- unsigned int _value;
- if(!bytes.empty())
- bytes.clear();
- for(std::string::size_type i = , j = ; i < hexString.length(); i+=)
- {
- if(NumberParser::tryParseHex(hexString.substr(i, ), _value))
- bytes.push_back(_value);
- }
- }
- void Encoding::EncodeHexString(const std::wstring& utf16String, std::string& hexString)
- {
- if(!hexString.empty())
- hexString.clear();
- Poco::DigestEngine::Digest digest;
- for(auto iter = utf16String.begin(); iter != utf16String.end(); ++iter)
- {
- const unsigned char* ptr = (const unsigned char*)&*iter;
- if(GetCurrentByteOrder() == BIG_ENDIAN_BYTE_ORDER)
- {
- digest.push_back(*ptr);
- digest.push_back(*(ptr + ));
- }
- else if(GetCurrentByteOrder() == LITTLE_ENDIAN_BYTE_ORDER)
- {
- digest.push_back(*(ptr + ));
- digest.push_back(*ptr);
- }
- else
- return;
- }
- hexString = Poco::DigestEngine::digestToHex(digest);
- }
- void Encoding::DecodeHexString(const std::string& hexString, std::wstring& utf16String)
- {
- unsigned int _value;
- if(!utf16String.empty())
- utf16String.clear();
- for(std::string::size_type i = , j = ; i < hexString.length(); i+=)
- {
- if(NumberParser::tryParseHex(hexString.substr(i, ), _value))
- utf16String.push_back(_value);
- }
- }
- Encoding::ByteOrderType Encoding::GetCurrentByteOrder()
- {
- static bool flag = false;
- if(flag)
- return _currentByteOrder;
- union
- {
- char16_t s;
- char c[];
- }un;
- un.s = 0x0102;
- if(un.c[] == && un.c[] == )
- _currentByteOrder = BIG_ENDIAN_BYTE_ORDER;
- else if(un.c[] == && un.c[] == )
- _currentByteOrder = LITTLE_ENDIAN_BYTE_ORDER;
- else
- _currentByteOrder = UNKNOW;
- flag = true;
- return _currentByteOrder;
- }
基于Poco的UTF8、UTF16、GBK、Hex之间的转换的更多相关文章
- UTF-8和GBK编码之间的区别(页面编码、数据库编码区别)以及在实际项目中的应用
第一节:UTF-8和GBK编码概述 UTF-8 (8-bit Unicode Transformation Format) 是一种针对Unicode的可变长度字符编码,又称万国码,它包含全世界所有国家 ...
- ASC与HEX之间的转换
ASC与HEX之间的转换 有这么两个函数: 函数 原型 功能 返回值 参数 备注 hex2asc __int16 hex2asc(unsigned char *strhex,unsigned char ...
- C#中的Byte,String,Int,Hex之间的转换函数。
/// <summary> Convert a string of hex digits (ex: E4 CA B2) to a byte array. </summary> ...
- ascii、unicode、utf-8、gbk区别及转换
一.编码 ascii: A:00000010 8位 一个字节 unicode: A:00000000 00000001 00000010 00000100 32位 四个字节 中:00000000 00 ...
- ascii、unicode、utf-8、gbk 区别?
发展史: https://www.cnblogs.com/houxt/p/11250878.html python2内容进行编码(默认ascii),而python3对内容进行编码的默认为utf-8. ...
- UTF8,UTF16,UTF32,UTF16-LE,UTF16-BE,GBK 之间的转换
Unicode是Unicode.org制定的编码标准,目前得到了绝大部分操作系统和编程语言的支持.Unicode.org官方对Unicode的定义是:Unicode provides a unique ...
- 字符编码之间的相互转换 UTF8与GBK(转载)
转载自http://www.cnblogs.com/azraelly/archive/2012/06/21/2558360.html UTF8与GBK字符编码之间的相互转换 C++ UTF8编码转换 ...
- 【miscellaneous】【C/C++语言】UTF8与GBK字符编码之间的相互转换
UTF8与GBK字符编码之间的相互转换 C++ UTF8编码转换 CChineseCode 一 预备知识 1,字符:字符是抽象的最小文本单位.它没有固定的形状(可能是一个字形),而且没有值." ...
- UNICODE与UTF8和GBK之间的关系
http://wenku.baidu.com/link?url=bheGEzfSjEx-QX-ciME5oKooKYE08_NJZ02l2kKFa7kVZJ4t8Ks2uSNByovgP2QL6btq ...
随机推荐
- spring中AOP
1 AOP 的功能是把横切的问题(如性能监视.事务管理)模块化.AOP的核心是连接点模型,他提供在哪里发生横切. Spring AOP 的底层是通过使用 JDK 或 CGLib 动态代理技术为目标 b ...
- cocos2dx实现3d拾取注意事项
用的是cocos2dx 3.x,如果是真机测试,glview = cocos2d::GLViewImpl::createWithRect(...)和glview->setDesignResolu ...
- 【转】input file accept属性可以限制的文件类型
来源:http://blog.sina.com.cn/s/blog_6c9d65a10101a8yh.html 在上传文件的时候,需要限制指定的文件类型. <input type="f ...
- 跟我一起学习VIM - vim插件合集
2016-06-14 15:04 13333人阅读 评论(0) 收藏 举报 分类: Linux(104) 目录(?)[+] 前两天同事让我在小组内部分享一下VIM,于是我花了一点时间写了个简短的教 ...
- activiti自己定义流程之Spring整合activiti-modeler实例(一):环境搭建
项目中须要整合activiti-modeler自己定义流程,找了非常多资料后,最终成功的跳转到activiti-modeler流程设计界面.下面是记录: 一.整合基础:eclipse4.4.1.tom ...
- c# 封装的7zip压缩 (全源码,不含任何类库)
1,从soureforge下载sdk(包括汇编,c,c++,c#,java) 下载地址http://nchc.dl.sourceforge.net/project/sevenzip/LZMA%20SD ...
- vue轮播图插件vue-awesome-swiper的使用与组件化
不管是APP还是移动端网页开发,轮播图在大部分项目当中都是存在的,这时候如果用vue开发项目,选择一款好的插件并且封装好是很重要的 1. 推荐使用vue-awesome-swiper 安装:cnpm ...
- NIS & Kerberos配置
NIS & Kerberos配置 所需RPM包列表: krb5-server-1.10.3-42.el6.x86_64.rpm krb5-workstation-1.10.3-42.el6.x ...
- 【转载】用Pwnage + Redsnow 制作完美越狱固件
[转载] 现在貌似IOS 7.X系 大行其道,就算不是IOS7.X ,很多人也装着IOS 6.X系. 进入正文前首先介绍一下自己的装备 设备:iphone4 GSM 大陆行货 (内部版本3,1) 为什 ...
- 一款基于TweenMax.js的网页幻灯片
之前介绍了好多网页幻灯片.今天给大家带来一款基于TweenMax.js的网页幻灯片.这款幻灯片以不规则的碎片百叶窗的形式切换.切换效果非常漂亮.一起看下效果图: 在线预览 源码下载 实现的代码. ...