从 HTTP 请求中提取用户代理

Extract the User-Agent from HTTP request

我正在尝试从 HTTP 请求中获取 User-Agent 值并将其放入一个名为“UserAgent”的单独字段中,但到目前为止还没有成功。看起来我需要查看回车 return 和换行符? 将不胜感激。
下面是 regex101 link.

https://regex101.com/r/rdu8yE/1

POST /xxx/yyyy HTTP/1.1\r\nUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:86.0) Gecko/20100101 Firefox/86.0\r\nAccept: application/json\r\nAccept-Language: en-US,en;q=0.5\r\nX-XSRF-TOKEN: 989g8ddfgdf7979df\r\ntimestamp: 2021-04-07T18:35:50.639Z\r\nContent-Type: application/json;charset=utf-8\r\nContent-Length: 340\r\nOrigin: https://example.com\r\nConnection: keep-alive\r\nReferer: https://my.example.com\r\n

也许是这个? ^.*?User-Agent: (?<UserAgent>.*?)\r\n

比你需要的多一点,选择从字符串的开头开始选择,消耗但不捕获用户代理信号之前的所有内容(这里我使用CRLFUser-Agent:),然后捕获所有内容,但不包括下一个 CRLF。

您的原始正则表达式:User-Agent: (?<UserAgent>[^\r\n]*) 将 'n' 作为 class 符号的一部分,这些符号的存在将停止捕获(在方括号中定义),因此您只能捕获直到'Windows'.

这个词的中途

如果不清楚,请回复:)。