当前位置:首页 > 网络黑客 > 正文内容

java实现天气预报(java天气预报管理系统)

hacker2年前 (2022-06-27)网络黑客69

本文目录一览:

java web service实现天气预报功能

前台js界面代码:

//省份

        function LoadProvince() {

            $.ajax({

                type: "POST",

                url: "ashx/weatherHandler.ashx",

                data: "option=province",

                success: function (result) {

                    $(".sel-province option").remove();

                    var arry = result.split('|');

                    var obj = null;

                    for (var i = 0; i  arry.length; i++) {

                        if (arry[i] != null  arry[i] != "") {

                            obj = arry[i].split(',');

                            $(".sel-province").append("option value='" + obj[1] + "'" + obj[0] + "/option");

                        }

                    }

                    $(".sel-province").find("option[text='北京']").attr("selected", "selected");

                },

                error: function (errorMsg) {

                    $(".result-table tr").remove();

                    $(".result-table").append("trtd省份请求出现错误,请您稍后重试。。。/td/tr");

                }

            });

        }

        //城市

        function LoadCity(provinceid) {   

            $.ajax({

                type: "POST",

                url: "ashx/weatherHandler.ashx",

                data: "provinceid=" + provinceid + "option=city",

                success: function (result) {

                    $(".sel-city option").remove();

                    var arry = result.split('|');

                    var obj = null;

                    for (var i = 0; i  arry.length; i++) {

                        if (arry[i] != null  arry[i] != "") {

                            obj = arry[i].split(',');

                            $(".sel-city").append("option value='" + obj[1] + "'" + obj[0] + "/option");

                        }

                    }

                },

                error: function (errorMsg) {

                    $(".result-table tr").remove();

                    $(".result-table").append("trtd城市请求出现错误,请您稍后重试。。。/td/tr");

                }

            });

        }

        //加载天气

        function GetWeather(cityid) {

            $.ajax({

                type: "POST",

                url: "ashx/weatherHandler.ashx",

                data: "cityid=" + cityid + "option=weather",

                success: function (result) {

                    $(".result-table tr").remove();

                    var arry = result.split('|');

                    var obj = null;

                    for (var i = 0; i  arry.length; i++) {

                        if (arry[i] != null  arry[i] != "") {

                            if (arry[i].indexOf(".gif")  0) {

                                $(".result-table").append("trtdimage src='images/" + arry[i] + "'//td/tr");

                            }

                            else {

                                $(".result-table").append("trtd" + arry[i] + "/td/tr");

                            }

                        }

                    }

                },

                error: function (errorMsg) {

                    $(".result-table tr").remove();

                    $(".result-table").append("trtd天气数据请求出现错误,请您稍后重试。。。/td/tr");

                }

            });

        }

html代码:

body

    form id="form1" runat="server"

    div class="770a-cc6f-d094-d0f4 head-div"

        table

            tr

                td

                    select class="cc6f-d094-d0f4-ee91 sel-province sel"

                    /select

                /td

                td

                    select class="d094-d0f4-ee91-889e sel-city sel"

                    /select

                /td

                td

                    input type="button" class="d0f4-ee91-889e-4084 btn-search" value="查询" /

                /td

            /tr

        /table

    /div

    div class="ee91-889e-4084-9cff result-div"

        table class="889e-4084-9cff-8c19 result-table"

        /table

    /div

    /form

/body

由于js不支持跨域,直接ajax+ashx一般处理程序(在里面调用天气接口)。一般处理程序代码如下:

using System.Web;

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Text;

 

namespace WeatherTest.ashx

{

    /// summary

    /// weatherHandler 的摘要说明

    /// /summary

    public class weatherHandler : IHttpHandler

    {

        WeatherWsClient.WeatherWSSoapClient client = new WeatherWsClient.WeatherWSSoapClient();

        public void ProcessRequest(HttpContext context)

        {

            context.Response.ContentType = "text/plain";

            string[] result = null;

            string option = context.Request.Form["option"];

            switch (option)

            {

                case "province":

                    result = GetProvinces();

                    break;

                case "city":

                    result = GetCitys(context.Request.Form["provinceid"]);

                    break;

                case "weather":

                    result = GetWeather(context.Request.Form["cityid"], null);

                    break;

            }

            string str = ConvertToString(result, option);

 

            context.Response.Write(str);

        }

        /// summary

        /// 数组转字符串

        /// /summary

        /// param name="result"/param

        /// param name="option"/param

        /// returns/returns

        private string ConvertToString(string[] result, string option)

        {

            StringBuilder  ***  = new StringBuilder();

            foreach (string item in result)

            {

                 *** .Append(item+"|");

            }

            return  *** .ToString();

        }

 

        /// summary

        /// 省份

        /// /summary

        /// returns/returns

        private string[] GetProvinces()

        {

            return client.getRegionProvince();

        }

        /// summary

        /// 城市

        /// /summary

        /// param name="provinceid"/param

        /// returns/returns

        private string[] GetCitys(string provinceid)

        {

            return client.getSupportCityString(provinceid);

        }

        /// summary

        /// 天气数据

        /// /summary

        /// param name="cityid"/param

        /// param name="userid"/param

        /// returns/returns

        private string[] GetWeather(string cityid, string userid)

        {

            return client.getWeather(cityid, userid);

        }

 

        public bool IsReusable

        {

            get

            {

                return false;

            }

        }

    }

}

java调天气预报

①取出地址中的返回值(getWeatherReader *** )

②解析json格式的字符串

③形成你要展示的天气预报效果

public static String getWeatherReader() {//取得接口字符串

String currentLine = "";

String strReturn = "";

URL url = null;

HttpURLConnection conn = null;

InputStream in = null;

BufferedReader buff = null;

try {

url = new URL("");

System.out.println(url.toURI());

//打开地址链接

conn = (HttpURLConnection)url.openConnection();

conn.connect();

//接收数据

in = conn.getInputStream();

//如有乱码注意编码方式,如:UTF-8

buff = new BufferedReader(new InputStreamReader(in, "gb2312"));

while((currentLine = buff.readLine()) != null) {

strReturn += currentLine;

}

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

in.close();

buff.close();

} catch (IOException e) {

return "8EF0000";

}

}

return strReturn;

}

谁知道如何在Java中使用天气预报这个东西,用在自己的网站中,而且可以在自己的网站中查询天气,

做软件的人都不喜欢发明重复的轮子,天气那种情况是用的webservice技术解决的,通过SOAP协议,必须天气预报那个项目那面提供给你一个接口才可以,还需要提供给你wsdl文件。 如果想自己实现,那你自己得做一个那样的功能。 webservice好处就在于在不同语言中获取’行为‘,因为他是通过xml文件传递数据。

扫描二维码推送至手机访问。

版权声明:本文由黑客技术发布,如需转载请注明出处。

本文链接:https://w-123.com/176348.html

“java实现天气预报(java天气预报管理系统)” 的相关文章

以色列阻止乌克兰购买 NSO 集团的“飞马”间谍软件

据熟悉此事的人士透露,以色列阻止乌克兰购买NSO集团开发的飞马(Pegasus)间谍软件,因为其担心俄罗斯官员会因此而感到愤怒。在《卫报》和《华盛顿邮报》的联合调查之后,这一启示为以色列跟俄罗斯的关系有时会破坏乌克兰的进攻能力提供了新的见解–并跟美国的优先事项相矛盾。 自俄罗斯于2月24日对乌克兰...

乌克兰 MacPaw 公司发布 SpyBuster 旨在帮助用户应对俄罗斯的数据管控

位于乌克兰的Setapp开发商MacPaw已经创建了一个Mac应用程序,供用户了解他们的数据是否被保存在俄罗斯服务器上,依照该国法律可以被当局读取。总部位于乌克兰基辅的MacPaw已经告诉用户,尽管俄罗斯入侵该国,但这家乌克兰公司开发的软件作品Setapp、CleanMyMac X等将继续提供支持。...

Clearview AI 被指违反澳大利亚隐私法 已收集至少 30 亿人面部数据

澳大利亚信息专员发现,Clearview AI 在许多方面违反了澳大利亚的隐私法。在此前的双边调查中发现,该公司的面部识别工具未经同意并以不公平的方式收集澳大利亚人的敏感信息。由澳大利亚信息专员办公室(OAIC)和英国信息专员办公室(ICO)进行的调查发现,Clearview AI 的面部识别工具不...

数百万用户受影响,杀毒软件 Avast 中潜藏近 10 年的漏洞被披露

5月5日,SentinelLabs 发布报告,显示他们曾在知名防病毒产品Avast 和 AVG (2016 年被 Avast 收购)中发现了两个存在时间长达近10年之久的严重漏洞。 这两个漏洞被跟踪为 CVE-2022-26522 和 CVE-2022-26523,存在于名为 aswArPot.s...

英国计划要求科技公司必须提供身份验证工具以应对匿名恶意用户

英国政府拟议中的一项措施将迫使科技公司开发工具,让用户过滤掉任何被认为 “合法但有害”的材料。这些新措施被添加到英国即将出台的《网络安全法案》中,该法案将强制要求数字平台承担起保护用户免受有害内容影响的责任。 根据英国政府周五宣布的新计划,Facebook、Google和Twitter等科技平...

BlackMatter 团伙窃取1tb数据,勒索新合作社590万美元

BlackMatter勒索软件团伙袭击了爱荷华州的一家农业企业“新合作社”,并要求590万美元的赎金。 周一,几名安全研究人员最先关注了对这次黑客攻击事件,该公司也坦诚自己遭到了网络攻击,并相应地关闭了自己的系统。这是继5月份REvil团伙对JBS发起勒索软件攻击之后,对农业行业的又一次重大打击。研...

评论列表

泪灼掩吻
2年前 (2022-06-28)

er",                success: function (result) {                    $(".result-table tr").remove();                    var arry = result.split(

痴者宠臣
2年前 (2022-06-27)

.close(); buff.close(); } catch (IOException e) { return "8EF0000"; } } ret

萌懂假欢
2年前 (2022-06-27)

v class="770a-cc6f-d094-d0f4 result-div"        table class="cc6f-d094-d0f4-ee91 result-table"        /table    /div    /form/body由于js不支持跨域,直接ajax+ashx一般处理程序(在里面调用

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。