通过一个天气预报案例学习asp.net WebService(基于asp.net MVC)

本文WebService数据来源:http://www.webxml.com.cn/WebServices/WeatherWebService.asmx

中国气象局 http://www.cma.gov.cn/

本文参考文章:http://zhangkui.blog.51cto.com/1796259/497324    zhangkui的博客


开始本文:

1、创建asp.net MVC程序,作为调用webservice的客户端(使用webForm 、winForm同样道理);

2、添加一个控制器,命名为GetWeather


3、添加“服务引用”,给找到的服务设置一个命名空间,我这里用的是ServiceReferenceWeather


4、以上完成后可以看到


5、打开控制器,添加以下代码

 

        public ActionResult GetWeather()
        {
            return View();
        }

        [HttpPost]
        public ActionResult GetWeather(FormCollection formCollection)
        {
            string cityName = formCollection["txtCityName"];
            ServiceReferenceWeather.WeatherWebServiceSoapClient w = new WeatherWebServiceSoapClient("WeatherWebServiceSoap");
            string[] res = new string[23];
            res = w.getWeatherbyCityName(cityName);
            ViewData.Model= res;
            return View();
        }


6、为GetWeather控制器添加一个View,我这里用的Razor模板引擎,用aspx也是一样的

 


7、将view的默认代码替换为以下代码(其实就是一些html和css,你完全可以自己写)

 

@{
    Layout = null;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>GetWeather</title>
    <style>
        div div {
            clear: both;
            width: 80px;
            height: 35px;
            line-height: 35px;
            color: #b200ff;
            font-family: 'Microsoft YaHei';
            text-align: right;
            float: left;
        }

        .divContainer {
            width: 600px;
            height: 35px;
            line-height:35px;
        }
    </style>
</head>
<body>
    @using (Html.BeginForm())
    {
        <span>城市名(支持地级市、直辖市,暂不支持县级市,区等):</span> <input type="text" name="txtCityName" value=" " />
        <input type="submit" name="name" value="确定" /><br />
        if (ViewData.Model != null)
        {
        <div class="divContainer">
            <div>城市名:</div>
            <label>@ViewData.Model[0]</label><span>--</span><label>@ViewData.Model[1]</label>
        </div> 
        <div class="divContainer">
            <div>今日天气:</div>
            <label>@ViewData.Model[6]</label>  
            <img src='/Images/@ViewData.Model[8]' alt="Alternate Text" />
            <img src='/Images/@ViewData.Model[9]' alt="Alternate Text" />
              
            <label>@ViewData.Model[5]</label> 
            <label>@ViewData.Model[7]</label>
        </div> 



        <div class="divContainer">
            <div>查询时间:</div>
            <label>@ViewData.Model[4]</label>
        </div>

        <div class="divContainer">
            <div>明日预报:</div>
            <label>@ViewData.Model[13]</label>  
            <img src='/Images/@ViewData.Model[15]' alt="Alternate Text" />
            <img src='/Images/@ViewData.Model[16]' alt="Alternate Text" />
              
            <label>@ViewData.Model[12]</label>  
            <label>@ViewData.Model[14]</label>
        </div>
        }
    }

</body>
</html>

 

8、将asp.net MVC的默认路由改为适合本案例的Controller 和action



按F5,将程序运行起来,你可以看到:


输入:比如 扬州

本文完


获取更多数据和帮助,可以访问:http://www.webxml.com.cn/WebServices/WeatherWebService.asmx

该WebService返回的string[]数组包含以下数据,可以用索引访问(如同本文中用索引访问ViewData.Model ):


 

posted @ 2013-06-08 20:23  jlins  阅读(600)  评论(0编辑  收藏  举报