#ifdef _WIN32
#if defined(_MSC_VER) && !defined(_CRT_SECURE_NO_WARNINGS)
#define _CRT_SECURE_NO_WARNINGS // _CRT_SECURE_NO_WARNINGS for sscanf errors in MSVC2013 Express
#endif
#ifndef WIN32_LEAN_AND_MEAN
#define WIN32_LEAN_AND_MEAN
#endif
#include <fcntl.h>
#include <WinSock2.h>
#include <WS2tcpip.h>
#pragma comment( lib, "ws2_32" )
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <io.h>
#ifndef _SSIZE_T_DEFINED
typedef int ssize_t;
#define _SSIZE_T_DEFINED
#endif
#ifndef _SOCKET_T_DEFINED
typedef SOCKET socket_t;
#define _SOCKET_T_DEFINED
#endif
#ifndef snprintf
#define snprintf _snprintf_s
#endif
#if _MSC_VER >=1600
// vs2010 or later
#include <stdint.h>
#else
typedef __int8 int8_t;
typedef unsigned __int8 uint8_t;
typedef __int32 int32_t;
typedef unsigned __int32 uint32_t;
typedef __int64 int64_t;
typedef unsigned __int64 uint64_t;
#endif
#define socketerrno WSAGetLastError()
#define SOCKET_EAGAIN_EINPROGRESS WSAEINPROGRESS
#define SOCKET_EWOULDBLOCK WSAEWOULDBLOCK
#else
#include <fcntl.h>
#include <netdb.h>
#include <netinet/in.h>
#include <netinet/tcp.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <sys/time.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdint.h>
#ifndef _SOCKET_T_DEFINED
typedef int socket_t;
#define _SOCKET_T_DEFINED
#endif
#ifndef INVALID_SOCKET
#define INVALID_SOCKET (-1)
#endif
#ifndef SOCKET_ERROR
#define SOCKET_ERROR (-1)
#endif
#define closesocket(s) ::close(s)
#include <errno.h>
#define socketerrno errno
#define SOCKET_EAGAIN_EINPROGRESS EAGAIN
#define SOCKET_EWOULDBLOCK EWOULDBLOCK
#endif
#include <vector>
#include <string>
#include "easywsclient.hpp"
using easywsclient::Callback_Imp;
using easywsclient::BytesCallback_Imp;
namespace { // private module-only namespace
socket_t hostname_connect(const std::string& hostname, int port) {
struct addrinfo hints;
struct addrinfo *result;
struct addrinfo *p;
int ret;
socket_t sockfd = INVALID_SOCKET;
char sport[16];
memset(&hints, 0, sizeof(hints));
hints.ai_family = AF_UNSPEC;
hints.ai_socktype = SOCK_STREAM;
snprintf(sport, 16, "%d", port);
if ((ret = getaddrinfo(hostname.c_str(), sport, &hints, &result)) != 0)
{
fprintf(stderr, "getaddrinfo: %s\n", gai_strerror(ret));
return 1;
}
for(p = result; p != NULL; p = p->ai_next)
{
sockfd = socket(p->ai_family, p->ai_socktype, p->ai_protocol);
if (sockfd == INVALID_SOCKET) { continue; }
if (connect(sockfd, p->ai_addr, p->ai_addrlen) != SOCKET_ERROR) {
break;
}
closesocket(sockfd);
sockfd = INVALID_SOCKET;
}
freeaddrinfo(result);
return sockfd;
}
class _DummyWebSocket : public easywsclient::WebSocket
{
public:
void poll(int timeout) { }
void send(const std::string& message) { }
void sendBinary(const std::string& message) { }
void sendBinary(const std::vector<uint8_t>& message) { }
void sendPing() { }
void close() { }
readyStateValues getReadyState() const { return CLOSED; }
void _dispatch(Callback_Imp & callable) { }
void _dispatchBinary(BytesCallback_Imp& callable) { }
};
class _RealWebSocket : public easywsclient::WebSocket
{
public:
// http://tools.ietf.org/html/rfc6455#section-5.2 Base Framing Protocol
//
// 0 1 2 3
// 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
// +-+-+-+-+-------+-+-------------+-------------------------------+
// |F|R|R|R| opcode|M| Payload len | Extended payload length |
// |I|S|S|S| (4) |A| (7) | (16/64) |
// |N|V|V|V| |S| | (if payload len==126/127) |
// | |1|2|3| |K| | |
// +-+-+-+-+-------+-+-------------+ - - - - - - - - - - - - - - - +
// | Extended payload length continued, if payload len == 127 |
// + - - - - - - - - - - - - - - - +-------------------------------+
// | |Masking-key, if MASK set to 1 |
// +-------------------------------+-------------------------------+
// | Masking-key (continued) | Payload Data |
// +-------------------------------- - - - - - - - - - - - - - - - +
// : Payload Data continued ... :
// + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - +
// | Payload Data continued ... |
// +---------------------------------------------------------------+
struct wsheader_type {
unsigned header_size;
bool fin;
bool mask;
enum opcode_type {
CONTINUATION = 0x0,
TEXT_FRAME = 0x1,
BINARY_FRAME = 0x2,
CLOSE = 8,
PING = 9,
PONG = 0xa,
} opcode;
int N0;
uint64_t N;
uint8_t masking_key[4];
};
std::vector<uint8_t> rxbuf;
std::vector<uint8_t> txbuf;
std::vector<uint8_t> receivedData;
socket_t sockfd;
readyStateValues readyState;
bool useMask;
bool isRxBad;
_RealWebSocket(socket_t sockfd, bool useMask)
: sockfd(sockfd)
, readyState(OPEN)
, useMask(useMask)
, isRxBad(false) {
}
readyStateValues getReadyState() const {
return readyState;
}
void poll(int timeout) { // timeout in milliseconds
if (readyState == CLOSED) {
if (timeout > 0) {
timeval tv = { timeout/1000, (timeout%1000) * 1000 };
select(0, NULL, NULL, NULL, &tv);
}
return;
}
if (timeout != 0) {
fd_set rfds;
fd_set wfds;
timeval tv = { timeout/1000, (timeout%1000) * 1000 };
FD_ZERO(&rfds);
FD_ZERO(&wfds);
FD_SET(sockfd, &rfds);
if (txbuf.size()) { FD_SET(sockfd, &wfds); }
select(sockfd + 1, &rfds, &wfds, 0, timeout > 0 ? &tv : 0);
}
while (true) {
// FD_ISSET(0, &rfds) will be true
int N = rxbuf.size();
ssize_t ret;
rxbuf.resize(N + 1500);
ret = recv(sockfd, (char*)&rxbuf[0] + N, 1500, 0);
if (false) { }
else if (ret < 0 && (socketerrno == SOCKET_EWOULDBLOCK || socketerrno == SOCKET_EAGAIN_EINPROGRESS)) {
rxbuf.resize(N);
break;
}
else if (ret <= 0) {
rxbuf.resize(N);
closesocket(sockfd);
readyState = CLOSED;
fputs(ret < 0 ? "Connection error!\n" : "Connection closed!\n", stderr);
break;
}
else {
rxbuf.resize(N + ret);
}
}
while (txbuf.size()) {
int ret = ::send(sockfd, (char*)&txbuf[0], txbuf.size(), 0);
if (false) { } // ??
else if (ret < 0 && (socketerrno == SOCKET_EWOULDBLOCK || socketerrno == SOCKET_EAGAIN_EINPROGRESS)) {
break;
}
else if (ret <= 0) {
closesocket(sockfd);
readyState = CLOSED;
fputs(ret < 0 ? "Connection error!
没有合适的资源?快使用搜索试试~ 我知道了~
ServerNew_2022.zip
共163个文件
h:80个
cc:59个
cpp:15个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 28 浏览量
2022-01-12
23:00:40
上传
评论
收藏 276KB ZIP 举报
温馨提示
11
资源推荐
资源详情
资源评论
收起资源包目录
ServerNew_2022.zip (163个子文件)
GameLogic.cc 75KB
JackTable.cc 68KB
SanLogic.cc 60KB
RbTakeAllGame.cc 53KB
GameServer.cc 46KB
JackGame.cc 36KB
GamePlayer.cc 29KB
StreamClient.cc 13KB
ZjhDeck.cc 10KB
GameConfig.cc 10KB
OxHandCard.cc 10KB
Daemon.cc 10KB
MySqlClient.cc 9KB
RedisClient.cc 8KB
JackPlayer.cc 8KB
Log.cc 7KB
JackServer.cc 7KB
WscCoin.cc 7KB
OxDeck.cc 6KB
RbTakeAllBet.cc 6KB
ZjhHandCard.cc 6KB
DdzHandCard.cc 6KB
RbTakeAllPlayer.cc 6KB
ThreeHandCard.cc 5KB
RbTakeAllServer.cc 5KB
TwoHandCard.cc 5KB
SanHandCard.cc 5KB
ZjhProtocol.cc 5KB
SanDeck.cc 4KB
DdzDeck.cc 4KB
SortPlayer.cc 4KB
TexasHandCard.cc 4KB
CommonFun.cc 3KB
TexasDeck.cc 3KB
JackDeck.cc 3KB
Eventlog.cc 3KB
TwoDeck.cc 3KB
ThreeDeck.cc 3KB
GameClient.cc 3KB
main.cc 3KB
JackHandCard.cc 2KB
PondPool.cc 2KB
Buffer.cc 2KB
GameSeat.cc 2KB
main.cc 2KB
RobotName.cc 2KB
WordFilter.cc 2KB
JackSeat.cc 2KB
JsonPacket.cc 1KB
Card.cc 1KB
Dice.cc 1KB
SanCard.cc 1KB
Encrypt.cc 1007B
TexasCard.cc 926B
DdzCard.cc 890B
JackCard.cc 836B
OxCard.cc 818B
ZjhCard.cc 757B
Protocol.cc 393B
RbTakeAll.conf 3KB
BlackJack.conf 2KB
easywsclient.cpp 21KB
TexasPokerCalc.cpp 13KB
sha1.cpp 13KB
md5.cpp 11KB
DiyMessage.cpp 10KB
SafeJson.cpp 10KB
Wsc_Protocol.cpp 10KB
base64.cpp 4KB
CardGroup.cpp 4KB
DiyKfifo.cpp 3KB
CharCoding.cpp 3KB
Wsc_HsMsg.cpp 2KB
Wsc_DatBuf.cpp 1KB
Wsc_DatMsg.cpp 1KB
Wsc_Msg.cpp 24B
GameLogic.h 14KB
GameCmd.h 10KB
GamePlayer.h 10KB
MySqlClient.h 9KB
JackTable.h 8KB
SafeJson.h 7KB
GameServer.h 6KB
BaseEnum.h 6KB
GameConfig.h 5KB
RbTakeAllGame.h 4KB
CardType.h 4KB
OxHandCard.h 4KB
SanLogic.h 4KB
TexasHandCard.h 4KB
Log.h 4KB
SanHandCard.h 3KB
RedisClient.h 3KB
JackHandCard.h 3KB
Card.h 3KB
TwoHandCard.h 3KB
ThreeHandCard.h 3KB
DiyMessage.h 3KB
JackGame.h 3KB
Buffer.h 3KB
共 163 条
- 1
- 2
资源评论
vscode_remote
- 粉丝: 2
- 资源: 5
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功