`

微信昵称乱码

    博客分类:
  • PHP
阅读更多




数据库base64_encode()存入 
再base64_decode()解码


问题解决


  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

    <script type="text/javascript">
        <!--
        var keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
        //将Ansi编码的字符串进行Base64编码
        function encode64(input) {
            var output = "";
            var chr1, chr2, chr3 = "";
            var enc1, enc2, enc3, enc4 = "";
            var i = 0;
            do {
                chr1 = input.charCodeAt(i++);
                chr2 = input.charCodeAt(i++);
                chr3 = input.charCodeAt(i++);
                enc1 = chr1 >> 2;
                enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
                enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
                enc4 = chr3 & 63;
                if (isNaN(chr2)) {
                    enc3 = enc4 = 64;
                } else if (isNaN(chr3)) {
                    enc4 = 64;
                }
                output = output + keyStr.charAt(enc1) + keyStr.charAt(enc2)
                + keyStr.charAt(enc3) + keyStr.charAt(enc4);
                chr1 = chr2 = chr3 = "";
                enc1 = enc2 = enc3 = enc4 = "";
            } while (i < input.length);
            return output;
        }
        //将Base64编码字符串转换成Ansi编码的字符串
        function decode64(input) {
            var output = "";
            var chr1, chr2, chr3 = "";
            var enc1, enc2, enc3, enc4 = "";
            var i = 0;

            if (input.length % 4 != 0) {
                return "";
            }
            var base64test = /[^A-Za-z0-9\+\/\=]/g;
            if (base64test.exec(input)) {
                return "";
            }
            do {
                enc1 = keyStr.indexOf(input.charAt(i++));
                enc2 = keyStr.indexOf(input.charAt(i++));
                enc3 = keyStr.indexOf(input.charAt(i++));
                enc4 = keyStr.indexOf(input.charAt(i++));
                chr1 = (enc1 << 2) | (enc2 >> 4);
                chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
                chr3 = ((enc3 & 3) << 6) | enc4;

                output = output + String.fromCharCode(chr1);
                if (enc3 != 64) {
                    output += String.fromCharCode(chr2);
                }
                if (enc4 != 64) {
                    output += String.fromCharCode(chr3);
                }
                chr1 = chr2 = chr3 = "";
                enc1 = enc2 = enc3 = enc4 = "";
            } while (i < input.length);
            return output;
        }

        function utf16to8(str) {
            var out, i, len, c;

            out = "";
            len = str.length;
            for(i = 0; i < len; i++) {
                c = str.charCodeAt(i);
                if ((c >= 0x0001) && (c <= 0x007F)) {
                    out += str.charAt(i);
                } else if (c > 0x07FF) {
                    out += String.fromCharCode(0xE0 | ((c >> 12) & 0x0F));
                    out += String.fromCharCode(0x80 | ((c >>  6) & 0x3F));
                    out += String.fromCharCode(0x80 | ((c >>  0) & 0x3F));
                } else {
                    out += String.fromCharCode(0xC0 | ((c >>  6) & 0x1F));
                    out += String.fromCharCode(0x80 | ((c >>  0) & 0x3F));
                }
            }
            return out;
        }

        function utf8to16(str) {
            var out, i, len, c;
            var char2, char3;

            out = "";
            len = str.length;
            i = 0;
            while(i < len) {
                c = str.charCodeAt(i++);
                switch(c >> 4) {
                    case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7:
                    // 0xxxxxxx
                    out += str.charAt(i-1);
                    break;
                    case 12: case 13:
                    // 110x xxxx   10xx xxxx
                    char2 = str.charCodeAt(i++);
                    out += String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F));
                    break;
                    case 14:
                        // 1110 xxxx  10xx xxxx  10xx xxxx
                        char2 = str.charCodeAt(i++);
                        char3 = str.charCodeAt(i++);
                        out += String.fromCharCode(((c & 0x0F) << 12) |
                        ((char2 & 0x3F) << 6) |
                        ((char3 & 0x3F) << 0));
                        break;
                }
            }
            return out;
        }

        // 测试代码 开始
        var de = encode64(utf16to8("张晓泉™ <=> 1069897836@qq.com"));
        document.writeln(de+"<br>");
        var ee = utf8to16(decode64("5byg5pmT5rOJ4oSiIDw9PiAxMDY5ODk3ODM2QHFxLmNvbQ=="));
        document.writeln(ee);

        //-->
    </script>
</head>
<body>
</body>
</html>


GOODLUCK!!
分享到:
评论

相关推荐

    java ipone 微信昵称emoji表情保存失败 问题解决

    本问题涉及的是一个典型的Java、iPhone和微信环境下的emoji表情存储问题。当iPhone 5s用户尝试在昵称中使用emoji表情时,这些表情无法成功保存到MySQL数据库中,导致报出"java.sql.SQLException: Incorrect string ...

    Unicode表情符号:Unicode&Emoji处理工具类,可用于解决微信登录Emoji表情昵称乱码问题,包含Emoji表情处理,中日韩字符判断,Unicode格式化表示等

    含表情符号表情处理,中日韩字符判断,Unicode格式化表示等,可用于解决微信登录表情符号表情昵称乱码问题。 微信原始昵称含三种表情符号: 微信授权昵称未处理Emoji表情: 微信授权昵称已处理Emoji表情: String ...

    微信小程序 wx.login解密出现乱码的问题解决办法

    在微信小程序的开发过程中,`wx.login` 是一个至关重要的接口,它允许用户授权并获取登录凭证(code),以便进一步获取微信用户的基本信息。然而,有些开发者在使用此功能时可能会遇到解密用户数据时出现乱码的问题...

    微信导出聊天记录_android系统分享.pdf

    首先需要定位到手机内存的微信文件夹,即 /data/data/com.tencent.mm/MicroMsg,然后进入找到 MicroMsg.db 文件,这就是存储好友号码、昵称、聊天记录的数据库文件。想备份,简单,直接复制了就得! 想要打开和导出...

    微信导出聊天记录_android系统.pdf

    首先,定位到手机内存的微信文件夹,即/data/data/com.tencent.mm/MicroMsg,这回又看到了那个乱七八糟数字和字母组合的文件夹,进入后找到 MicroMsg.db 文件,就是它了,这就是存储好友号码、昵称、聊天记录的...

    电脑上怎么查看微信聊天记录.docx

    不同的文件夹名代表不同的,如果你用不同的登陆过微信,每个会产生一个新乱码文件夹,保险起见,可以都备份上)。 3. 进入找到 MicroMsg.db 文件,这就是存储好友号码、昵称、聊天记录的数据库文件。全部拷贝到电脑...

    电脑如何查看记录 如何查看微信聊天记录【详解】.docx

    不同的文件夹名代表不同的 QQ,如果你用不同的 QQ 登陆过微信,每个 QQ 会产生一个新乱码文件夹,保险起见,可以都备份上)。 3. 然后进入找到 MicroMsg.db 文件,就是它了,这就是存储好友号码、昵称、聊天记录的...

    Python 实现微信防撤回功能

    msg_from = itchat.search_friends(userName=msg['FromUserName'])['NickName'] # 在好友列表中查询发送信息的好友昵称 msg_time = msg['CreateTime'] # 信息发送的时间 msg_id = msg['MsgId'] # 每条信息的id ...

    微信通源码+wap手机版

    2014.10.20 后台粉丝管理升级,认证服务号可以获取微信昵称、头像、性别、地区等信息 2014.10.19 更新点击 首页 直接自动登陆功能 2014.10.19 更新微信多客服系统 2014.10.18 更新微信付款提示 2014.10.17 修复...

    java处理数据库不支持的emoji表情符问题解决

    因此,当我们存入带有表情符的微信昵称时,就会出现乱码情况。 为了解决这个问题,我们可以采取两种方法。第一种方法是将mysql数据库升级到5.5版本以上,并将utf8改为utf8mb4。utf8mb4的字符最多可以是4个字节,...

    3种方法轻松处理php开发中emoji表情的问题

    由于移动设备的普及,用户在发送内容时往往会包含emoji表情,这些表情若未经处理,在显示时会变成乱码。原因在于标准的Mysql的utf8字符集只支持最多三个字节的UTF-8编码,而emoji表情是使用四个字节的UTF-8编码,...

Global site tag (gtag.js) - Google Analytics