js代碼還原,中文字元轉unicode

來源:互聯網
上載者:User

eval(function(E,I,A,D,J,K,L,H){function.....

的js

 

還原的方法就很簡單了,那前面的 eval(  和後面的 ) 去掉:

 

<!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>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>代碼還原</title>
</head>
<body>
<TEXTAREA NAME="tx1" ROWS="10" COLS="100"></TEXTAREA>
<SCRIPT type="text/javascript">
document.all.tx1.value =function(E,I,A,D,J,K,L,H){ ....
</SCRIPT>
</body>
</html>

 

 <script language="javascript">
 var o = "\x3c\x64\151\x76\x20\x63\154\141\x73\151\166\x3e";      
alert(o.toString())
</script>

 

Regex http://www.w3cfuns.com/portal.php?mod=topic&topicid=46 

 

/**
 * 中文轉unicode字元工具
 */
function toUnicode(str, cssType) {
    var i = 0,
        l = str.length,
        result = [], //轉換後的結果數組
        unicodePrefix, //unicode首碼 (example:\1234||\u1234)
        unicode16; //轉換成16進位後的unicode

    //如果是css中使用格式為\1234之類
    unicodePrefix = (cssType && cssType.toLowerCase() === 'css') ? '\\' : '\\u';

    for (; i < l; i++) {
        //轉為16進位的unicode, js及css裡須轉成16進位
        unicode16 = str.charCodeAt(i).toString(16);
        result.push( unicodePrefix + unicode16 );
    }

    return result.join(' ');
}
字串的charCodeAt方法返回的是10進位的unicode,所以我們需要用toString(16)將其轉為16進位的,才能在JS及CSS中使用,而CSS中跟JS不同的是少了個U

  //檢測英文等字元排除
    function checkInput(str) {
        var charReg = /[^u0391-uFFE5]/g; //匹配英文等無需轉換的字元

        if (charReg.test(str)) {
            msg.innerHTML = '輸入字元格式設定有誤,請輸入中文等字元';
正則/[\u0391-\uFFE5]/是用來匹配中文字元,包括標點,繁體什麼的。

中國:\u4e2d\u56fd    css:\4e2d\56fd 

 

    /// <summary>    /// 字元編解碼助手:    ///     ←    ///     →       ///     \u840c\u59b9\u7ffb\u7a97\u8868\u767d\u57fa\u60c5\u5916\u6cc4    /// </summary>    public class AsciiHelper    {        /// <summary>        /// 編碼        /// </summary>        /// <param name="value"></param>        /// <returns></returns>        public static string EncodeNonAsciiCharacters(string value)        {            StringBuilder sb = new StringBuilder();            foreach (char c in value)            {                if (c > 127)                {                    // This character is too big for ASCII                    string encodedValue = "\\u" + ((int)c).ToString("x4");                    sb.Append(encodedValue);                }                else                {                    sb.Append(c);                }            }            return sb.ToString();        }        /// <summary>        /// 解碼        /// </summary>        /// <param name="value"></param>        /// <returns></returns>        public static string DecodeEncodedNonAsciiCharacters(string value)        {            return Regex.Replace(                value,                @"\\u(?<Value>[a-zA-Z0-9]{4})",                m =>                {                    return ((char)int.Parse(m.Groups["Value"].Value, NumberStyles.HexNumber)).ToString();                });        }    }

  

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.