//
// DataHimi.cpp
// Oh!MonsterMR
//
// Created by Himi on 12-3-8.
// Copyright (c) 2012年 Augustimpression. All rights reserved.
// #include "DataBase64Himi.h" static const std::string dataChars =
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"abcdefghijklmnopqrstuvwxyz"
"0123456789+/"; static inline bool baseData(unsigned char c) {
return (isalnum(c) || (c == '+') || (c == '/'));
} std::string himiSaveData(unsigned char const* bytes_to_encode, unsigned int in_len) {
std::string ret;
int i = 0;
int j = 0;
unsigned char char_array_3[3];
unsigned char char_array_4[4]; while (in_len--) {
char_array_3[i++] = *(bytes_to_encode++);
if (i == 3) {
char_array_4[0] = (char_array_3[0] & 0xfc) >> 2;
char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4);
char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6);
char_array_4[3] = char_array_3[2] & 0x3f; for(i = 0; (i <4) ; i++)
ret += dataChars[char_array_4[i]];
i = 0;
}
} if (i)
{
for(j = i; j < 3; j++)
char_array_3[j] = '\0'; char_array_4[0] = (char_array_3[0] & 0xfc) >> 2;
char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4);
char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6);
char_array_4[3] = char_array_3[2] & 0x3f; for (j = 0; (j < i + 1); j++)
ret += dataChars[char_array_4[j]]; while((i++ < 3))
ret += '='; } return ret; } std::string himiParseData(std::string const& encoded_string) {
int in_len = encoded_string.size();
int i = 0;
int j = 0;
int in_ = 0;
unsigned char char_array_4[4], char_array_3[3];
std::string ret; while (in_len-- && ( encoded_string[in_] != '=') && baseData(encoded_string[in_])) {
char_array_4[i++] = encoded_string[in_]; in_++;
if (i ==4) {
for (i = 0; i <4; i++)
char_array_4[i] = dataChars.find(char_array_4[i]); char_array_3[0] = (char_array_4[0] << 2) + ((char_array_4[1] & 0x30) >> 4);
char_array_3[1] = ((char_array_4[1] & 0xf) << 4) + ((char_array_4[2] & 0x3c) >> 2);
char_array_3[2] = ((char_array_4[2] & 0x3) << 6) + char_array_4[3]; for (i = 0; (i < 3); i++)
ret += char_array_3[i];
i = 0;
}
} if (i) {
for (j = i; j <4; j++)
char_array_4[j] = 0; for (j = 0; j <4; j++)
char_array_4[j] = dataChars.find(char_array_4[j]); char_array_3[0] = (char_array_4[0] << 2) + ((char_array_4[1] & 0x30) >> 4);
char_array_3[1] = ((char_array_4[1] & 0xf) << 4) + ((char_array_4[2] & 0x3c) >> 2);
char_array_3[2] = ((char_array_4[2] & 0x3) << 6) + char_array_4[3]; for (j = 0; (j < i - 1); j++) ret += char_array_3[j];
} return ret;
}
												

最新文章

  1. 03-JAVA方法
  2. 水题 HDOJ 4716 A Computer Graphics Problem
  3. [leetcode]_Longest Common Prefix
  4. hdu1880
  5. postgres 约束 多个条件 联合 约束
  6. Spark学习之RDD的理解
  7. HDU 1104 Remainder( BFS(广度优先搜索))
  8. 【FF14】工匠配方爬取
  9. Mysql、Hbuilder、Idea快捷键
  10. 剑指Offer-和为S的连续正数序列
  11. 【转】机器学习在B2B的应用
  12. vmware中如何检查cpu的使用状况-一个考题引发的思考
  13. Linux磁盘空间占满问题快速定位
  14. 一,ESP8266下载和刷固件(基于Lua脚本语言)
  15. SQLServer DBA 三十问
  16. AngularJs 学习 (一)
  17. mac上安装完成node,就升级好了npm,之后的设置
  18. Jmeter的接口测试简介
  19. 观察者模式与Guava EventBus
  20. Tomcat和Mysql部署成Windows服务

热门文章

  1. Uboot 2014.07 makefile分析 - 其他Cortex系列
  2. hibernate中的SessionFactory,Session分别表示什么啊?如何理解?
  3. 用net匹配并替换iOS标准的emoji表情符号
  4. 用socket方式传输Image和Sound文件
  5. Jqgrid入门-Jqgrid列数据拖动(七)
  6. js array 数组删除元素
  7. [反汇编练习]160个CrackMe之001
  8. 一天一个Java基础——数组
  9. 【LCS,LIS】最长公共子序列、单调递增最长子序列
  10. TCP/IP详解学习笔记(9)-TCP协议概述