下面的代码是常用的截取某个长度字符串的代码,平时都用得很好,可是突然有一天发现在服务器上的那个部分不起作用了,但是本地测试又是好的,百思不得其解
View Code
1 #region 截取字符
2 /// <summary>
3 /// 截取字符
4 /// </summary>
5 /// <param name="s">原字符</param>
6 /// <param name="len">要截取的长度</param>
7 /// <returns></returns>
8 public string Left(string s, int len)
9 {
10 s = NoHTML(s); //这里清除html代码
11 byte[] sarr = System.Text.Encoding.Default.GetBytes(s);
12 if (sarr.Length > len)
14 {
15 return System.Text.Encoding.Default.GetString(sarr, 0, len) + "...";
16 }
17 else
18 {
19 return s;
20 }
21 }
22 #endregion
最后翻来翻去,嫌疑定位到了System.Text.Encoding.Default.GetBytes,由于服务器是windows2003英文版的,所以有点怀疑是不是编码不一致导致的,最后改成System.Text.Encoding.UTF8.GetBytes(页面都是UTF-8的编码),终于变成它应该是的效果了
转载于:https://www.cnblogs.com/yoder/archive/2011/09/15/2177555.html