1. #pragma once
  2.  
  3. #ifndef WINSOCK_H
  4.  
  5. #include<WinSock2.h>
  6. #pragma comment(lib,"ws2_32.lib")
  7.  
  8. #define WINSOCK_H
  9.  
  10. #endif
  11.  
  12. #ifndef WINDOWS_H
  13.  
  14. #define WINDOWS_H
  15. #include<Windows.h>
  16.  
  17. #endif
  18.  
  19. #ifndef SOCK_PORT
  20.  
  21. #define SOCK_PORT 27015 //默认端口号
  22.  
  23. #endif
  24.  
  25. bool GetHostInf(struct hostent* hostinf) { //获取主机信息
  26. char host_name[];
  27. if (gethostname(host_name, sizeof(host_name)) != ) {
  28. return false;
  29. }
  30. hostinf = gethostbyname(host_name);
  31. return true;
  32. }
  33.  
  34. bool isIP(char *a) {
  35. char *b = "192.168.1.";
  36. for (int i = ; i <= strlen(b) - ; i++) {
  37. if (a[i] != b[i])
  38. return false;
  39. }
  40. return true;
  41. }
  42.  
  43. #ifndef HOST_TEXT
  44.  
  45. bool GetHostAddr(char *addr) {
  46. char host_name[] = { };
  47. char ip[] = { };
  48. char *a = ip;
  49. gethostname(host_name, sizeof(host_name));
  50. HOSTENT *host_entry = gethostbyname(host_name);
  51.  
  52. for (int i = ; host_entry != NULL && host_entry->h_addr_list[i] != NULL; ++i) {
  53. sprintf(addr, "%s", inet_ntoa(*(struct in_addr *)host_entry->h_addr_list[i]));
  54. //strcpy_s(addr ,strlen(ip),ip);
  55. //printf("[IP]\t%s\n[Name]\t%s\n\n", a, host_name); //*****text*****
  56. if (isIP(addr)) {
  57. //sprintf_s(addr,strlen(a),"%s", a);
  58. return true;
  59. }
  60. }
  61. return false;
  62. }
  63.  
  64. #else
  65.  
  66. bool GetHostAddr(char *addr) {
  67. strcpy(addr, "127.0.0.1");
  68. return true;
  69. }
  70.  
  71. #endif
  72.  
  73. bool GetHostName(char *name) { //获取主机名字
  74. if (gethostname(name, sizeof(name)) != ) {
  75. return false;
  76. }
  77. return true;
  78. }
  79.  
  80. bool InitSocket() //初始化sock
  81. {
  82. WSADATA wsaData;
  83. int err;
  84. err = WSAStartup(MAKEWORD(, ), &wsaData);
  85. if (err != ) {
  86. return false;
  87. }
  88. if (LOBYTE(wsaData.wVersion) != || HIBYTE(wsaData.wVersion) != ) {
  89. WSACleanup();
  90. return false;
  91. }
  92. return true;
  93. }
  94.  
  95. inline void EndSock() { //结束sock
  96. WSACleanup();
  97. }
  98.  
  99. #ifdef SOCKRUN_TCP
  100.  
  101. bool StartListen(SOCKET *s, char *sServerIP) { //开始监听端口
  102.  
  103. *s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
  104.  
  105. struct sockaddr_in sockaddr = { };
  106. sockaddr.sin_addr.S_un.S_addr = inet_addr(sServerIP);
  107. sockaddr.sin_family = AF_INET;
  108. sockaddr.sin_port = htons(SOCK_PORT);
  109.  
  110. if (bind(*s, (SOCKADDR *)&sockaddr, sizeof(sockaddr)) == SOCKET_ERROR) {
  111. closesocket(*s);
  112. return false;
  113. }
  114.  
  115. if (listen(*s, SOMAXCONN) == SOCKET_ERROR) {
  116. closesocket(*s);
  117. return false;
  118. }
  119. return true;
  120. }
  121.  
  122. bool StartConnect(SOCKET *s, char *sServerIP) {
  123.  
  124. *s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
  125.  
  126. struct sockaddr_in sockaddr = { };
  127. sockaddr.sin_addr.S_un.S_addr = inet_addr(sServerIP);
  128. sockaddr.sin_family = AF_INET;
  129. sockaddr.sin_port = htons(SOCK_PORT);
  130.  
  131. if (connect(*s, (SOCKADDR *)&sockaddr, sizeof(sockaddr)) == SOCKET_ERROR) {
  132. closesocket(*s);
  133. return false;
  134. }
  135. return true;
  136. }
  137.  
  138. #else
  139. #ifdef SOCKRUN_UDP
  140. bool StartListen(SOCKET *s, char *sServerIP) { //开始监听端口
  141.  
  142. *s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
  143.  
  144. struct sockaddr_in sockaddr = { };
  145. sockaddr.sin_addr.S_un.S_addr = inet_addr(sServerIP);
  146. sockaddr.sin_family = AF_INET;
  147. sockaddr.sin_port = htons(SOCK_PORT);
  148.  
  149. if (bind(*s, (SOCKADDR *)&sockaddr, sizeof(sockaddr)) == SOCKET_ERROR) {
  150. return false;
  151. }
  152.  
  153. if (listen(*s, SOMAXCONN) == SOCKET_ERROR) {
  154. return false;
  155. }
  156. return true;
  157. }
  158.  
  159. bool StartConnect(SOCKET *s, char *sServerIP) {
  160.  
  161. *s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
  162.  
  163. struct sockaddr_in sockaddr = { };
  164. sockaddr.sin_addr.S_un.S_addr = inet_addr(sServerIP);
  165. sockaddr.sin_family = AF_INET;
  166. sockaddr.sin_port = htons(SOCK_PORT);
  167.  
  168. if (connect(*s, (SOCKADDR *)&sockaddr, sizeof(sockaddr)) == SOCKET_ERROR) {
  169. closesocket(*s);
  170. return false;
  171. }
  172. return true;
  173. }
  174.  
  175. #endif
  176. #endif

