使用自定义攻击者在 Vegeta 中发送 POST 请求中的负载

Sending payload in POST request in Vegeta with custom attacker

所以我看到一些帖子说你应该将目标放在临时文件中,而 body 放在 .json 文件中,但我需要发送很多随机文件数据到我的网站,理想情况下我不想不断地向这些文件写入新的随机数据——所以我想在一个文件中完成所有这些工作。如果这是不可能的并且我使用多个文件,请告诉我。

我现在要做的就是向网页发送一个 POST 请求,该网页只是一个包含 4 个输入的表单:标题、编号、卷数和年份。我有以下代码,但现在它没有发送值。它正在发送一个有效负载,但没有任何值。这意味着键 [] 和值 "" 不断存储在后端的地图中。任何人都可以看到它发送空白的原因吗?谁能告诉我应该如何修复它?

package main

import (
    "encoding/json"
    "fmt"
    "time"

    vegeta "github.com/tsenart/vegeta/lib"
)

func NewCustomTargeter() vegeta.Targeter {
    return func(tgt *vegeta.Target) error {
        if tgt == nil {
            return vegeta.ErrNilTarget
        }

        tgt.Method = "POST"

        tgt.URL = "http://localhost:8080/create.html"

        payload := map[string]string{
            "title":  "junk",
            "number": "junk2",
            "volume": "junk3",
            "year":   "junk4",
        }
        body, _ := json.Marshal(payload)
        tgt.Body = []byte(body)
        return nil
    }
}

func main() {
    rate := vegeta.Rate{Freq: 100, Per: 2 * time.Second}
    duration := 10 * time.Second
    targeter := NewCustomTargeter()
    attacker := vegeta.NewAttacker()
    var metrics vegeta.Metrics
    for res := range attacker.Attack(targeter, rate, duration, "Load Test") {
        metrics.Add(res)
    }
    metrics.Close()
    fmt.Printf("%+v  \n", metrics)

}

你需要做一些事情来让攻击者能够发送 FormData 格式的数据。

首先,将 Content-type header 值设置为 application/x-www-form-urlencoded。您可能需要导入 net/http 包。

header := http.Header{}
header.Set("Content-type", "application/x-www-form-urlencoded")
tgt.Header = header

然后,将数据设置为url.Values格式。将它的编码值传给tgt.Body。您还需要导入 net/url 包。

form := url.Values{}
form.Set("title", "junk")
form.Set("number", "junk2")
form.Set("volume", "junk3")
form.Set("year", "junk4")

tgt.Body = []byte(form.Encode())

补充说明

在数据准备上,我们也可以使用map literal样式。
但是由于url.Valuesmap[string][]string的别名(不是map[string]string),
可能需要一些调整。

form := url.Values{
    "title":  []string{"junk"},
    "number": []string{"junk2"},
    "volume": []string{"junk3"},
    "year":   []string{"junk4"},
}