在线文档教程
PHP
联网 | Networking

rawurlencode

rawurlencode

(PHP 4, PHP 5, PHP 7)

rawurlencode — URL-encode according to RFC 3986

Description

string rawurlencode ( string $str )

Encodes the given string according to » RFC 3986.

Parameters

str

The URL to be encoded.

Return Values

Returns a string in which all non-alphanumeric characters except -_.~ have been replaced with a percent (%) sign followed by two hex digits. This is the encoding described in » RFC 3986 for protecting literal characters from being interpreted as special URL delimiters, and for protecting URLs from being mangled by transmission media with character conversions (like some email systems).

Note: Prior to PHP 5.3.0, rawurlencode encoded tildes (~) as per » RFC 1738.

Changelog

VersionDescription
5.3.4Tilde characters are no longer encoded when rawurlencode() is used with EBCDIC strings.
5.3.0Now conforms to » RFC 3986.

Examples

Example #1 including a password in an FTP URL

<?php echo '<a href="ftp://user:', rawurlencode('foo @+%/'),      '@ftp.example.com/x.txt">'; ?>

The above example will output:

<a href="ftp://user:foo%20%40%2B%25%2F@ftp.example.com/x.txt">

Or, if you pass information in a PATH_INFO component of the URL:

Example #2 rawurlencode() example 2

<?php echo '<a href="http://example.com/department_list_script/',     rawurlencode('sales and marketing/Miami'), '">'; ?>

The above example will output:

<a href="http://example.com/department_list_script/sales%20and%20marketing%2FMiami">

See Also

  • rawurldecode() - Decode URL-encoded strings

  • urldecode() - Decodes URL-encoded string

  • urlencode() - URL-encodes string

← rawurldecode

urldecode →

© 1997–2017 The PHP Documentation Group

Licensed under the Creative Commons Attribution License v3.0 or later.

https://secure.php.net/manual/en/function.rawurlencode.php