socket函数库简单封装的更多相关文章

  1. ABP+AdminLTE+Bootstrap Table权限管理系统第七节--登录逻辑及abp封装的Javascript函数库

    经过前几节,我们已经解决数据库,模型,DTO,控制器和注入等问题.那么再来看一下登录逻辑.这里算是前面几节的一个初次试水. 首先我们数据库已经有的相应的数据. 模型和DTO已经建好,所以我们直接在服务 ...

  2. ABP+AdminLTE+Bootstrap Table权限管理系统第七节--登录逻辑及几种abp封装的Javascript函数库

    返回总目录:ABP+AdminLTE+Bootstrap Table权限管理系统一期         简介 经过前几节,我们已经解决数据库,模型,DTO,控制器和注入等问题.那么再来看一下登录逻辑.这 ...

  3. 我自己的Javascript 库,封装了一些常用函数 Kingwell.js

    我自己的Javascript 库,封装了一些常用函数 Kingwell.js 博客分类: Javascript javascript 库javascript库  现在Javascript库海量,流行的 ...

  4. Google图片加载库Glide的简单封装GlideUtils

    Google图片加载库Glide的简单封装GlideUtils 因为项目里用的Glide的地方比较多,所有简单的封装了以下,其实也没什么,就是写了个工具类,但是还是要把基础说下 Glide的Githu ...

  5. zlog 纯C日志函数库的简单使用方法

    zlog简述: log是一个高性能.线程安全.灵活.概念清晰的纯C日志函数库. 事实上,在C的世界里面没有特别好的日志函数库(就像JAVA里面的的log4j,或者C++的log4cxx).C程序员都喜 ...

  6. 循环 与 分支语句 和 字符函数库cctype 文件简单处理

    循环 for循环 while循环 do  while循环 通常,入口条件循环比出口条件循环好,因为循环开始前对条件进行检查 c++11基于范围的for循环    对数组(或容器类,如:vector和a ...

  7. php GD库简单使用和封装

    GD库创建图像步骤 <?php //1.创建画布 $width = 300; $height= 200; $image=imagecreatetruecolor($width,$height); ...

  8. 我对开源C++网络库简单应用总结

    网上有篇文章<开源免费的C/C++网络库(c/c++ sockets library) 七剑下天山>,看了之后觉得每个库都不错,这里我具体下载这些库看一下,简单总结一下: 顺便添加一些我找 ...

  9. python socket 实现的简单http服务器

    预备知识: 关于http 协议的基础请参考这里. 关于socket 基础函数请参考这里. 关于python 网络编程基础请参考这里. 一.python socket 实现的简单http服务器   废话 ...

随机推荐

  1. Delphi XE2 之 FireMonkey 入门(25) - 数据绑定: TBindingsList: 表达式的灵活性及表达式函数

    Delphi XE2 之 FireMonkey 入门(25) - 数据绑定: TBindingsList: 表达式的灵活性及表达式函数 绑定表达式中可以有简单的运算和字符串连接, 但字符串需放在双引号 ...

  2. shell习题-输入数字执行对应命令

    要求: 写一个脚本实现如下功能:输入一个数字,然后运行对应的一个命令.显示命令如下:*cmd meau**  1—date 2–ls 3–who 4–pwd当输入1时,会运行date, 输入2时运行l ...

  3. 测开之路八十七:HTML之a标签的用法

    初始化的HTML结构为,只需要在body里面加网页的标签和要显示的内容即可 <!DOCTYPE html><html lang="en"><head& ...

  4. 多线程threading初识,线程等待

    1.线程是程序里面最小的执行单元. 2.进程是资源的集合. 线程是包含在进程里面的,一个进程可以有多个线程,但只要要有一个线程. 一.多线程,就是N个线程一起干活: 1.传统方式,串行,循环5次需要1 ...

  5. 应用安全 - PHPCMS - Joomla漏洞汇总

    Joomla 反序列化(版本低于3.4.5) CVE-2015-8562 RCE Date:October, 2019原理:https://blog.hacktivesecurity.com/inde ...

  6. DevOps的前世今生

    From今日头条:https://www.toutiao.com/a6534660729453150723/?tt_from=weixin&utm_campaign=client_share& ...

  7. 使用SqlBulkCopy 批量操作大量数据

    private void button1_Click(object sender, EventArgs e) { //1.0 构建一个内存表一定要和Users表的结构保持一致,除了自增的主键外 Dat ...

  8. Ansible安装配置(CentOS 7)

    Ansible 中的概念 任务 Task——多个 Task 顺序执行,在每个 Task 执行结束可以通知 Hanlder 触发新操作. 变量 Variable——用户定义的变量. 环境 Facts—— ...

  9. 使用xmake优雅地描述工程

    描述语法 xmake的描述语法基于lua实现,因此描述语法继承了lua的灵活性和简洁性,并且通过28原则,将描述作用域(简单描述).脚本作用域(复杂描述)进行分离,使得工程更加的简洁直观,可读性非常好 ...

  10. 单片机BootLoader

    http://bbs.elecfans.com/jishu_467138_1_1.html 作用:app程序,固件程序升级