目的, 把远程服务器传回的Html, 解析到类里面, 为GridView等提供数据源
1 、向远程服务器Почта
public int PostData (URL-адрес строки, данные строки, информация о строке)
{
информация = "";
CookieContainer cc = новый CookieContainer();
Запрос HttpWebRequest = WebRequest.Create(url) как HttpWebRequest;
request.CookieContainer = cc;
запрос.Метод = "POST";
request.ContentType = "application/x-www-form-urlencoded";
Поток requestStream = request.GetRequestStream();
byte[] byteArray = Encoding.UTF8.GetBytes(данные);
requestStream.Write(byteArray, 0, byteArray.Length);
запросПоток.Закрыть();
Ответ HttpWebResponse = request.GetResponse() как HttpWebResponse;
Uri responseUri = response.ResponseUri;
Поток полученияПоток = ответ.GetResponseStream();
Кодировка encode = System.Text.Encoding.GetEncoding("utf-8");
StreamReader readStream = новый StreamReader (receiveStream, encode);
строковый результат = readStream.ReadToEnd();
информация = результат;
вернуть 0;
}2、解析返回的html, 有省略
public ClassInfo[] GetClass (строка html)
{
ArrayList ar = новый ArrayList ();
ArrayList обр = новый ArrayList();
строковая таблица = "";
Regex regtable = new Regex(@"(?<=<table.*>).*?(?=</table>)", RegexOptions.Singleline);
Матч ma = regtable.Match(html);
пока (ма.Успех)
{
если (ma.Value.Trim() != "")
{
arr.Add(HttpUtility.HtmlDecode(ma.Value));
}
ма = ма.NextMatch();
}
for (int i = 0; i < arr.Count; i++)
{
таблица = arr[i].ToString() + таблица;
}
Regex reg = new Regex(@"(?<=<.*?>).*?(?=<.*?>)", RegexOptions.Singleline);
Соответствие m = reg.Match(таблица);
пока (м.Успех)
{
если (m.Value.Trim() != "")
{
ar.Add(HttpUtility.HtmlDecode(m.Value));
}
м = m.NextMatch();
}
ClassInfo[] ci = новый ClassInfo[classno];
for (int i = 0; i <номер класса; i++)
{
ci[i] = новый ClassInfo();
ci[i].RegisterDate = (ar[i * 8 + 0]).ToString();
ci[i].LoginDate = (ar[i * 8 + 1]).ToString();
ci[i].LogoutDate = (ar[i * 8 + 2]).ToString();
ci[i].UseMin = ar[i * 8 + 3].ToString();
ci[i].ClassName = ar[i * 8 + 5].ToString();
ci[i].ClassType = ar[i * 8 + 6].ToString();
ci[i].Percent = ar[i * 8 + 7].ToString();
}
вернуть ци;
}
3. Приложение ClassInfo, CodeSmith.
публичный класс ClassInfo
{
Переменные-члены#переменные-члены региона
защищенная строка _loginDate;
защищенная строка _logoutDate;
защищенная строка _registerDate;
защищенная строка _useMin;
защищенная строка _className;
защищенная строка _classType;
защищенная строка _percent;
//защищенная строка _nouse;
#endregion
Constructors#region Constructors
public ClassInfo() { }
public ClassInfo(строка loginDate, строка logoutDate, строка RegisterDate, строка useMin, строка className, строка classType, строка процентов)
{
this._loginDate = loginDate;
this._logoutDate = logoutDate;
this._registerDate = RegisterDate;
this._useMin = useMin;
this._className = имя класса;
this._classType = classType;
this._percent = процент;
}
#Общественные свойства региона
#Общественные свойства региона
// публичная строка NoUse
// {
// получить {вернуть _nouse;}
// устанавливаем { _nouse= значение;}
// }
общедоступная строка LoginDate
{
получить {вернуться _loginDate; }
установить {_loginDate = значение; }
}
публичная строка LogoutDate
{
получить {вернуться _logoutDate; }
установить {_logoutDate = значение; }
}
публичная строка RegisterDate
{
получить {вернуться _registerDate; }
установить {_registerDate = значение; }
}
публичная строка UseMin
{
получить {вернуться _useMin; }
установить {_useMin = значение; }
}
публичная строка ClassName
{
получить {вернуться _className; }
набор
{
if (значение!= null && value.Length > 50)
throw new ArgumentOutOfRangeException("Недопустимое значение для ClassName", value, value.ToString());
_имякласса = значение;
}
}
публичная строка ClassType
{
получить {вернуться _classType; }
набор
{
if (значение!= null && value.Length > 50)
throw new ArgumentOutOfRangeException("Недопустимое значение для ClassType", value, value.ToString());
_classType = значение;
}
}
публичная строка Процент
{
получить {вернуться _percent; }
набор
{
if (значение!= null && value.Length > 50)
throw new ArgumentOutOfRangeException("Недопустимое значение для процента", value, value.ToString());
_процент = значение;
}
}
#конечныйрегион
}