js代码还原,中文字符转unicode

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>

 

正则表达式 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();
                });
        }
    }

  

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值