xugusql_sock_send.go 3.4 KB

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