HttpWebRequest实现读取天气预报信息-程序员宅基地

技术标签: c#  ViewUI  ui  javascript  

<HTML>
    <HEAD>
        <title>Weather</title>
        <meta content="Microsoft Visual Studio .NET 7.1" name="GENERATOR">
        <meta content="C#" name="CODE_LANGUAGE">
        <meta content="JavaScript" name="vs_defaultClientScript">
        <meta content="http://schemas.microsoft.com/intellisense/ie5" name="vs_targetSchema">
    </HEAD>
    <body MS_POSITIONING="GridLayout">
        <form id="Form1" method="post" runat="server">
            <TABLE id="Table1" style="Z-INDEX: 110; LEFT: 296px; WIDTH: 320px; POSITION: absolute; TOP: 24px; HEIGHT: 231px"
                cellSpacing="1" cellPadding="1" width="320" bgColor="#ffff99" border="1">
                <TR>
                    <TD><asp:label id="Label1" runat="server" Font-Italic="True">==天气预报==</asp:label></TD>
                    <TD><asp:dropdownlist id="ddlcity" runat="server">
                            <asp:ListItem Value="深圳" Selected="True">深圳</asp:ListItem>
                            <asp:ListItem Value="广州">广州</asp:ListItem>
                            <asp:ListItem Value="上海">上海</asp:ListItem>
                            <asp:ListItem Value="北京">北京</asp:ListItem>
                            <asp:ListItem Value="天津">天津</asp:ListItem>
                            <asp:ListItem Value="武汉">武汉</asp:ListItem>
                            <asp:ListItem Value="重庆">重庆</asp:ListItem>
                            <asp:ListItem Value="成都">成都</asp:ListItem>
                            <asp:ListItem Value="南京">南京</asp:ListItem>
                            <asp:ListItem Value="香港">香港</asp:ListItem>
                            <asp:ListItem Value="澳门">澳门</asp:ListItem>
                        </asp:dropdownlist></TD>
                    <TD><asp:button id="Button1" runat="server" Text="读取"></asp:button></TD>
                </TR>
                <TR>
                    <TD colSpan="3"><asp:label id="l_city" runat="server"></asp:label></TD>
                </TR>
                <TR>
                    <TD colSpan="3"><asp:label id="l_wea" runat="server"></asp:label></TD>
                </TR>
                <TR>
                    <TD colSpan="3"><asp:label id="l_sky" runat="server"></asp:label></TD>
                </TR>
                <TR>
                    <TD colSpan="3"><asp:label id="l_date" runat="server"></asp:label></TD>
                </TR>
                <TR>
                    <TD colSpan="3"><asp:label id="l_w1" runat="server"></asp:label></TD>
                </TR>
                <TR>
                    <TD colSpan="3"><asp:label id="l_w2" runat="server"></asp:label></TD>
                </TR>
                <TR>
                    <TD colSpan="3"><asp:label id="l_w3" runat="server"></asp:label></TD>
                </TR>
                <TR>
                    <TD colSpan="3"><asp:label id="l_w4" runat="server"></asp:label></TD>
                </TR>
            </TABLE>
        </form>
    </body>
