通过一个天气预报案例学习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 ):
 
 
                    
                
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号