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();
             });
     }
}

  

    本文转自曾祥展博客园博客,原文链接:http://www.cnblogs.com/zengxiangzhan/archive/2010/03/14/1685377.html,如需转载请自行联系原作者



相关文章
|
18天前
|
JavaScript
短小精悍的js代码
【10月更文挑战第17天】
117 58
|
28天前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 来检查代码规范并自动格式化 Vue.js 代码。
【10月更文挑战第7天】随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 来检查代码规范并自动格式化 Vue.js 代码。通过安装和配置这两个工具,可以确保代码风格一致,提升团队协作效率和代码质量。
201 2
|
5天前
|
JavaScript
原生js炫酷随机抽奖中奖效果代码
原生js随机抽奖是一个炫酷的根据数据随机抽奖的代码,该网页可进行随机抽取一个数据,页面动画高科技、炫酷感觉的随机抽奖效果,简单好用,欢迎下载!
18 3
原生js炫酷随机抽奖中奖效果代码
|
10天前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤。通过这些工具,可以显著提升编码效率和代码质量。
122 4
|
12天前
|
JSON 移动开发 数据格式
html5+css3+js移动端带歌词音乐播放器代码
音乐播放器特效是一款html5+css3+js制作的手机移动端音乐播放器代码,带歌词显示。包括支持单曲循环,歌词显示,歌曲搜索,音量控制,列表循环等功能。利用json获取音乐歌单和歌词,基于html5 audio属性手机音乐播放器代码。
62 6
|
8天前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码。通过安装和配置这些工具,可以确保代码风格一致,提高代码质量和可读性。
32 1
|
26天前
|
JavaScript 前端开发 开发者
如何在 VSCode 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升团队协作效率和代码质量。
【10月更文挑战第9天】随着前端开发技术的发展,代码规范和格式化工具变得至关重要。本文介绍如何在 VSCode 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升团队协作效率和代码质量。通过安装插件、配置 ESLint 和 Prettier,以及设置 VSCode,实现代码实时检查和格式化,确保代码风格一致。
21 2
|
27天前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升代码质量和团队协作效率。
【10月更文挑战第8天】本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升代码质量和团队协作效率。通过安装 VSCode 插件、配置 ESLint 和 Prettier,实现代码规范检查和自动格式化,确保代码风格一致,提高可读性和维护性。
38 2
|
23天前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript中的闭包:原理、应用与代码演示
【10月更文挑战第12天】深入理解JavaScript中的闭包:原理、应用与代码演示