//PHP base64_encode
php
function str_encode($str){
return base64_encode(iconv('GB18030','UTF-8',$str));
}
echo str_encode('你好!美女!');
?>
//////////////////////////////////////////////////////////////////////////////////////
另附PHP的base64的加解密函数!
{echo base64_encode($str)."
"; //加密
$ss='Z25pZD0yNSZncGljaT0x';
echo base64_decode($ss); //解密
/////////////////////////////////////////////////////////////////////////////////////
//JavaScript base64_decode
<script language='<a style="color:#f60; text-decoration:underline;" title= "javascript" href="https://www.php.cn/zt/15724.html" target="_blank">javascript</a>'> <br>/* utf.js - UTF-8 <=> UTF-16 convertion <br>* <br>* Copyright (C) 1999 Masanao Izumo <iz@onicos.co.jp> <br>* Version: 1.0 <br>* LastModified: Dec 25 1999 <br>* This library is free. You can redistribute it and/or modify it. <br>*/ <br><br>/* <br>* Interfaces: <br>* utf8 = utf16to8(utf16); <br>* utf16 = utf16to8(utf8); <br>*/ <br><br>function utf16to8(str) { <br>var out, i, len, c; <br><br>out = ""; <br>len = str.length; <br>for(i = 0; i < len; i++) { <br>c = str.charCodeAt(i); <br>if ((c >= 0x0001) && (c <= 0x007F)) { <br>out += str.charAt(i); <br>} else if (c > 0x07FF) { <br>out += String.fromCharCode(0xE0 | ((c >> 12) & 0x0F)); <br>out += String.fromCharCode(0x80 | ((c >> 6) & 0x3F)); <br>out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F)); <br>} else { <br>out += String.fromCharCode(0xC0 | ((c >> 6) & 0x1F)); <br>out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F)); <br>} <br>} <br>return out; <br>} <br><br>function utf8to16(str) { <br>var out, i, len, c; <br>var char2, char3; <br><br>out = ""; <br>len = str.length; <br>i = 0; <br>while(i < len) { <br>c = str.charCodeAt(i++); <br>switch(c >> 4) <br>{ <br>case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7: <br>// 0xxxxxxx <br>out += str.charAt(i-1); <br>break; <br>case 12: case 13: <br>// 110x xxxx 10xx xxxx <br>char2 = str.charCodeAt(i++); <br>out += String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F)); <br>break; <br>case 14: <br>// 1110 xxxx 10xx xxxx 10xx xxxx <br>char2 = str.charCodeAt(i++); <br>char3 = str.charCodeAt(i++); <br>out += String.fromCharCode(((c & 0x0F) << 12) | <br>((char2 & 0x3F) << 6) | <br>((char3 & 0x3F) << 0)); <br>break; <br>} <br>} <br><br>return out; <br>} <br><br>/* Copyright (C) 1999 Masanao Izumo <iz@onicos.co.jp> <br>* Version: 1.0 <br>* LastModified: Dec 25 1999 <br>* This library is free. You can redistribute it and/or modify it. <br>*/ <br><br>/* <br>* Interfaces: <br>* b64 = base64encode(data); <br>* data = base64decode(b64); <br>*/ <br><br><br>var base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; <br>var base64DecodeChars = new Array( <br>-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, <br>-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, <br>-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63, <br>52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1, <br>-1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, <br>15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1, <br>-1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, <br>41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1); <br><br>function base64encode(str) { <br>var out, i, len; <br>var c1, c2, c3; <br><br>len = str.length; <br>i = 0; <br>out = ""; <br>while(i < len) { <br>c1 = str.charCodeAt(i++) & 0xff; <br>if(i == len) <br>{ <br>out += base64EncodeChars.charAt(c1 >> 2); <br>out += base64EncodeChars.charAt((c1 & 0x3) << 4); <br>out += "=="; <br>break; <br>} <br>c2 = str.charCodeAt(i++); <br>if(i == len) <br>{ <br>out += base64EncodeChars.charAt(c1 >> 2); <br>out += base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4)); <br>out += base64EncodeChars.charAt((c2 & 0xF) << 2); <br>out += "="; <br>break; <br>} <br>c3 = str.charCodeAt(i++); <br>out += base64EncodeChars.charAt(c1 >> 2); <br>out += base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4)); <br>out += base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >>6)); <br>out += base64EncodeChars.charAt(c3 & 0x3F); <br>} <br>return out; <br>} <br><br>function base64decode(str) { <br>var c1, c2, c3, c4; <br>var i, len, out; <br><br>len = str.length; <br>i = 0; <br>out = ""; <br>while(i < len) { <br>/* c1 */ <br>do { <br>c1 = base64DecodeChars[str.charCodeAt(i++) & 0xff]; <br>} while(i < len && c1 == -1); <br>if(c1 == -1) <br>break; <br><br>/* c2 */ <br>do { <br>c2 = base64DecodeChars[str.charCodeAt(i++) & 0xff]; <br>} while(i < len && c2 == -1); <br>if(c2 == -1) <br>break; <br><br>out += String.fromCharCode((c1 << 2) | ((c2 & 0x30) >> 4)); <br><br>/* c3 */ <br>do { <br>c3 = str.charCodeAt(i++) & 0xff; <br>if(c3 == 61) <br>return out; <br>c3 = base64DecodeChars[c3]; <br>} while(i < len && c3 == -1); <br>if(c3 == -1) <br>break; <br><br>out += String.fromCharCode(((c2 & 0XF) << 4) | ((c3 & 0x3C) >> 2)); <br><br>/* c4 */ <br>do { <br>c4 = str.charCodeAt(i++) & 0xff; <br>if(c4 == 61) <br>return out; <br>c4 = base64DecodeChars[c4]; <br>} while(i < len && c4 == -1); <br>if(c4 == -1) <br>break; <br>out += String.fromCharCode(((c3 & 0x03) << 6) | c4); <br>} <br>return out; <br>} <br>//input base64 encode <br>function strdecode(str){ <br>return utf8to16(base64decode(str)); <br>} <br>document.write(strdecode('5L2g5aW9Iee+juWlsyE=')); <br></script>
0
0
相关文章
PHP时区设置与夏令时冲突怎么办_自动处理夏令时的方法【教程】
如何在 PDO 查询结果中准确判断是否存在有效商品数据
PHP变量怎么从函数返回_PHP函数返回变量操作【说明】
PHP 中使用 while 循环查找命令行参数中的最大值
PHP过低怎样优化新版性能_PHP过低新版优化技巧【性能】
相关标签:
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。
797
2026.02.13
本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。
272
2026.02.13
本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。
144
2026.02.13
本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。
25
2026.02.13
本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。
92
2026.02.13
本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。
15
2026.02.12
本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。
717
2026.02.12
本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。
64
2026.02.12
热门下载
相关下载
精品课程
最新文章


