Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
c6c29db9
Commit
c6c29db9
authored
Aug 14, 2014
by
Paweł 'Zibi' Zaremba
Committed by
Qiang Xue
Aug 14, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixes #4636: Added `yii\web\Response::setDownloadHeaders()`
parent
4846643f
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
32 additions
and
15 deletions
+32
-15
CHANGELOG.md
framework/CHANGELOG.md
+1
-0
Response.php
framework/web/Response.php
+31
-15
No files found.
framework/CHANGELOG.md
View file @
c6c29db9
...
...
@@ -180,6 +180,7 @@ Yii Framework 2 Change Log
-
Enh #4602: Added $key param in ActionColumn buttons Closure call (disem)
-
Enh #4607: AR model will throw an exception if it does not have a primary key to avoid updating/deleting data massively (qiangxue)
-
Enh #4630: Added automatic generating of unique slug value to
`yii\behaviors\Sluggable`
(klimov-paul)
-
Enh #4636: Added
`yii\web\Response::setDownloadHeaders()`
(pawzar)
-
Enh #4644: Added
`\yii\db\Schema::createColumnSchema()`
to be able to customize column schema used (mcd-php)
-
Enh #4656: HtmlPurifier helper config can now be a closure to change the purifier config object after it was created (Alex-Code)
-
Enh #4691: Encoding on
`ActiveForm`
and
`ActiveField`
validation errors is now configurable (Alex-Code)
...
...
framework/web/Response.php
View file @
c6c29db9
...
...
@@ -455,24 +455,19 @@ class Response extends \yii\base\Response
public
function
sendContentAsFile
(
$content
,
$attachmentName
,
$mimeType
=
'application/octet-stream'
)
{
$headers
=
$this
->
getHeaders
();
$contentLength
=
StringHelper
::
byteLength
(
$content
);
$range
=
$this
->
getHttpRange
(
$contentLength
);
if
(
$range
===
false
)
{
$headers
->
set
(
'Content-Range'
,
"bytes */
$contentLength
"
);
throw
new
HttpException
(
416
,
'Requested range not satisfiable'
);
}
$headers
->
setDefault
(
'Pragma'
,
'public'
)
->
setDefault
(
'Accept-Ranges'
,
'bytes'
)
->
setDefault
(
'Expires'
,
'0'
)
->
setDefault
(
'Content-Type'
,
$mimeType
)
->
setDefault
(
'Cache-Control'
,
'must-revalidate, post-check=0, pre-check=0'
)
->
setDefault
(
'Content-Transfer-Encoding'
,
'binary'
)
->
setDefault
(
'Content-Length'
,
StringHelper
::
byteLength
(
$content
))
->
setDefault
(
'Content-Disposition'
,
"attachment; filename=
\"
$attachmentName
\"
"
);
$this
->
setDownloadHeaders
(
$attachmentName
,
$mimeType
,
$contentLength
);
list
(
$begin
,
$end
)
=
$range
;
if
(
$begin
!=
0
||
$end
!=
$contentLength
-
1
)
{
if
(
$begin
!=
0
||
$end
!=
$contentLength
-
1
)
{
$this
->
setStatusCode
(
206
);
$headers
->
set
(
'Content-Range'
,
"bytes
$begin
-
$end
/
$contentLength
"
);
$this
->
content
=
StringHelper
::
byteSubstr
(
$content
,
$begin
,
$end
-
$begin
+
1
);
...
...
@@ -511,25 +506,46 @@ class Response extends \yii\base\Response
}
list
(
$begin
,
$end
)
=
$range
;
if
(
$begin
!=
0
||
$end
!=
$fileSize
-
1
)
{
if
(
$begin
!=
0
||
$end
!=
$fileSize
-
1
)
{
$this
->
setStatusCode
(
206
);
$headers
->
set
(
'Content-Range'
,
"bytes
$begin
-
$end
/
$fileSize
"
);
}
else
{
$this
->
setStatusCode
(
200
);
}
$length
=
$end
-
$begin
+
1
;
$this
->
setDownloadHeaders
(
$attachmentName
,
$mimeType
,
$end
-
$begin
+
1
);
$this
->
format
=
self
::
FORMAT_RAW
;
$this
->
stream
=
[
$handle
,
$begin
,
$end
];
return
$this
;
}
/**
* Sets a default set of HTTP headers for file downloading purpose.
* @param string $attachmentName the attachment file name
* @param string $mimeType the MIME type for the response. If null, `Content-Type` header will NOT be set.
* @param integer $contentLength the byte length of the file being downloaded. If null, `Content-Length` header will NOT be set.
* @return static the response object itself
*/
public
function
setDownloadHeaders
(
$attachmentName
,
$mimeType
=
null
,
$contentLength
=
null
)
{
$headers
=
$this
->
getHeaders
();
$headers
->
setDefault
(
'Pragma'
,
'public'
)
->
setDefault
(
'Accept-Ranges'
,
'bytes'
)
->
setDefault
(
'Expires'
,
'0'
)
->
setDefault
(
'Content-Type'
,
$mimeType
)
->
setDefault
(
'Cache-Control'
,
'must-revalidate, post-check=0, pre-check=0'
)
->
setDefault
(
'Content-Transfer-Encoding'
,
'binary'
)
->
setDefault
(
'Content-Length'
,
$length
)
->
setDefault
(
'Content-Disposition'
,
"attachment; filename=
\"
$attachmentName
\"
"
);
$this
->
format
=
self
::
FORMAT_RAW
;
$this
->
stream
=
[
$handle
,
$begin
,
$end
];
if
(
$mimeType
!==
null
)
{
$headers
->
setDefault
(
'Content-Type'
,
$mimeType
);
}
if
(
$contentLength
!==
null
)
{
$headers
->
setDefault
(
'Content-Length'
,
$contentLength
);
}
return
$this
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment