Control character in cookie value or attribute. 异常处理方法

一、遇到的异常

  • java.lang.IllegalArgumentException: Control character in cookie value or attribute.

二、解决办法

  • 前端在存储cookie,特别是cookie内容中有中文的时候,对cookie进行base64编码后再存储,相应的在取cookie用的时候再进行相应的解码。
  • 当然如果不想用进行相应的编码,在用cookie做登录页面的时候,尽量用英文用户名和密码,这样也可以避免这种异常的产生。

三、js中实现base64的加密和解密

//base64加密 解密

/* //1.加密  
var result = Base.encode('125中文');  //--> "MTI15Lit5paH"
  
//2.解密  
var result2 = Base.decode(result); //--> '125中文'
*/

~(function(root, factory) {
  if (typeof define === "function" && define.amd) {
    define([], factory);
  } else if (typeof module === "object" && module.exports) {
    module.exports = factory();
  } else {
    root.Base = factory();
  }
}(this, function() {
   'use strict';
   
    function Base64() {
        // private property
        this._keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
    }
    //public method for encoding
    Base64.prototype.encode = function (input) {
        var output = "", chr1, chr2, chr3, enc1, enc2, enc3, enc4, i = 0;
        input = this._utf8_encode(input);
        while (i < input.length) {
            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 +
            this._keyStr.charAt(enc1) + this._keyStr.charAt(enc2) +
            this._keyStr.charAt(enc3) + this._keyStr.charAt(enc4);
        }
        return output;
    }

    // public method for decoding
    Base64.prototype.decode = function (input) {
        var output = "", chr1, chr2, chr3, enc1, enc2, enc3, enc4, i = 0;
        input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
        while (i < input.length) {
            enc1 = this._keyStr.indexOf(input.charAt(i++));
            enc2 = this._keyStr.indexOf(input.charAt(i++));
            enc3 = this._keyStr.indexOf(input.charAt(i++));
            enc4 = this._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 = output + String.fromCharCode(chr2);
            }
            if (enc4 != 64) {
                output = output + String.fromCharCode(chr3);
            }
        }
        output = this._utf8_decode(output);
        return output;
    }

    // private method for UTF-8 encoding
    Base64.prototype._utf8_encode = function (string) {
        string = string.replace(/\r\n/g,"\n");
        var utftext = "";
        for (var n = 0; n < string.length; n++) {
            var c = string.charCodeAt(n);
            if (c < 128) {
                utftext += String.fromCharCode(c);
            } else if((c > 127) && (c < 2048)) {
                utftext += String.fromCharCode((c >> 6) | 192);
                utftext += String.fromCharCode((c & 63) | 128);
            } else {
                utftext += String.fromCharCode((c >> 12) | 224);
                utftext += String.fromCharCode(((c >> 6) & 63) | 128);
                utftext += String.fromCharCode((c & 63) | 128);
            }
    
        }
        return utftext;
    }

    // private method for UTF-8 decoding
    Base64.prototype._utf8_decode = function (utftext) {
        var string = "", i = 0, c = 0, c1 = 0, c2 = 0, c3 = 0;
        while ( i < utftext.length ) {
            c = utftext.charCodeAt(i);
            if (c < 128) {
                string += String.fromCharCode(c);
                i++;
            } else if((c > 191) && (c < 224)) {
                c2 = utftext.charCodeAt(i+1);
                string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
                i += 2;
            } else {
                c2 = utftext.charCodeAt(i+1);
                c3 = utftext.charCodeAt(i+2);
                string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
                i += 3;
            }
        }
        return string;
    }
    
    var Base = new Base64();
    
    return Base;
}));
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: element.attributevalue方法是一种在HTML或XML文档中获取元素属性值的方法。它可以通过指定元素名称和属性名称来获取属性值。例如,如果要获取id为"example"的元素的class属性值,可以使用以下代码: element.attributevalue("example", "class") 这将返回id为"example"的元素的class属性值。 ### 回答2: element.attributevalue方法是在HTML或XML文档中访问特定元素的属性值的一种方式。这个方法可以通过JavaScript来调用,它接收一个参数,即所需属性的名称,并返回该属性的值。 举一个例子,假如我们有一个具有“id”属性的HTML元素,我们可以使用element.attributevalue方法来获取该元素的ID值。代码如下: ``` // 获取id为“myElement”的元素的ID值 var myElement = document.getElementById('myElement'); var idValue = myElement.attributevalue('id'); ``` 在此代码示例中,我们首先使用`document.getelementbyid()`方法获取具有“id”属性为“myelement”的元素,并将其存储在`myelement`变量中。然后,我们调用`myElement.attributevalue('id')`方法获取该元素的ID值,并将其存储在`idValue`变量中。 此外,element.attributevalue方法也可以用于设置元素的属性值。我们可以把一个新值传入这个方法,它会把这个值设置为元素的属性值。代码如下: ``` // 设置id为“myElement”的元素的新ID值 var myElement = document.getElementById('myElement'); myElement.attributevalue('id', 'newIdValue'); ``` 在此代码示例中,我们首先使用`document.getelementbyid()`方法获取具有“id”属性为“myelement”的元素,并将其存储在`myelement`变量中。然后,我们使用`myElement.attributevalue('id', 'newIdValue')`方法将元素的ID值更改为“newIdValue”。 总之,element.attributevalue方法是用于获取和设置特定HTML或XML元素属性值的一种便捷方法。通过使用这种方法,我们可以轻松地获取和更改元素的属性值,从而实现各种JavaScript操作。 ### 回答3: 在 HTML 和 XML 中,标记通常会包含元素的属性,以提供关于元素的进一步信息。在 JavaScript 中,使用 element.attributevalue 方法可以获取元素的属性值。 具体而言,element.attributevalue 方法需要一个参数来指定要获取的属性的名称。例如,对于以下 HTML 元素: ``` <img src="image.jpg" alt="A picture of a cat"> ``` 我们可以使用 attributevalue 方法来获取 `src` 和 `alt` 属性的值: ```javascript const imgElem = document.querySelector('img'); const srcValue = imgElem.attributevalue('src'); // "image.jpg" const altValue = imgElem.attributevalue('alt'); // "A picture of a cat" ``` 如果要设置元素的属性值,可以使用类似的 element.setAttribute 方法: ```javascript imgElem.setAttribute('src', 'newimage.jpg'); ``` 注意,某些属性(例如,`value` 属性以及特定布尔属性如 `checked` 和 `disabled`)有特殊行为,在这些情况下,它们的值不是元素的属性值,而是元素的属性状态。 除了 attributevalue 方法,还有其他方法可以访问和修改元素的属性。但是,attributevalue 方法通常足够简单和直接,因此是处理元素属性的好起点。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值