用C#读取sina天气预报到wap页面(二)

sina|天气预报|页面

 
public class weather : System.Web.UI.MobileControls.MobilePage
 {
  protected System.Web.UI.MobileControls.Label Label1;
  protected System.Web.UI.MobileControls.Label Label2;
  protected System.Web.UI.MobileControls.SelectionList s_weather;
  protected System.Web.UI.MobileControls.Label l_date;
  protected System.Web.UI.MobileControls.Label l_city;
  protected System.Web.UI.MobileControls.Label l_wea;
  protected System.Web.UI.MobileControls.Label l_sky;
  protected System.Web.UI.MobileControls.Label l_w1;
  protected System.Web.UI.MobileControls.Label l_w2;
  protected System.Web.UI.MobileControls.Label l_w3;
  protected System.Web.UI.MobileControls.Link Link1;
  protected System.Web.UI.MobileControls.Command Command1;
  protected System.Web.UI.MobileControls.Label Label3;
  protected System.Web.UI.MobileControls.Form Form1;

  private void Page_Load(object sender, System.EventArgs e)
  {
   // 在此处放置用户代码以初始化页面
   if (!Page.IsPostBack)
   {
    string city = "深圳";
    int start,stop;
    string weather1,weather2,wea;
    string wea_city = weather_city(city);
    wea_city = wea_city.Replace(" ","");

    start = wea_city.IndexOf("<b>",0,wea_city.Length);
    stop = wea_city.IndexOf("</b>", start);
    weather1 = wea_city.Substring(start, stop-start).Trim() + "          ";
    weather1 = weather1.Substring(3,8).Trim();
   
    start = wea_city.IndexOf("<tdstyle=\"font-size:40px;font-family:TimesNewRoman;font-weight:bold;\">",0,wea_city.Length);
    stop = wea_city.IndexOf("℃",start) + 40;
    weather2 = wea_city.Substring(start, stop-start);
    weather2 = weather2.Substring(stop-start-42,40).Trim();
    weather2 = weather2.Replace("\t","");

    start = wea_city.IndexOf("<fontcolor=#183888><b>", 0, wea_city.Length);
    stop = wea_city.IndexOf("</b></font>",start);
    wea = wea_city.Substring(start,stop-start);
    wea = wea.Substring(22,wea.Length-22) + "kbrk";
    wea = wea.Replace("\t", "");
    wea = wea.Replace(">", "k");
    wea = wea.Replace("<", "k");
    wea = wea.Replace("kbrk", "k");
    string [] wall = null;
    char[] seperator = {'k'};
    wall = wea.Split(seperator);

    //////////////////////////////////////
    l_city.Text = "[城市]:" + city;
    l_wea.Text = "[天气]:" + weather1;
    l_sky.Text = "[温度]:" + weather2;
    ///////
    l_date.Text = wall[0];
    l_w1.Text = wall[1];
    l_w2.Text = wall[2];
    l_w3.Text = wall[3];
   }
  }

  #region Web 窗体设计器生成的代码
  override protected void OnInit(EventArgs e)
  {
   //
   // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
   //
   InitializeComponent();
   base.OnInit(e);
  }

  /// <summary>
  /// 设计器支持所需的方法 - 不要使用代码编辑器修改
  /// 此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {   
   this.Command1.Click += new System.EventHandler(this.Command1_Click);
   this.Load += new System.EventHandler(this.Page_Load);

  }
  #endregion

  private void Command1_Click(object sender, System.EventArgs e)
  {
   string city = s_weather.Selection.Value.Trim();
   int start,stop;
   string weather1,weather2,wea;
   string wea_city = weather_city(city);
   wea_city = wea_city.Replace(" ","");

   start = wea_city.IndexOf("<b>",0,wea_city.Length);
   stop = wea_city.IndexOf("</b>", start);
   weather1 = wea_city.Substring(start, stop-start).Trim() + "          ";
   weather1 = weather1.Substring(3,8).Trim();
   
   start = wea_city.IndexOf("<tdstyle=\"font-size:40px;font-family:TimesNewRoman;font-weight:bold;\">",0,wea_city.Length);
   stop = wea_city.IndexOf("℃",start) + 40;
   weather2 = wea_city.Substring(start, stop-start);
   weather2 = weather2.Substring(stop-start-42,40).Trim();
   weather2 = weather2.Replace("\t","");

   start = wea_city.IndexOf("<fontcolor=#183888><b>", 0, wea_city.Length);
   stop = wea_city.IndexOf("</b></font>",start);
   wea = wea_city.Substring(start,stop-start);
   wea = wea.Substring(22,wea.Length-22) + "kbrk";
   wea = wea.Replace("\t", "");
   wea = wea.Replace(">", "k");
   wea = wea.Replace("<", "k");
   wea = wea.Replace("kbrk", "k");
   string [] wall = null;
   char[] seperator = {'k'};
   wall = wea.Split(seperator);

   //////////////////////////////////////
   l_city.Text = "[城市]:" + city;
   l_wea.Text = "[天气]:" + weather1;
   l_sky.Text = "[温度]:" + weather2;
   ///////
   l_date.Text = wall[0];
   l_w1.Text = wall[1];
   l_w2.Text = wall[2];
   l_w3.Text = wall[3];  
  }

  public string weather_city(string city)
  {
   string temp = null;
   try
   {
    string strURL = "http://weather.news.sina.com.cn/cgi-bin/figureWeather/search.cgi";
    HttpWebRequest request;
    request = (HttpWebRequest)WebRequest.Create(strURL);
    request.Method="POST"; //Post请求方式
    request.ContentType="application/x-www-form-urlencoded"; //内容类型
    string paraUrlCoded = System.Web.HttpUtility.UrlEncode("city"); //参数经过URL编码
    paraUrlCoded = paraUrlCoded + "=" + System.Web.HttpUtility.UrlEncode(city, System.Text.Encoding.GetEncoding("GB2312"));
    byte[] payload;
    payload = System.Text.Encoding.GetEncoding("GB2312").GetBytes(paraUrlCoded); //将URL编码后的字符串转化为字节
    request.ContentLength = payload.Length; //设置请求的ContentLength
    Stream writer = request.GetRequestStream(); //获得请求流
    writer.Write(payload,0,payload.Length); //将请求参数写入流
    writer.Close(); //关闭请求流
    HttpWebResponse response;
    response = (HttpWebResponse)request.GetResponse(); //获得响应流
    Stream s;
    s = response.GetResponseStream();
    StreamReader objReader = new StreamReader(s,System.Text.Encoding.GetEncoding("GB2312"));
    string HTML = "";
    string sLine = "";
    int i = 0;
    while (sLine!=null)
    {
     i++;
     sLine = objReader.ReadLine();
     if (sLine!=null)
      HTML += sLine;
    }
    HTML = HTML.Replace("<","<");
    HTML = HTML.Replace(">",">");
    int start,stop;
    start = HTML.IndexOf("<img src=\"http://image2.sina.com.cn/dy/weather/images/figure/",0,HTML.Length);
    stop = HTML.IndexOf("<td background=http://image2.sina.com.cn/dy/weather/images",start);
    temp = HTML.Substring(start, stop - start);
   }
   catch (Exception x)
   {
   }
   return temp;
  }
 }

时间: 2024-09-12 22:47:50

用C#读取sina天气预报到wap页面(二)的相关文章

用C#读取sina天气预报到wap页面(一)

sina|天气预报|页面 页面代码:<%@ Register TagPrefix="mobile" Namespace="System.Web.UI.MobileControls" Assembly="System.Web.Mobile" %><%@ Page language="c#" Codebehind="weather.aspx.cs" Inherits="goodwap

php生成WAP页面

页面 WAP(无线通讯协议)是在数字移动电话.个人手持设备(PDA等)及计算机之间进行通讯的开放性全球标准.由于静态的WAP页面在很多方面不能满足用户个性化的服务请求,因此通过WAP服务器端语言产生动态的WML页面,具有很广泛的应用价值和很高的商业价值. WAP应用结构非常类似于Internet,一个典型的WAP应用请求是这样的:首先,具有WAP用户代理功能的移动终端(WAP手机等)通过内部运行的微浏览器(Micro Browser)对某一网站以无线方式发送WAP服务请求.该请求先由WAP网关截

PHP生成动态WAP页面(转一)

动态|页面 WAP(无线通讯协议)是在数字移动电话.个人手持设备(PDA等)及计算机之间进行通讯的开放性全球标准.由于静态的WAP页面在很多方面不能满足用户个性化的服务请求,因此通过WAP服务器端语言产生动态的WML页面,具有很广泛的应用价值和很高的商业价值. WAP应用结构非常类似于Internet,一个典型的WAP应用请求是这样的:首先,具有WAP用户代理功能的移动终端(WAP手机等)通过内部运行的微浏览器(Micro Browser)对某一网站以无线方式发送WAP服务请求.该请求先由WAP

PHP生成动态WAP页面(转二)

动态|页面 一.设置WEB服务器 首先你的 Web服务器要安装好PHP,即能处理PHP脚本程序.其次,为使Web服务器能同时识别和处理PHP.WML.WBMP等文件,Web 服务器的MIME表需添加以下的几种文件类型. text/vnd.wap.wml .wml image/vnd.wap.wbmp .wbmp application/vnd.wap.wmlc .wmlc text/vnd.wap.wmls.wmls application/vnd.wap.wmlsc .wmlsc 二.用PHP

如何用php生成WAP页面

页面 WAP(无线通讯协议)是在数字移动电话.个人手持设备(PDA等)及计算机之间进行通讯的开放性全球标准.由于静态的WAP页面在很多方面不能满足用户个性化的服务请求,因此通过WAP服务器端语言产生动态的WML页面,具有很广泛的应用价值和很高的商业价值. WAP应用结构非常类似于Internet,一个典型的WAP应用请求是这样的:首先,具有WAP用户代理功能的移动终端(WAP手机等)通过内部运行的微浏览器(Micro Browser)对某一网站以无线方式发送WAP服务请求.该请求先由WAP网关截

PHP生成动态WAP页面

动态|页面 WAP(无线通讯协议)是在数字移动电话.个人手持设备(PDA等)及计算机之间进行通讯的开放性全球标准.由于静态的WAP页面在很多方面不能满足用户个性化的服务请求,因此通过WAP服务器端语言产生动态的WML页面,具有很广泛的应用价值和很高的商业价值. WAP应用结构非常类似于Internet,一个典型的WAP应用请求是这样的:首先,具有WAP用户代理功能的移动终端(WAP手机等)通过内部运行的微浏览器(Micro Browser)对某一网站以无线方式发送WAP服务请求.该请求先由WAP

用 PHP 编程语言开发动态 WAP 页面

编程|动态|页面 WAP (无线通讯协议)是在数字移动电话.个人手持设备(PDA等)及计算机之间进行通讯的开放性全球标准协议.随着无线通讯的不断发展,静态的 WAP 页面在很多方面已经不能满足用户个性化的要求,因此开发者可以在 WAP 服务器端使用诸如PHP等语言产生动态的 WML 页面,来满足用户的需要. WAP 的应用结构非常类似于 Internet,一个典型的 WAP 应用请求步骤描述如下: 1. 具有 WAP 用户代理功能的移动终端(如 WAP 手机),通过内部运行的微浏览器向某一网站发

php生成WAP页面的详细讲解

页面 WAP(无线通讯协议)是在数字移动电话.个人手持设备(PDA等)及计算机之间进行通讯的开放性全球标准.由于静态的WAP页面在很多方面不能满足用户个性化的服务请求,因此通过WAP服务器端语言产生动态的WML页面,具有很广泛的应用价值和很高的商业价值. WAP应用结构非常类似于Internet,一个典型的WAP应用请求是这样的:首先,具有WAP用户代理功能的移动终端(WAP手机等)通过内部运行的微浏览器(Micro Browser)对某一网站以无线方式发送WAP服务请求.该请求先由WAP网关截

WAP页面设计与实现

目前绝大多数手机都支持WAP 2.0.WAP 2.0的页面设计具有更好的视觉效果,更接近网页.不过由于手机千差万别,手机浏览器的能力也各不相同,直接照搬网页的设计与实现,很可能让你的WAP页面出现问题.以下小贴士来自于我们的页面设计与开发实践. 1.当你试图使用背景图时,请同时搭配近似的背景色 手机上,有些浏览器是不支持使用背景图片的.比如下图,在S60v3操作系统的手机(如N76)上: 喜欢使用深色背景图片和浅色文字的同学们请注意了,在不支持背景图片的浏览器上,很可能由于"靠色",而