资源简介
内部包含本人原创c语言编写的websocket服务端程序源码,默认支持1024条并发,可修改源码轻易支持更高并发,并会自动删除已关闭的连接,里面含80%以上源码写有注释,可帮助websocket小白快速入门,积分不够的小伙伴可以在我的博客直接复制源码,https://blog.csdn.net/baidu_39146182/article/details/81394046
代码片段和文件信息
/*********************************************************************************
* Copyright: (C) 2017 Yang Zheng
* All rights reserved.
*
* Filename: base64.c
* Description: This file
*
* Version: 1.0.0(08/17/2017~)
* Author: Yang Zheng
* ChangeLog: 1 Release initial version on “08/17/2017 02:09:12 PM“
*
********************************************************************************/
#include “base64.h“
const char base[] = “ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=“;
char *base64_encode(const char* data int data_len)
{
int prepare = 0;
int ret_len;
int temp = 0;
char *ret = NULL;
char *f = NULL;
int tmp = 0;
unsigned char changed[4];
int i = 0;
ret_len = data_len / 3;
temp = data_len % 3;
if (temp > 0)
ret_len += 1;
ret_len = ret_len*4 + 1;
ret = (char *)malloc(ret_len);
if ( ret == NULL) {
printf(“ret alloc failure.\n“);
return NULL;
}
memset(ret 0 ret_len);
f = ret;
while (tmp < data_len)
{
temp = 0;
prepare = 0;
memset(changed ‘\0‘ 4);
while (temp < 3)
{
if (tmp >= data_len)
break;
prepare = ((prepare << 8) | (data[tmp] & 0xFF));
tmp++;
temp++;
}
prepare = (prepare<<((3-temp)*8));
for (i=0; i<4 ;i++) {
if (temp < i)
changed[i] = 0x40;
else
changed[i] = (prepare>>((3-i)*6)) & 0x3F;
*f = base[changed[i]];
f++;
}
}
*f = ‘\0‘;
return ret;
}
static char find_pos(char ch)
{
char *ptr = (char*)strrchr(base ch);//the last position (the only) in base[]
return (ptr - base);
}
char *base64_decode(const char *data int data_len)
{
int ret_len = (data_len / 4) * 3;
int equal_count = 0;
char *ret = NULL;
char *f = NULL;
int tmp = 0;
int temp = 0;
char need[3];
int prepare = 0;
int i = 0;
if (*(data + data_len - 1) == ‘=‘)
equal_count += 1;
if (*(data + data_len - 2) == ‘=‘)
equal_count += 1;
if (*(data + data_len - 3) == ‘=‘)
equal_count += 1;
switch (equal_count)
{
case 0:
ret_len += 4;//3 + 1 [1 for NULL]
break;
case 1:
ret_len += 4;//Ceil((6*3)/8)+1
break;
case 2:
ret_len += 3;//Ceil((6*2)/8)+1
break;
case 3:
ret_len += 2;//Ceil((6*1)/8)+1
break;
}
ret = (char *)malloc(ret_len);
if (NULL == ret) {
printf(“ret alloc failure.\n“);
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 0 2018-07-31 15:56 websocket\
文件 3704 2018-07-31 15:56 websocket\ba
文件 764 2018-07-31 15:57 websocket\ba
文件 1927 2018-08-03 13:23 websocket\intlib.c
文件 659 2018-07-31 15:55 websocket\intlib.h
文件 20877 2018-08-03 20:15 websocket\main.c
文件 6699 2018-07-31 15:53 websocket\sha1.c
文件 1151 2018-07-31 15:54 websocket\sha1.h
- 上一篇:C语言解析IP数据包程序
- 下一篇:编译原理课程设计广工C语言
相关资源
- C++并发编程实战pdf高清无码
- C++并发编程第二版,中文版
- C++并发编程实战(英文版)
- c++并发编程实战C++11完整pdf中文版
- C++并发编程实战(中文版)
- MFC websocket server | MFC websocket服务器
- c++ 并发编程实战 中文版+英文版
- C++并发编程实战 美威廉姆斯著 高清扫
- websocket客户端
- MFC socket与websocket通信
- C 并发编程实战(C 11).[美]Anthony Wi
- c++并发编程
- websocket C++ Server端简单demo
- 基于C++ socket编程实现的websocket服务器
- C++并发编程实战 pdf
- websocket_server_client
- 一个好用的C++编写的websocket服务端d
- WebsocketPP C++构建Web服务器源代码
- c++ websocket服务器和html客户端
- linux c语言实现websocket
评论
共有 条评论