5

我正在使用根据我插入的 Yahoo API URL 更改我的 wordpress 网站背景的代码。有没有办法让它在没有任何数据库的情况下自动显示访客天气?我虽然使用过 Google 的 API,但我是编程新手,不知道如何在我的网站中实现它。请帮忙!代码可以在这里查看:http: //css-tricks.com/using-weather-data-to-change-your-websites-apperance-through-php-and-css/

请彻底,因为我是 PHP 新手 谢谢!

4

4 回答 4

7

您将需要一个 API 用于将访问者 IP 地址映射到位置 ( ipapi.co ),并需要另一个 API 来获取该位置的天气预报 ( openweathermap.org )。以下代码适用于 php(服务器端):

# Part 1 (get latitude & longitude)
$ip = '1.2.3.4';
$api_1 = 'https://ipapi.co/' . $ip . '/latlong/';
$location = file_get_contents($api_1);
$point = explode(",", $location);

# Part 2 (get weather forecast)
$api_2 = 'http://api.openweathermap.org/data/2.5/weather?lat=' . $point[0] . '&lon=' . $point[1] . '&appid=API_KEY';
$weather = file_get_contents($api_2);
于 2016-05-06T07:20:20.133 回答
5

这将使用来自Data Science Toolkit的开源IP2Coordinates 服务从用户的 IP 地址获取用户的邮政编码。

那里有更准确的地理位置 API,但这个 API 是完全免费的,而且使用起来非常简单。如果我在生产站点上开发这个,我会使用HTML5 Geolocation作为我的主要方法,并回退到更好的 IP 地理定位器,比如Max Mind

请注意,这仅适用于您网站的美国用户。您可能应该将更详细的数据传递给其他 Yahoo 地点 API 之一,以使用其 WOEID 之一(或选择不同的天气 API)。

这是给你的代码。将其放在<?php示例代码中的标记之后。一旦你确定它工作正常,注释掉所有以 . 开头的行print

//Get the user's IP address
$user_ip = $_SERVER['REMOTE_ADDR'];
//The Data Science Toolkit URL
$url = 'http://www.datasciencetoolkit.org/ip2coordinates/';
//Find the user's location from their IP. 
//*** You need the get_data function from the sample code
$raw_geocode = json_decode( get_data( $url . $user_ip) );
//Check if the user is in the US
if ('US' === $raw_geocode->$user_ip->country_code) {
  //If yes, store their zip code in a variable, and print it
  $zip_code = $raw_geocode->$user_ip->postal_code;
  printf('<p>Your zip code is: %s</p>', $raw_geocode->$user_ip->postal_code);
} else {
  //If the user isn't in the US, set a sip code that will work.
  $zip_code = '97211';
  //and print an error
  printf('<p>Sorry, this app does not work in %s.</p>', $raw_geocode->$user_ip->country_name);
}

//Print the raw data for debugging.
printf('<pre>%s</pre>', print_r($raw_geocode, true));

现在将示例代码中以此开头的行更改为$data =

$data = get_data("http://weather.yahooapis.com/forecastrss?p={$zip_code}&u=f");
于 2012-08-26T01:22:12.747 回答
1

使用ipinfo.ioOpenWeatherMap

Javascript:

<script type="text/javascript" src="jquery.simpleopenweather.js"></script>
<script type="text/javascript">
    $(document).ready(function() {
        $.get("http://ipinfo.io", function (response) {
            $("#weather").attr('data-simpleopenweather-city', response.city).simpleopenweather({template: '<h2>'+'{{temperature}} '+'&deg;'+'C'+'<h2>', units: 'metric'});
        }, "jsonp");
    });
</script>

HTML:

<div id="weather" class="simpleopenweather" data-simpleopenweather-city=""></div>

它将显示类似 6.3 ºC

于 2013-12-17T17:02:17.847 回答
0
***You can get data about the location with use third-party API. for example:http://ip-api.com/.**
You get your location weather data from OpenWeatherMap service using the ip-api. its help you to get visitor location weather.*



 var getIP = 'http://ip-api.com/json/';
    var openWeatherMap = 'http://api.openweathermap.org/data/2.5/weather'
    $.getJSON(getIP).done(function(location) {
        $.getJSON(openWeatherMap, {
            lat: location.lat,
            lon: location.lon,
            units: 'metric',
            APPID: 'Your-Openweather-Apikey'
        }).done(function(weather) {
          $('#weather').append(weather.main.temp);
            console.log(weather);
        })
    })

HTML:

<div id="weather"> </div>

它显示您当前的天气温度。

于 2020-10-13T04:55:50.667 回答