如何使用 Http 客户端(有可选更改)将 Symfony 请求转发到另一台服务器?
How to forward a Symfony Request to another server using the Http Client (with optional changes)?
如何截取请求并将其与 HttpClient
一起发送到另一台服务器并 return 修改后来自该服务器的响应?
原始请求将包含数据和文件。我正在寻找最不冗长的解决方案,直到将原始 body 复制为字符串。我坚持的部分是以最短的方式将 Request
object 插入 HttpClient
请求 (无需编写代码来复制数据和 headers 位by bit),剩下的(处理响应)我来处理。
Symfony 的 Http 客户端不接受 HttpFoundation\Request
作为发出新请求的参数。
您需要“手动”将 Request
object 转换为必要的参数(包括转换路径、方法、传递适当的 headers 等)。
然后,您必须根据客户端的响应创建一个 HttpFoundation\Response
(同样,不能简单地在您的控制器中发回)。
根据你的具体要求,不是特别繁重。一个天真的,可能有错误的实现会是这样的:
use Symfony\Component\HttpFoundation;
use Symfony\Contracts\HttpClient\HttpClientInterface;
class FooProxy
{
public function __construct(private HttpClientInterface $client)
{
}
public function __invoke(HttpFoundation\Request $request): HttpFoundation\Response
{
$options = [];
$newServer = 'https://www.example.com';
$options['headers'] = $request->headers->all();
$options['body'] = $request->getContent();
$clientResponse = $this->client->request(
$request->getMethod(),
$newServer . $request->getRequestUri(),
$options
);
return new HttpFoundation\Response(
$clientResponse->getContent(false),
$clientResponse->getStatusCode(),
$clientResponse->getHeaders(false)
);
}
}
同样,这是非常天真的实现。您需要确保处理任何异常和边缘情况。
考虑到 PHP 不是构建真正 HTTP 代理的最佳语言选择。
如何截取请求并将其与 HttpClient
一起发送到另一台服务器并 return 修改后来自该服务器的响应?
原始请求将包含数据和文件。我正在寻找最不冗长的解决方案,直到将原始 body 复制为字符串。我坚持的部分是以最短的方式将 Request
object 插入 HttpClient
请求 (无需编写代码来复制数据和 headers 位by bit),剩下的(处理响应)我来处理。
Symfony 的 Http 客户端不接受 HttpFoundation\Request
作为发出新请求的参数。
您需要“手动”将 Request
object 转换为必要的参数(包括转换路径、方法、传递适当的 headers 等)。
然后,您必须根据客户端的响应创建一个 HttpFoundation\Response
(同样,不能简单地在您的控制器中发回)。
根据你的具体要求,不是特别繁重。一个天真的,可能有错误的实现会是这样的:
use Symfony\Component\HttpFoundation;
use Symfony\Contracts\HttpClient\HttpClientInterface;
class FooProxy
{
public function __construct(private HttpClientInterface $client)
{
}
public function __invoke(HttpFoundation\Request $request): HttpFoundation\Response
{
$options = [];
$newServer = 'https://www.example.com';
$options['headers'] = $request->headers->all();
$options['body'] = $request->getContent();
$clientResponse = $this->client->request(
$request->getMethod(),
$newServer . $request->getRequestUri(),
$options
);
return new HttpFoundation\Response(
$clientResponse->getContent(false),
$clientResponse->getStatusCode(),
$clientResponse->getHeaders(false)
);
}
}
同样,这是非常天真的实现。您需要确保处理任何异常和边缘情况。
考虑到 PHP 不是构建真正 HTTP 代理的最佳语言选择。