下面的代碼是常用的截取某個長度字元串的代碼,平時都用得很好,可是突然有一天發現在伺服器上的那個部分不起作用了,但是本地測試又是好的,百思不得其解
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