</HTML>2.cs
添加如下应用
using System.Net;
using System.IO;页面代码
public class Weather : System.Web.UI.Page
    {
        protected System.Web.UI.WebControls.Label l_date;
        protected System.Web.UI.WebControls.Label l_city;
        protected System.Web.UI.WebControls.Label l_wea;
        protected System.Web.UI.WebControls.Label l_sky;
        protected System.Web.UI.WebControls.Label l_w1;
        protected System.Web.UI.WebControls.Label l_w2;
        protected System.Web.UI.WebControls.Button Button1;
        protected System.Web.UI.WebControls.Label Label1;
        protected System.Web.UI.WebControls.Label l_w3;
        protected System.Web.UI.WebControls.Label l_w4;
        protected System.Web.UI.WebControls.DropDownList ddlcity;
   
        private void Page_Load(object sender, System.EventArgs e)
        {
            if (!Page.IsPostBack)
            {
                writeWeatherInfo(ddlcity.SelectedValue);
                writeWeather(ddlcity.SelectedValue);
            }
        }   

        getWeatherByCity 通过城市过虑#region getWeatherByCity 通过城市过虑
        public string getWeatherByCity(string city)
        {
            string temp = null;
            try
            {
                string strURL = "http://weather.news.sina.com.cn/cgi-bin/figureWeather/search.cgi";
                HttpWebRequest request= (HttpWebRequest)WebRequest.Create(strURL);//使用 WebRequest.Create 方法初始化 HttpWebRequest 的一个新实例。如果 URI 的方案是 http:// 或 https://,则 Create 将返回 HttpWebRequest 实例。
                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 = 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 = (HttpWebResponse)request.GetResponse(); //获得响应流
                Stream 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("&lt;","<");
                HTML = HTML.Replace("&gt;",">");
                int start,stop;
                //start = HTML.IndexOf("<img src=\"http://image2.sina.com.cn/dy/weather/images/figure/",0,HTML.Length);
                start = HTML.IndexOf("<table border=0 cellpadding=0 cellspacing=0 style=\"margin:5px;\">",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;
        }

        #endregion

        writeWeatherInfo 显示处理后的信息#region writeWeatherInfo 显示处理后的信息
        private void writeWeatherInfo(string city)
        {
            int start,stop;
            string weather1,weather2,wea;
            string wea_city = getWeatherByCity(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]; //空气质量
            l_w4.Text = wall[4]; //紫外线强度
        }
   
        #endregion

        writeWeather 直接显示读取到的信息#region writeWeather 直接显示读取到的信息
        private void writeWeather(string city)
        {
            string wea_city = getWeatherByCity(city);
            Response.Write(wea_city);
        }
        #endregion
   
        Button1_Click#region Button1_Click
        private void Button1_Click(object sender, System.EventArgs e)
        {
            writeWeatherInfo(ddlcity.SelectedValue);
            writeWeather(ddlcity.SelectedValue);
        }
        #endregion

        Web Form Designer generated code#region Web Form Designer generated code
        override protected void OnInit(EventArgs e)
        {
            //
            // CODEGEN: This call is required by the ASP.NET Web Form Designer.
            //
            InitializeComponent();
            base.OnInit(e);
        }
       
        /** <summary>
        /// Required method for Designer support - do not modify
        /// the contents of this method with the code editor.
        /// </summary>
        private void InitializeComponent()
        {   
            this.Button1.Click += new System.EventHandler(this.Button1_Click);
            this.Load += new System.EventHandler(this.Page_Load);

        }
        #endregion

       
    }

本文来自程序员宅基地,转载请标明出处:http://blog.csdn.net/zwei1121/archive/2006/04/10/657716.aspx

转载于:https://www.cnblogs.com/zhdonghu/archive/2010/10/09/1846910.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/anku0825/article/details/101513322

智能推荐

mysql 创建学生表_mysql创建学生信息表-程序员宅基地

文章浏览阅读2.4w次,点赞19次,收藏93次。创建两张表 1》学生基本信息表:姓名,性别,年龄 2》学生各科成绩表:科目,成绩,学期题目1、创建两张表create table student( s_id varchar(20) not null, s_name varchar(20) not null, s_sex varchar(20), s_age varchar(20) not null, primary key(s_..._mysql创建学生信息表

重置$.messager.confirm 弹出框的高度,以及显示的文字_$confirm 弹框内容过长-程序员宅基地

文章浏览阅读4.8k次。$.messager.defaults = { ok: "需要",collapsible:false,minimizable:false,maximizable:false,resizable:false,cancel:"不需要",width:'250px',height:'150px'}; _$confirm 弹框内容过长

Log算子_log算子模板-程序员宅基地

文章浏览阅读3k次。LOG算子,也就是Laplacian-Gauss算子。它把的Gauss平滑滤波器和Laplacian锐化滤波器结合了起来,先平滑掉噪声,再进行边缘检测,常用的5x5模板:-2 -4-4 -4 -2-4 08 0 -4-4 824 9 -4-4 08 0 -4-2 -4-4 -4 -2_log算子模板

给所有开发者的React Native详细入门指南-程序员宅基地

文章浏览阅读1.2k次。原文链接:http://www.jianshu.com/u/174a09ba6c25http://www.codeceo.com/article/facebook-react-native-app.html#0-qzone-1-31371-d020d2d2a4e8d1a374a433f596ad1440非常棒的一篇经验文章,作者总结了自己学习React Native的历程,对其

web_webqwq-程序员宅基地

文章浏览阅读178次。题目实现根据学院名称、专业名称两个条件查询学生信息,数据库及表结构自己定义和设计,学院名称和专业名称由数据库表维护(可直接通过数据库管理软件维护)。要求(1)学院名称和专业名称由EasyUI的下拉列表组件实现;并且如果学院名称不为空,则专业名称的选项值为所选学院所包含的专业名称。(2)可根据学院名称查询,也可以根据学院和专业名称查询,查询使用模糊查询; (3)将查询结果显示在EasyUI的DataGrid组件中,并提供将学生的信息导出到Excel文件中,Excel文件的模板样式自己定义;(4_webqwq

python删除表格第一行不动,Selenium Python遍历在第一行停止的行表-程序员宅基地

文章浏览阅读43次。I am iterating over a table of rows using Selenium Python. On the GUI i have deleted an item from a table. In my script I am checking if the item is not there to verify it has been deleted.When i it...

随便推点

idea插件开发教程_idea 插件开发-程序员宅基地

文章浏览阅读3k次。主要的插件类型UI主题插件自定义语言支持插件框架集成插件工具集成插件开发插件的三种方式Using GradleUsing GitHub Template在github上选择一个模板,会自动根据模板生成一个配置好的插件项目,可以直接clone到本地开发Using DevKit使用DevKit开发插件设置开发环境准备工作确认启用Plugin DevKit插件,该插件是IDEA自带的插件为项目配置IntelliJ Platform SDK创建一个ntelliJ Platf_idea 插件开发

C++11(11):动态内存-程序员宅基地

文章浏览阅读1.2k次。动态分配的内存,只有在显式释放是,这些对象才会销毁。但是标准库中的两智能指针可以确保自动释放除了静态内存和栈内存,每个程序还拥有一个内存池。这部分内存被称作自由空间或堆。静态内存用来保存局部static对象、类static数据成员以及定义在任何函数之外的变量。栈内存用来保存定义在函数没得非static对象。智能指针:三个类都定义在memory头文件中:shared_ptr允

SPSS Modeler 进行均值比较(指南 第八章)_telco.sav-程序员宅基地

文章浏览阅读1.2k次。案例:Demo文件下的telco.sav数据文件。数据展示:平均值节点1. 两组独立样本均值比较目的:分析流失组与非流失组客户的上月长途业务使用均值是否存在差异。1.1 数据流1.2 设置1.3 运行结果2. 多组独立样本均值比较目的:分析不同套餐的客户的上月长途业务使用均值是否存在差异。2.1 设置2.2 运行结果3. 配对样本均值比较目的:分析每名客户..._telco.sav

web_webqwq-程序员宅基地

文章浏览阅读177次。题目实现根据学院名称、专业名称两个条件查询学生信息,数据库及表结构自己定义和设计,学院名称和专业名称由数据库表维护(可直接通过数据库管理软件维护)。要求(1)学院名称和专业名称由EasyUI的下拉列表组件实现;并且如果学院名称不为空,则专业名称的选项值为所选学院所包含的专业名称。(2)可根据学院名称查询,也可以根据学院和专业名称查询,查询使用模糊查询; (3)将查询结果显示在EasyUI的DataGrid组件中,并提供将学生的信息导出到Excel文件中,Excel文件的模板样式自己定义;(4_webqwq

【渗透实战系列】| - 记某色X商城支付逻辑漏洞的白嫖(修改价格提交订单)_如何通过抓包修改商品价格-程序员宅基地

文章浏览阅读936次,点赞2次,收藏5次。涉及知识点:1、fofa搜索代码2、bp抓包3、cookie分析参数4、逻辑漏洞常在页面跳转参数传递中HACK学习呀Author 硝基苯好家伙,居然还真有这种商城,原谅我孤陋寡闻了。于是乎,想进去学习了一下首先,进行了一下初步的信息收集基本上都是伪静态的,没有什么发现可以明显判断其网站后端语言的地方在搜索框点击搜索后可以发现这个地址并不能帮助我们判断该站的类型但也要尝试一下SQL注入然后直接被 Ban IP了,索性放弃..._如何通过抓包修改商品价格

Deigo1# 机器视觉-人脸跟踪-程序员宅基地

文章浏览阅读401次,点赞2次,收藏4次。基于前面两节人脸检测,特征值获取及跟踪,我们进一步实现人脸的跟踪,我们可以让机器人跟踪人脸,暨当人脸移动时控制机器人转动,使得人脸始终在图像窗体的中间位置,基本流程如下人脸检测,lesson 16中已经介绍过了,这里直接引用就可以。特征获取,lesson 17中也已经实现,但要达到比较好的效果,需要对特征点做一些补偿及噪声点的剔除人脸跟踪,需要根据ROI的位置,来判断机器人需要怎样移动才能...