环境: Guzzle 6 交响乐 2.3
通过 Guzzle POST 请求上传多个文件 should be done with a multipart request .所以我像这样配置我的 $options 数组:
Array
(
[multipart] => Array
(
[0] => Array
(
[name] => filename-0
[contents] => Resource id #440
[filename] => filename-0
)
[1] => Array
(
[name] => filename-1
[contents] => Resource id #441
[filename] => filename-1
)
[2] => Array
(
[name] => filename-2
[contents] => Resource id #442
[filename] => filename-2
)
)
[headers] => Array
(
[Accept] => application/json
[Content-Type] => multipart/form-data
[Accept-Language] => de
)
[allow_redirects] =>
[http_errors] =>
)
多部分数组中的资源是 fopen() 的结果。
并使用
发送请求$response = $this->client->post(
'/someUrl/someAction',
$options
);
使用已经创建的客户端。
在接受 Symfony-Controllers 方面,我无法发送文件:
var_dump($_FILES); // array(0) {}
var_dump($_POST); // array(0) {}
var_dump(count($request->files->all())); // int(0)
但是,这两者:
var_dump(file_get_contents("php://input"));
var_dump($request->getContent());
在输入流上返回数据:
/myPath/FileController.php:xx:
string(601) "--e55f849feb078da4a9e35ba77da3ded02ec813a7
Content-Disposition: form-data; name="filename-0"; filename="filename-0"
Content-Length: 43
This is a testfile...
--e55f849feb078da4a9e35ba77da3ded02ec813a7
Content-Disposition: form-data; name="filename-1"; filename="filename-1"
Content-Length: 43
This is a testfile...
--e55f849feb078da4a9e35ba77da3ded02ec813a7
Content-Disposition: form-data; name="filename-2"; filename="filename-2"
Content-Length: 43
This is a testfile...
--e55f849feb078da4a9e35ba77da3ded02ec813a7--
"
我怎样才能以 Symfony 方式进入接收 Controller ?
考虑的好奇心: Controller 报告
var_dump($request->getContentType()); // NULL
我的直觉告诉我这可能很重要。
最佳答案
当使用multipart 选项时,您不能自己指定Content-Type header 。 Guzzle 将处理这个问题,并且 - 对于这个问题更重要的是 - 将原始请求正文中的内容部分分开的边界。主要的 Content-Type header 定义该边界,如下所示:
Content-Type: multipart/form-data; boundary=unique-string-that-is-hopefully-not-used-in-the-real-content-because-it-separates-the-content-parts`
检查 Client.php#L308 :
当使用 multipart 选项时,Guzzle 将请求主体创建为 GuzzleHttp\Psr7\MultipartStream 对象。
然后检查 MultipartStream.php#L30 处的 MultipartStream 构造函数:
创建一个随机值用作边界:sha1(uniqid('', true))
然后 Guzzle 将使用边界自行在 Client.php#L383 处设置正确的内容类型.
但由于 Guzzle 不会覆盖您明确指定的选项,因此主 header 指定了一个空边界,原始正文部分将由 MultpartStream 构造函数创建的部分分隔。在接收端,PHP 无法再分离内容部分。
这段代码对我有用:
(new GuzzleHttp\Client())->request(
'POST',
'http://localhost/upload',
[
'multipart' => [
[
'name' => 'filename-0',
'contents' => fopen(__DIR__.'/sample-0.txt', 'rb'),
'filename' => 'filename-0',
],
[
'name' => 'filename-1',
'contents' => fopen(__DIR__.'/sample-1.txt', 'rb'),
'filename' => 'filename-1',
],
[
'name' => 'filename-2',
'contents' => fopen(__DIR__.'/sample-2.txt', 'rb'),
'filename' => 'filename-2',
],
],
'headers' => [
# Do not override the Content-Type header here, Guzzle takes care of it
] ,
]
);
请注意,所有这些都与 Symfony 无关,即 Symfony 只是根据它可以通过 PHP 的 native 资源(如 $_FILES、 >$_POST 等 你能够看到原始请求正文($request->getContent())中的所有内容,因为它是这样发送的,但 PHP 无法拆分内容部分,因为它不知道正确的边界。
关于php - Symfony 无法识别通过 Guzzle 多部分/表单数据请求上传的多个文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47550801/
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta