xugu_sock_send.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. package xugu
  2. import (
  3. "encoding/binary"
  4. "fmt"
  5. )
  6. func SockSendCommandN(pConn *xuguConn, sql string, num int) (int, error) {
  7. ret := 0
  8. var err error
  9. cmd_len := len(sql)
  10. ret, err = RhSend(pConn, []byte("?"), 1)
  11. if err != nil {
  12. return 0, err
  13. }
  14. ret, err = rhSendInt32(pConn, uint32(cmd_len))
  15. if err != nil {
  16. return 0, err
  17. }
  18. ret, err = RhSend(pConn, []byte(sql), cmd_len+1)
  19. if err != nil {
  20. return 0, err
  21. }
  22. if num != 0 {
  23. ret, err = rhSendInt32(pConn, uint32(num)) //param num
  24. if err != nil {
  25. return 0, err
  26. }
  27. } else {
  28. ret, err = rhSendInt32(pConn, uint32(0))
  29. if err != nil {
  30. return 0, err
  31. }
  32. }
  33. return ret, nil
  34. }
  35. func SockSendCommand0(pConn *xuguConn, sql string) (int, error) {
  36. cmdLen := len(sql)
  37. //发送问号字符 ?
  38. ret, err := RhSend(pConn, []byte("?"), cmdLen)
  39. if err != nil {
  40. return 0, err
  41. }
  42. // Comand_Len
  43. lengthInt32 := uint32(len(sql))
  44. ret, err = rhSendInt32(pConn, lengthInt32)
  45. if err != nil {
  46. return 0, err
  47. }
  48. // Comand_str
  49. ret, err = RhSend(pConn, []byte(sql), cmdLen+1)
  50. if err != nil {
  51. return 0, err
  52. }
  53. data := make([]byte, 1)
  54. ret, err = RhSend(pConn, data, 1)
  55. if err != nil {
  56. return 0, err
  57. }
  58. // Param_num
  59. ret, err = rhSendInt32(pConn, 0)
  60. if err != nil {
  61. return 0, err
  62. }
  63. fmt.Println("SockSendCommand0 msg", pConn.sendBuff.String())
  64. RhFlush(pConn)
  65. return ret, nil
  66. }
  67. // RhSend Go 版本的 rh_send 函数
  68. // TODO :加密连接还没有实现
  69. func RhSend(pConn *xuguConn, buff []byte, length int) (int, error) {
  70. pConn.mu.Lock()
  71. defer pConn.mu.Unlock()
  72. //没有内容则不发送
  73. if length == 0 {
  74. return 0, nil
  75. }
  76. //连接里是否有加密
  77. if pConn.useSSL {
  78. fmt.Println("加密未实现")
  79. return length, nil
  80. // if length > 2*1024 {
  81. // EncryptBuff(pconn, buff)
  82. // if _, err := pconn.conn.Write(pconn.sendBuff.Bytes()); err != nil {
  83. // pconn.sendBuff.Reset()
  84. // return 0, err
  85. // }
  86. // pconn.sendBuff.Reset()
  87. // _, err := pconn.conn.Write(bufPrintln()
  88. // return len(buff), err
  89. // } else if pconn.sendBuff.Len()+length >= BUFF_SIZE {
  90. // if _, err := pconn.conn.Write(pconn.sendBuff.Bytes()); err != nil {
  91. // pconn.sendBuff.Reset()
  92. // return 0, err
  93. // }
  94. // pconn.sendBuff.Reset()
  95. // _, err := pconn.sendBuff.Write(buff)
  96. // if err != nil {
  97. // return 0, err
  98. // }
  99. // EncryptBuff(pconn, pconn.sendBuff.Bytes())
  100. // return len(buff), nil
  101. // } else {
  102. // pconn.sendBuff.Write(buff)
  103. // EncryptBuff(pconn, pconn.sendBuff.Bytes()[pconn.sendBuff.Len()-length:])
  104. // return length, nil
  105. // }
  106. } else {
  107. /*如果数据长度大于 2048,先发送缓冲区中的数据,然后直接发送新的大数据块。*/
  108. if length > 2048 {
  109. if _, err := pConn.conn.Write(pConn.sendBuff.Bytes()); err != nil {
  110. //将缓冲区重置为空
  111. pConn.sendBuff.Reset()
  112. return 0, err
  113. }
  114. //将缓冲区重置为空
  115. pConn.sendBuff.Reset()
  116. //发送新的大数据块
  117. _, err := pConn.conn.Write(buff)
  118. return length, err
  119. } else if pConn.sendBuff.Len()+length >= 8*1024 {
  120. //缓冲区空间不足:
  121. /*- 如果当前缓冲区中的数据加上新数据的长度超过 `8 * 1024` 字节,
  122. 则先发送缓冲区中的数据,然后重置缓冲区,将新数据拷贝到缓冲区中。*/
  123. if _, err := pConn.conn.Write(pConn.sendBuff.Bytes()); err != nil {
  124. pConn.sendBuff.Reset()
  125. return 0, err
  126. }
  127. pConn.sendBuff.Reset()
  128. pConn.sendBuff.Write(buff)
  129. return length, nil
  130. } else {
  131. //TODO: 这里c代码里是添加到缓存buff里面 ,不直接发送
  132. pConn.sendBuff.Write(buff)
  133. return length, nil
  134. }
  135. }
  136. }
  137. func rhSendInt32(pConn *xuguConn, i uint32) (int, error) {
  138. // 创建一个 4 字节的缓冲区,用于存储网络字节序的 int32 值
  139. var networkBytes [4]byte
  140. // 将 int32 值转换为网络字节序(大端字节序)并写入缓冲区
  141. binary.BigEndian.PutUint32(networkBytes[:], i)
  142. //fmt.Println("networkBytes[] ", networkBytes[:])
  143. return RhSend(pConn, networkBytes[:], 4)
  144. }
  145. func RhFlush(pConn *xuguConn) (int, error) {
  146. if pConn.sendBuff.Len() > 0 {
  147. if _, err := pConn.conn.Write(pConn.sendBuff.Bytes()); err != nil {
  148. pConn.sendBuff.Reset()
  149. return 0, err
  150. }
  151. pConn.sendBuff.Reset()
  152. }
  153. return 0, nil
  154. }