当前位置:首页 > 未分类 > 正文内容

PHP 如何实现 URL 安全的 Base64 编码

admin1年前 (2024-02-06)未分类517

URL 安全的 Base64

由于标准的 Base64 编码后可能出现字符 + 和 / ,在 URL 中就不能直接作为参数,所以 URL 安全的 Base64 编码,需要把字符 + 和 / 分别变成 - 和 _,另外 = 字符也可能出现在 Base64 编码中,但 = 用在URL、Cookie 里面会造成歧义,所以,很多 URL 安全的 Base64 编码也会把 = 去掉:

function base64_urlencode($str){
    return rtrim(strtr(base64_encode($str), '+/', '-_'), '=');
}

去掉 = 后怎么解码呢?因为 Base64 是把 3 个字节变为 4 个字节,所以 Base64 编码的长度永远是 4 的倍数,因此,需要加上 = 把 Base64 字符串的长度变为 4 的倍数,就可以正常解码了,然后再把 - 和 _ 替换换回+ 和 /:

function base64_urldecode($str){
    return base64_decode(str_pad(strtr($str, '-_', '+/'), strlen($str) % 4, '='));
}


参考文章:https://www.cainiaoxueyuan.com/ymba/46667.html

扫描二维码推送至手机访问。

版权声明:本文由服务端开发技术分享发布,如需转载请注明出处。

本文链接:https://www.htmlcms.cn/?id=6

分享给朋友:

相关文章

数据库--MySQL:Failed to start LSB: start and stop MySQL.

mysql 启动失败Failed to start LSB: start and stop MySQL.Starting MySQL....The server quit without updating PID file (……查看错误日...

_initialize 和 __construct中不能return

1、构造函数是一个没有返回值的特殊函数,所有即使加上return也没意义,他不会执行的。2、不仅php,所有面向对象的语言的构造函数都没有return。因此正确的方法应该为:namespace app\service\contro...

ThinkPHP6,where和whereLike同时用踩坑记录

ThinkPHP6,where和whereLike同时用踩坑记录。。。// 以下示例共用条件  $where_or=[];    $where_or_i=[];  &...

MySQL 中 where in 长度过长的解决方法

在使用MySQL数据库时,我们经常会使用 where in 语句来查询一组特定的值,例如:SELECT * FROM students WHERE id IN (1,&n...

PHP去除数组中的 0

1. 使用array_filter()函数$array = [1, 0, 2, 0, 3, 0]; $array = array_filter($a...

MySQL 3个字段作为一个字段输出

在MySQL中,如果你想将3个字段合并成一个字段输出,可以使用CONCAT()函数或者CONCAT_WS()函数。这两个函数都可以用来连接字符串,但CONCAT_WS()允许你指定一个分隔符。1. 使用CONCAT() CONCAT()函数...