EncodingHelper
/// <summary> /// Url解码 /// </summary> /// <param name="str">原始字符串</param> /// <param name="isuft8">是否utf8</param> /// <returns></returns> public static string Url2Str_(string Url, bool IsUTF8 = false) { string result = string.Empty; int len = Url.Length; ; int H, L; string Hex = "0123456789ABCDEF"; List<byte> li = new List<byte>(); while (i < len) { ) != "%") { li.Add(Convert.ToByte(Url.Substring(i, ))); } else { i++; H = Hex.IndexOf(Url.Substring(i, ).ToUpper()); i++; L = Hex.IndexOf(Url.Substring(i, ).ToUpper()); li.Add(( + L)); } i++; } if (IsUTF8 == true) { result = Encoding.UTF8.GetString(li.ToArray()); } else { result = Encoding.Default.GetString(li.ToArray()); } return result; } /// <summary> /// Url编码 /// </summary> /// <param name="str">原始字符串</param> /// <param name="isuft8">是否utf8</param> /// <returns></returns> public static string Str2Url_(string strCode, bool NoEncodNum = false, bool isuft8 = false) { StringBuilder sb = new StringBuilder(); byte[] byStr; if (isuft8 == false) { byStr = System.Text.Encoding.Default.GetBytes(strCode); } else { byStr = System.Text.Encoding.UTF8.GetBytes(strCode); } System.Text.RegularExpressions.Regex regKey = new System.Text.RegularExpressions.Regex("^[A-Za-z0-9]+$"); ; i < byStr.Length; i++) { string strBy = Convert.ToChar(byStr[i]).ToString(); if (NoEncodNum == true) { if (regKey.IsMatch(strBy)) { //是字母或者数字则不进行转换 sb.Append(strBy); } else { sb.Append()); } } else { sb.Append()); } } return (sb.ToString()); }
/// <summary> /// Url编码,encoding默认为utf8编码 /// </summary> /// <param name="str">需要编码的字符串</param> /// <param name="encoding">指定编码类型</param> /// <returns>编码后的字符串</returns> public static string Str2Url(string str, Encoding encoding = null) { if (encoding == null) { return System.Web.HttpUtility.UrlEncode(str, Encoding.UTF8); } else { return System.Web.HttpUtility.UrlEncode(str, encoding); } } /// <summary> /// Url解码,encoding默认为utf8编码 /// </summary> /// <param name="str">需要解码的字符串</param> /// <param name="encoding">指定解码类型</param> /// <returns>解码后的字符串</returns> public static string Url2Str(string str, Encoding encoding = null) { if (encoding == null) { return System.Web.HttpUtility.UrlDecode(str, Encoding.UTF8); } else { return System.Web.HttpUtility.UrlDecode(str, encoding); } }
/// <summary> ///_usc2到ansi /// </summary> /// <param name="s"></param> /// <returns></returns> public static string Unicode2StringEX(string str) { return HttpUtility.UrlDecode(Regex.Unescape(str)); } /// <summary> /// 到ansi到usc2 /// </summary> /// <param name="str"></param> /// <returns></returns> public static string Str2Unicode(string str) { return HttpUtility.UrlEncodeUnicode(str); }
/// <summary> /// UTF8到GB2312 /// </summary> /// <param name="str"></param> /// <returns></returns> public static string UTF82Str(string str) { string result = str; byte[] byteArray = System.Text.Encoding.UTF8.GetBytes(str); result = System.Text.Encoding.Default.GetString(byteArray, , byteArray.Length); return result; } /// <summary> /// GB2312到UTF8 /// </summary> /// <param name="str"></param> /// <returns></returns> public static string Str2UTF8(string str) { string result = str; byte[] byteArray = System.Text.Encoding.Default.GetBytes(str); result = System.Text.Encoding.UTF8.GetString(byteArray, , byteArray.Length); return result; }
/// <summary> /// 将字符串转换为base64格式 默认UTF8编码 /// </summary> /// <param name="str">原始字符串</param> /// <param name="encoding">编码</param> /// <returns></returns> public static string String2Base64(string str, Encoding encoding = null) { if (encoding == null) { encoding = Encoding.UTF8; } return Convert.ToBase64String(encoding.GetBytes(str)); } /// <summary> /// base64字符串转换为普通格式 默认UTF8编码 /// </summary> /// <param name="str">原始字符串</param> /// <param name="encoding">编码</param> /// <returns></returns> public static string Base642String(string str, Encoding encoding = null) { if (encoding == null) { encoding = Encoding.UTF8; } byte[] buffer = Convert.FromBase64String(str); return encoding.GetString(buffer); }
EncodingHelper的更多相关文章
- sublime text 插件(前端自用)
一.软件安装 ST中文论坛:http://sublimetext.iaixue.com/ 或者 http://sublimetext.iaixue.com/dl/#sublime_text_3103 ...
- Sublime Text3快捷键以及常用插件
工若善其事,必先利其器.做为一个web前端开发人员,必须有一个得心应手的编码工具,本人推荐Sublime Text3和WebStorm,但WebStorm太过智能和耗性能了对初学者来说弊大于利,所以我 ...
- JS&CSS文件请求合并及压缩处理研究(五)
接上篇.在我们最终调用 @Html.RenderResFile(ResourceType.Script) 或者 @Html.RenderResFile(ResourceType.StyleSheet) ...
- Sublime Text 最佳插件列表(转)
Package Control 安装方法 首先通过快捷键 ctrl+` 或者 View > Show Console 打开控制台,然后粘贴相应的 Python 安装代码. Sublime Tex ...
- C# 根据IP地址获取城市
using System; using System.IO; using System.Net; using System.Text; using System.Web.Script.Serializ ...
- 推荐!Sublime Text 最佳插件列表
本文由 伯乐在线 - 艾凌风 翻译,黄利民 校稿.英文出处:ipestov.com.欢迎加入翻译组. 本文收录了作者辛苦收集的Sublime Text最佳插件,很全. 最佳的Sublime Text ...
- Sublime Text各种插件使用方法
有快捷键冲突的时候可以修改快捷键,建议修改插件快捷键而不是Sublime Text的快捷键,我的有冲突的一律将插件快捷键设置成:Ctrl+Alt+A(B...) Package Control 通俗易 ...
- 检测字节流是否是UTF8编码
几天前偶尔看到有人发帖子问“如何自动识别判断url中的中文参数是GB2312还是Utf-8编码” 也拜读了wcwtitxu使用巨牛的正则表达式检测UTF8编码的算法. 使用无数或条件的正则表达式用起来 ...
- c# 搭建服务端 常用的Helper(5)
常用的Helper 1.byteHelper :对象与byte[]之间的转换 2.ConvertJson:操作json对象 3.EncodingHelper:对象编码 4.ModelConvertHe ...
随机推荐
- Servlet3.0的注解
1.@WebListener注解 表示的就是我们之前的在xml中配置的 <listener> <listener-class>ListenerClass</listene ...
- java 开发模式
Java-开发模式 Java Web开发方案有多种,这里列举一些经典的开发模式进行横向比较JSP+JAVABEAN开发模式: 特点:该模式将业务逻辑与页面表现进行分离,在一定程度上增加了程序的可 ...
- 浅谈为之奋斗过的Set接口
Set接口 Set接口存储一组唯一,无序的对象 HashSet 是Set接口常用的实现类 HashSet允许集合元素值为null 操作数据的方法与List类似 Set接口不存在get()方法 set ...
- JavaScript Array数组方法详解
Array类型是ECMAScript中最常用的引用类型.ECMAScript中的数据与其它大多数语言中的数组有着相当大的区别.虽然ECMAScript中的数据与其它语言中的数组一样都是数据的有序列表, ...
- 如何围绕企业战略,建设BI驾驶舱?
随着企业的逐步发展,人员的增加.业态的复杂不仅对管理也对信息化的要求越来越高,甚至需要从战略角度出发,进行从上至下的全面推行. 关于这个话题,某公司深有体会.面对这样的瓶颈,一方面从优化信息架构.调整 ...
- [Android Studio]SQLScout插件安装破解
以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5972138.html [Android Studio]SQLS ...
- 关于多个block问题
在某个添加文本的页面中,leftbarbutton是删除(直接将数组中的这个string删除),rightbarbutton是完成,分别对应两个block,完成的block是一开始写的,写到了view ...
- DAO设计模式
DAO设计模式 DAO设计模式简介: DAO设计模式可以减少代码量,增强程序的可移植性,提高代码的可读性. DAO(数据库操作对象)设计模式是 JavaEE 数据层的操作.主要由五部分组成: 1.数据 ...
- 关于Oracle表连接
表连接注意left join on与where的区别: select * from dept; select * from emp; select * from emp a right outer j ...
- DOS下windows系统查看wifi密码
DOS下windows系统查看wifi密码 首先,按win+R键,win键如下 弹出框中输入cmd 在弹出界面输入 netsh wlan show profiles 你可以看到你链接过的所有wifi名 ...