复杂字符串通过base64编码后的数据传输

1.首先创建Base64对象:

//先创建Base64对象
            var Base64 = {
                _keyStr: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
                encode: function(e) {
                    var t = "";
                    var n, r, i, s, o, u, a;
                    var f = 0;
                    e = Base64._utf8_encode(e);
                    while (f < e.length) {
                        n = e.charCodeAt(f++);
                        r = e.charCodeAt(f++);
                        i = e.charCodeAt(f++);
                        s = n >> 2;
                        o = (n & 3) << 4 | r >> 4;
                        u = (r & 15) << 2 | i >> 6;
                        a = i & 63;
                        if (isNaN(r)) {
                            u = a = 64
                        } else if (isNaN(i)) {
                            a = 64
                        }
                        t = t + this._keyStr.charAt(s) + this._keyStr.charAt(o) + this._keyStr.charAt(u) + this._keyStr.charAt(a)
                    }
                    return t
                },
                decode: function(e) {
                    var t = "";
                    var n, r, i;
                    var s, o, u, a;
                    var f = 0;
                    e=e.replace(/[^A-Za-z0-9+/=]/g,"");
                    while (f < e.length) {
                        s = this._keyStr.indexOf(e.charAt(f++));
                        o = this._keyStr.indexOf(e.charAt(f++));
                        u = this._keyStr.indexOf(e.charAt(f++));
                        a = this._keyStr.indexOf(e.charAt(f++));
                        n = s << 2 | o >> 4;
                        r = (o & 15) << 4 | u >> 2;
                        i = (u & 3) << 6 | a;
                        t = t + String.fromCharCode(n);
                        if (u != 64) {
                            t = t + String.fromCharCode(r)
                        }
                        if (a != 64) {
                            t = t + String.fromCharCode(i)
                        }
                    }
                    t = Base64._utf8_decode(t);
                    return t
                },
                _utf8_encode: function(e) {
                
                  /*
                  网上有很多e = e.replace(/rn/g, "n");这样的写法,
                  这样字符串里面所有的‘rn’就替换成‘n’,下面才是正确的写法。
                  */
                    e = e.replace(/\r\n/g,"\n");
                    var t = "";
                    for (var n = 0; n < e.length; n++) {
                        var r = e.charCodeAt(n);
                        if (r < 128) {
                            t += String.fromCharCode(r)
                        } else if (r > 127 && r < 2048) {
                            t += String.fromCharCode(r >> 6 | 192);
                            t += String.fromCharCode(r & 63 | 128)
                        } else {
                            t += String.fromCharCode(r >> 12 | 224);
                            t += String.fromCharCode(r >> 6 & 63 | 128);
                            t += String.fromCharCode(r & 63 | 128)
                        }
                    }
                    return t
                },
                _utf8_decode: function(e) {
                    var t = "";
                    var n = 0;
                    var r = c1 = c2 = 0;
                    while (n < e.length) {
                        r = e.charCodeAt(n);
                        if (r < 128) {
                            t += String.fromCharCode(r);
                            n++
                        } else if (r > 191 && r < 224) {
                            c2 = e.charCodeAt(n + 1);
                            t += String.fromCharCode((r & 31) << 6 | c2 & 63);
                            n += 2
                        } else {
                            c2 = e.charCodeAt(n + 1);
                            c3 = e.charCodeAt(n + 2);
                            t += String.fromCharCode((r & 15) << 12 | (c2 & 63) << 6 | c3 & 63);
                            n += 3
                        }
                    }
                    return t
                }
            }

2.使用Base64对复杂字符串编码

//待编码的字符串
	var awaitCoding = "http://localhost:8080/sendMail?to=gb32s60@ioddsds.cn&subject=文本,时间=, <br>告警地点:lat=30.193885,lng=120.063402<br>紧急事件,请及时跟进!<img style="margin:20px" width="280" height="140"  src="img/bg.png "/>"
//编码
	var finishCoding = Base64.encode(awaitCoding );

3.常规处理方式

  • 通常用以下的字符串来代替
// 	# 用来标志特定的文档位置 %23
//	% 对特殊字符进行编码 %25
//	& 分隔不同的变量值对 %26
//	+ 在变量值中表示空格 %2B
//	\ 表示目录路径 %2F
//	= 用来连接键和值 %3D
//	? 表示查询字符串的开始 %3F

这样处理后“+”传输到后台表现出来的是空格,一般是后台直接判断空格为“+”号,但是如果同时出现多个特殊字符就会出现问题

4.解决方法

	var pushText = finishCoding .replace(/\+/g,"-");
	pushText = pushText.replace(/\=/g,"_");
  • 解决方法是与后台协商后将“+”定义成“-”,然后将“=”号定义成“_”传输到后台,再由后台解析处理,其他的特殊字符有需要也可以协商自定义,处理方式简单粗暴。
  • 个人解决方法不喜勿喷,有什么好的解决方法欢迎交流。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值