本文整理匯總了PHP中yii\helpers\Inflector::transliterate方法的典型用法代碼示例。如果您正苦於以下問題:PHP Inflector::transliterate方法的具體用法?PHP Inflector::transliterate怎麽用?PHP Inflector::transliterate使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類yii\helpers\Inflector
的用法示例。
在下文中一共展示了Inflector::transliterate方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: getDispositionHeaderValue
/**
* Returns Content-Disposition header value that is safe to use with both old and new browsers
*
* Fallback name:
*
* - Causes issues if contains non-ASCII characters with codes less than 32 or more than 126.
* - Causes issues if contains urlencoded characters (starting with `%`) or `%` character. Some browsers interpret
* `filename="X"` as urlencoded name, some don't.
* - Causes issues if contains path separator characters such as `\` or `/`.
* - Since value is wrapped with `"`, it should be escaped as `\"`.
* - Since input could contain non-ASCII characters, fallback is obtained by transliteration.
*
* UTF name:
*
* - Causes issues if contains path separator characters such as `\` or `/`.
* - Should be urlencoded since headers are ASCII-only.
* - Could be omitted if it exactly matches fallback name.
*
* @param string $disposition
* @param string $attachmentName
* @return string
*
* @since 2.0.10
*/
protected function getDispositionHeaderValue($disposition, $attachmentName)
{
$fallbackName = str_replace('"', '\\"', str_replace(['%', '/', '\\'], '_', Inflector::transliterate($attachmentName, Inflector::TRANSLITERATE_LOOSE)));
$utfName = rawurlencode(str_replace(['%', '/', '\\'], '', $attachmentName));
$dispositionHeader = "{$disposition}; filename=\"{$fallbackName}\"";
if ($utfName !== $fallbackName) {
$dispositionHeader .= "; filename*=utf-8''{$utfName}";
}
return $dispositionHeader;
}