IPRangeLoader.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. package main
  2. import (
  3. "bufio"
  4. "log"
  5. "net"
  6. "os"
  7. "strconv"
  8. "strings"
  9. )
  10. // 根据子网掩码获取主机数量
  11. func getCidrHostNum(maskLen int) int {
  12. cidrIPNum := int(0)
  13. if maskLen < 32 {
  14. var i int = int(32 - maskLen - 1)
  15. for ; i >= 1; i-- {
  16. cidrIPNum += 1 << i
  17. }
  18. cidrIPNum += 2
  19. } else {
  20. cidrIPNum = 1
  21. }
  22. if cidrIPNum > 255 {
  23. cidrIPNum = 255
  24. }
  25. return cidrIPNum
  26. }
  27. // 获取 IP 最后一段最小值和最大值
  28. func getCidrIPRange(cidr string) (uint8, uint8) {
  29. ip := strings.Split(cidr, "/")[0]
  30. ipSegs := strings.Split(ip, ".")
  31. maskLen, _ := strconv.Atoi(strings.Split(cidr, "/")[1])
  32. seg4MinIP, seg4MaxIP := getIPSeg4Range(ipSegs, maskLen)
  33. //ipPrefix := ipSegs[0] + "." + ipSegs[1] + "." + ipSegs[2] + "."
  34. return seg4MinIP,
  35. seg4MaxIP
  36. }
  37. // 获取 IP 最后一段的区间
  38. func getIPSeg4Range(ipSegs []string, maskLen int) (uint8, uint8) {
  39. ipSeg, _ := strconv.Atoi(ipSegs[3])
  40. return getIPSegRange(uint8(ipSeg), uint8(32-maskLen))
  41. }
  42. // 根据输入的基础IP地址和CIDR掩码计算一个IP片段的区间
  43. func getIPSegRange(userSegIP, offset uint8) (uint8, uint8) {
  44. var ipSegMax uint8 = 255
  45. netSegIP := ipSegMax << offset
  46. segMinIP := netSegIP & userSegIP
  47. segMaxIP := userSegIP&(255<<offset) | ^(255 << offset)
  48. return uint8(segMinIP), uint8(segMaxIP)
  49. }
  50. func loadFirstIPOfRangeFromFile(ipFile string) []net.IPAddr {
  51. file, err := os.Open(ipFile)
  52. if err != nil {
  53. log.Fatal(err)
  54. }
  55. firstIPs := make([]net.IPAddr, 0)
  56. scanner := bufio.NewScanner(file)
  57. scanner.Split(bufio.ScanLines)
  58. for scanner.Scan() {
  59. IPString := scanner.Text()
  60. if !strings.Contains(IPString, "/") { // 如果不含有 / 则代表不是 IP 段,而是一个单独的 IP,因此需要加上 /32 /128 子网掩码
  61. if ipv6Mode {
  62. IPString += "/128"
  63. } else {
  64. IPString += "/32"
  65. }
  66. }
  67. firstIP, IPRange, err := net.ParseCIDR(IPString)
  68. //fmt.Println(firstIP)
  69. //fmt.Println(IPRange)
  70. if err != nil {
  71. log.Fatal(err)
  72. }
  73. if !ipv6Mode { // IPv4
  74. minIP, maxIP := getCidrIPRange(IPString) // 获取 IP 最后一段最小值和最大值
  75. Mask, _ := strconv.Atoi(strings.Split(IPString, "/")[1]) // 获取子网掩码
  76. MaxIPNum := getCidrHostNum(Mask) // 根据子网掩码获取主机数量
  77. for IPRange.Contains(firstIP) {
  78. if allip { // 如果是测速全部 IP
  79. for i := int(minIP); i <= int(maxIP); i++ { // 遍历 IP 最后一段最小值到最大值
  80. firstIP[15] = uint8(i)
  81. firstIPCopy := make([]byte, len(firstIP))
  82. copy(firstIPCopy, firstIP)
  83. firstIPs = append(firstIPs, net.IPAddr{IP: firstIPCopy})
  84. }
  85. } else { // 随机 IP 的最后一段 0.0.0.X
  86. firstIP[15] = minIP + randipEndWith(MaxIPNum)
  87. firstIPCopy := make([]byte, len(firstIP))
  88. copy(firstIPCopy, firstIP)
  89. firstIPs = append(firstIPs, net.IPAddr{IP: firstIPCopy})
  90. }
  91. firstIP[14]++ // 0.0.(X+1).X
  92. if firstIP[14] == 0 {
  93. firstIP[13]++ // 0.(X+1).X.X
  94. if firstIP[13] == 0 {
  95. firstIP[12]++ // (X+1).X.X.X
  96. }
  97. }
  98. }
  99. } else { //IPv6
  100. var tempIP uint8
  101. for IPRange.Contains(firstIP) {
  102. //fmt.Println(firstIP)
  103. //fmt.Println(firstIP[0], firstIP[1], firstIP[2], firstIP[3], firstIP[4], firstIP[5], firstIP[6], firstIP[7], firstIP[8], firstIP[9], firstIP[10], firstIP[11], firstIP[12], firstIP[13], firstIP[14], firstIP[15])
  104. if !strings.Contains(IPString, "/128") {
  105. firstIP[15] = randipEndWith(255) // 随机 IP 的最后一段
  106. firstIP[14] = randipEndWith(255) // 随机 IP 的最后一段
  107. }
  108. firstIPCopy := make([]byte, len(firstIP))
  109. copy(firstIPCopy, firstIP)
  110. firstIPs = append(firstIPs, net.IPAddr{IP: firstIPCopy})
  111. tempIP = firstIP[13]
  112. firstIP[13] += randipEndWith(255)
  113. if firstIP[13] < tempIP {
  114. tempIP = firstIP[12]
  115. firstIP[12] += randipEndWith(255)
  116. if firstIP[12] < tempIP {
  117. tempIP = firstIP[11]
  118. firstIP[11] += randipEndWith(255)
  119. if firstIP[11] < tempIP {
  120. tempIP = firstIP[10]
  121. firstIP[10] += randipEndWith(255)
  122. if firstIP[10] < tempIP {
  123. tempIP = firstIP[9]
  124. firstIP[9] += randipEndWith(255)
  125. if firstIP[9] < tempIP {
  126. tempIP = firstIP[8]
  127. firstIP[8] += randipEndWith(255)
  128. if firstIP[8] < tempIP {
  129. tempIP = firstIP[7]
  130. firstIP[7] += randipEndWith(255)
  131. if firstIP[7] < tempIP {
  132. tempIP = firstIP[6]
  133. firstIP[6] += randipEndWith(255)
  134. if firstIP[6] < tempIP {
  135. tempIP = firstIP[5]
  136. firstIP[5] += randipEndWith(255)
  137. if firstIP[5] < tempIP {
  138. tempIP = firstIP[4]
  139. firstIP[4] += randipEndWith(255)
  140. if firstIP[4] < tempIP {
  141. tempIP = firstIP[3]
  142. firstIP[3] += randipEndWith(255)
  143. if firstIP[3] < tempIP {
  144. tempIP = firstIP[2]
  145. firstIP[2] += randipEndWith(255)
  146. if firstIP[2] < tempIP {
  147. tempIP = firstIP[1]
  148. firstIP[1] += randipEndWith(255)
  149. if firstIP[1] < tempIP {
  150. tempIP = firstIP[0]
  151. firstIP[0] += randipEndWith(255)
  152. }
  153. }
  154. }
  155. }
  156. }
  157. }
  158. }
  159. }
  160. }
  161. }
  162. }
  163. }
  164. }
  165. }
  166. }
  167. }
  168. return firstIPs
  169. }