asp.net与js中字符串的HTML编码与解码
2010-08-12 22:51
816 查看
一、Asp.net中字符的HTML编码与解码
字符的HTML编码:
System.Web.HttpUtility.HtmlEncode("字符串"); 字符的HTML解码:
message = page.Server.HtmlDecode("字符串");
二、JS中的HTML编码与解码
有两中方法可以实现。一种是通过将值赋给一个动态创建一个容器来实现,另外一种方法是通过替换特殊字符来实现。
1、通过将值赋给一个动态创建一个容器来实现
1)HTML编码:
此方法是用的浏览器内部转换器实现转换,方法是动态创建一个容器标签元素,如DIV,将要转换的字符串设置为这个元素的innerText,然后返回这个元素的innerHTML,即得到经过HTML编码转换的字符串。
代码function HTMLEncode ( input )
{
var converter = document.createElement("DIV");
converter.innerText = input;
var output = converter.innerHTML;
converter = null;
return output;
} 2)HTML解码:
用相同的方法实现对字符串的HTMLDecode解码,但有个问题就是紧跟在字符"<"后面的非空字符将连同字符"<"同时显示不出来。当 然,对字符串作相应处理是可以解决这个问题的,比如在字符"<"后面加个空格,解码后再去掉就行,这是后话。毕竟,要使用 HTMLDecode方法解码,自然是字符串已经经过HTMLEncode方法编码了,而经过HTMLEncode编码后的字符串,是不可能有字符 "<"存在的。
function HTMLDecode ( input )
{
var converter = document.createElement("DIV");
converter.innerHTML = input;
var output = converter.innerText;
converter = null;
return output;
}
2、通过替换特殊字符来实现
1)HTML编码:
function HTMLEnCode(str)
{
var s = "";
if (str.length == 0) return "";
s = str.replace(/&/g, ">");
s = s.replace(/</g, "<");
s = s.replace(/>/g, ">");
s = s.replace(/ /g, " ");
s = s.replace(/\'/g, "'");
s = s.replace(/\"/g, """);
s = s.replace(/\n/g, "<br>");
return s;
}
2)HTML解码:
function HTMLDeCode(str)
{
var s = "";
if (str.length == 0) return "";
s = str.replace(/>/g, "&");
s = s.replace(/</g, "<");
s = s.replace(/>/g, ">");
s = s.replace(/ /g, " ");
s = s.replace(/'/g, "\'");
s = s.replace(/"/g, "\"");
s = s.replace(/<br>/g, "\n");
return s;
}
注:本文中第二部分“JS中的HTML编码与解码”转自http://hi.baidu.com/hfgyd2616/blog/item/864becf8cbe52c0bd9f9fdd9.html
字符的HTML编码:
System.Web.HttpUtility.HtmlEncode("字符串"); 字符的HTML解码:
message = page.Server.HtmlDecode("字符串");
二、JS中的HTML编码与解码
有两中方法可以实现。一种是通过将值赋给一个动态创建一个容器来实现,另外一种方法是通过替换特殊字符来实现。
1、通过将值赋给一个动态创建一个容器来实现
1)HTML编码:
此方法是用的浏览器内部转换器实现转换,方法是动态创建一个容器标签元素,如DIV,将要转换的字符串设置为这个元素的innerText,然后返回这个元素的innerHTML,即得到经过HTML编码转换的字符串。
代码function HTMLEncode ( input )
{
var converter = document.createElement("DIV");
converter.innerText = input;
var output = converter.innerHTML;
converter = null;
return output;
} 2)HTML解码:
用相同的方法实现对字符串的HTMLDecode解码,但有个问题就是紧跟在字符"<"后面的非空字符将连同字符"<"同时显示不出来。当 然,对字符串作相应处理是可以解决这个问题的,比如在字符"<"后面加个空格,解码后再去掉就行,这是后话。毕竟,要使用 HTMLDecode方法解码,自然是字符串已经经过HTMLEncode方法编码了,而经过HTMLEncode编码后的字符串,是不可能有字符 "<"存在的。
function HTMLDecode ( input )
{
var converter = document.createElement("DIV");
converter.innerHTML = input;
var output = converter.innerText;
converter = null;
return output;
}
2、通过替换特殊字符来实现
1)HTML编码:
function HTMLEnCode(str)
{
var s = "";
if (str.length == 0) return "";
s = str.replace(/&/g, ">");
s = s.replace(/</g, "<");
s = s.replace(/>/g, ">");
s = s.replace(/ /g, " ");
s = s.replace(/\'/g, "'");
s = s.replace(/\"/g, """);
s = s.replace(/\n/g, "<br>");
return s;
}
2)HTML解码:
function HTMLDeCode(str)
{
var s = "";
if (str.length == 0) return "";
s = str.replace(/>/g, "&");
s = s.replace(/</g, "<");
s = s.replace(/>/g, ">");
s = s.replace(/ /g, " ");
s = s.replace(/'/g, "\'");
s = s.replace(/"/g, "\"");
s = s.replace(/<br>/g, "\n");
return s;
}
注:本文中第二部分“JS中的HTML编码与解码”转自http://hi.baidu.com/hfgyd2616/blog/item/864becf8cbe52c0bd9f9fdd9.html
相关文章推荐
- asp.net使用unescape读取js escape编码过的字符串
- asp.net+js实现批量编码与解码的方法
- JS将PHP htmlspecialchars 编码后的字符串解码
- 在asp.net mvc中使用百度UEditor初始化内容遇到自数据库中读取的html字符串在UEditor中始终是html编码的问题
- [原创]ASP.NET对数据进行HTML编码将其绑定到DrowdownList并解码的解决方案
- ASP.NET对数据进行HTML编码将其绑定到DrowdownList并解码的解决方案
- js 编码、解码与asp.net 编码、解码
- [C#/asp.net]字符串编码、解码以及编码转换
- js前台编码,asp.net后台解码 防止前台传值到后台为乱码
- asp.net+js实现批量编码与解码的方法
- ASP.NET MVC Razor 输出没有编码的HTML字符串
- ASP.NET MVC Razor 输出没有编码的HTML字符串
- JS编码,解码. asp.net(C#)对应解码,编码
- Asp.Net中的字符串和HTML十进制编码转换实现代码
- JS编码,解码. asp.net(C#)对应解码,编码
- asp.net与js中对Url进行utf8编码与解码
- Asp.Net中的字符串和HTML十进制编码转换实现代码
- ASP.NET 后台编码js前台解码
- ASP.NET MVC Razor 输出没有编码的HTML字符串
- JS编码,解码. asp.net(C#)对应解码,编码