J'utilise une connexion TCP écrite en Golang pour envoyer une requête curl depuis la console. Il s'agit donc essentiellement d'un flux de données. Je peux recevoir les données avec succès et les stocker dans le tampon en utilisant le code suivant
func PushDataToBuffer(bufferedChannel chan []byte, conn net.Conn) { defer conn.Close() fmt.Println("pushing messages into buffer...") buffer := make([]byte, 2048) // 2048 = assumption for reasonable event byte size for { n, err := conn.Read(buffer) if err != nil { fmt.Println("read error: ", err) continue // to continue listening for connections } bufferedChannel <- buffer[:n] } }
Mais quand j'essaie de lire ces données en utilisant ce code :
for data := range bufferedChannel { fmt.Println("The len of buffer is: ", len(bufferedChannel)) dataObject := models.Event{} err := json.Unmarshal(data, &dataObject) }
J'obtiens l'erreur suivante
Invalid character 'P' looking for beginning of value 2024/01/29 09:40:31 syntax error at byte offset 1
Quand j'ai imprimé les données elles-mêmes, j'ai vu ceci
POST / HTTP/1.1 Host: localhost:8952 User-Agent: curl/7.77.0 Accept: */* Content-Type: application/json Content-Length: 232 {\"customer\":\"Ada\",\"eventtype\":\"BuyingApples\",\"time\":\"0001-01-01T00:00:00Z\",\"specifics\":[{\"Key\":\"Shop\",\"Value\":\"Bakery\"},{\"Key\":\"Location\",\"Value\":\"Downtown\"},{\"Key\":\"recommends\",\"Value\":\"yes\"}]}
De ce qui précède, vous pouvez clairement voir où se situe le problème. Il ajoute des en-têtes aux données, c'est donc POST
中的 P
ce dont se plaint Golang. C'est pourquoi je ne peux pas le démonter. Voici donc ma question:
Comment envoyer les données au serveur ou les découper au fur et à mesure de leur arrivée, je n'utiliserai que la partie json :
{\"customer\":\"Ada\",\"eventtype\":\"BuyingApples\",\"time\":\"0001-01-01T00:00:00Z\",\"specifics\":[{\"Key\":\"Shop\",\"Value\":\"Bakery\"},{\"Key\":\"Location\",\"Value\":\"Downtown\"},{\"Key\":\"recommends\",\"Value\":\"yes\"}]}
P.S - J'utilise une connexion TCP pour obtenir les données au lieu de http
J'ai cherché diverses solutions en ligne, mais je n'en ai pas trouvé une qui corresponde à mon cas d'utilisation
cURL n'est pas un client TCP. Il s'agit d'un client HTTP et génère naturellement des en-têtes natifs du protocole (tels que la méthode et le chemin de la requête). C'est ce qui est finalement envoyé via la connexion TCP. Par conséquent, il existe une inadéquation entre ce que le serveur attend (TCP simple) et ce que le client envoie (HTTP).
Vous devez mettre à jour le code de votre serveur pour analyser les données brutes dans une requête HTTP, telle que http .ReadRequest, ou simplement utiliser un client qui envoie la charge utile attendue sur le réseau - c'est-à-dire TCP simple. Netcat rendra cela facile. Sans savoir grand-chose du problème que vous essayez de résoudre, je recommanderais par défaut cette dernière approche (car pourquoi envoyer HTTP alors que vous avez besoin de TCP en premier lieu ?).
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!