• Stars
    star
    171
  • Rank 215,306 (Top 5 %)
  • Language
    PHP
  • Created almost 6 years ago
  • Updated 12 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

🌈 基于高德开放平台接口的 PHP 天气信息组件。

Weather

🌈 基于高德开放平台的 PHP 天气信息组件。

Tests

Sponsor me

安装

$ composer require overtrue/weather -vvv

配置

在使用本扩展之前,你需要去 高德开放平台 注册账号,然后创建应用,获取应用的 API Key。

使用

use Overtrue\Weather\Weather;

$key = 'xxxxxxxxxxxxxxxxxxxxxxxxxxx';

$weather = new Weather($key);

获取实时天气

$response = $weather->getLiveWeather('深圳');

示例:

{
    "status": "1",
    "count": "1",
    "info": "OK",
    "infocode": "10000",
    "lives": [
        {
            "province": "广东",
            "city": "深圳市",
            "adcode": "440300",
            "weather": "中雨",
            "temperature": "27",
            "winddirection": "西南",
            "windpower": "5",
            "humidity": "94",
            "reporttime": "2018-08-21 16:00:00"
        }
    ]
}

获取近期天气预报

$response = $weather->getForecastsWeather('深圳');

示例:

{
    "status": "1",
    "count": "1",
    "info": "OK",
    "infocode": "10000",
    "forecasts": [
        {
            "city": "深圳市",
            "adcode": "440300",
            "province": "广东",
            "reporttime": "2018-08-21 11:00:00",
            "casts": [
                {
                    "date": "2018-08-21",
                    "week": "2",
                    "dayweather": "雷阵雨",
                    "nightweather": "雷阵雨",
                    "daytemp": "31",
                    "nighttemp": "26",
                    "daywind": "无风向",
                    "nightwind": "无风向",
                    "daypower": "≤3",
                    "nightpower": "≤3"
                },
                {
                    "date": "2018-08-22",
                    "week": "3",
                    "dayweather": "雷阵雨",
                    "nightweather": "雷阵雨",
                    "daytemp": "32",
                    "nighttemp": "27",
                    "daywind": "无风向",
                    "nightwind": "无风向",
                    "daypower": "≤3",
                    "nightpower": "≤3"
                },
                {
                    "date": "2018-08-23",
                    "week": "4",
                    "dayweather": "雷阵雨",
                    "nightweather": "雷阵雨",
                    "daytemp": "32",
                    "nighttemp": "26",
                    "daywind": "无风向",
                    "nightwind": "无风向",
                    "daypower": "≤3",
                    "nightpower": "≤3"
                },
                {
                    "date": "2018-08-24",
                    "week": "5",
                    "dayweather": "雷阵雨",
                    "nightweather": "雷阵雨",
                    "daytemp": "31",
                    "nighttemp": "26",
                    "daywind": "无风向",
                    "nightwind": "无风向",
                    "daypower": "≤3",
                    "nightpower": "≤3"
                }
            ]
        }
    ]
}

获取 XML 格式返回值

以上两个方法第二个参数为返回值类型,可选 jsonxml,默认 json

$response = $weather->getLiveWeather('深圳', 'xml');

示例:

<response>
    <status>1</status>
    <count>1</count>
    <info>OK</info>
    <infocode>10000</infocode>
    <lives type="list">
        <live>
            <province>广东</province>
            <city>深圳市</city>
            <adcode>440300</adcode>
            <weather>中雨</weather>
            <temperature>27</temperature>
            <winddirection>西南</winddirection>
            <windpower>5</windpower>
            <humidity>94</humidity>
            <reporttime>2018-08-21 16:00:00</reporttime>
        </live>
    </lives>
</response>

参数说明

array | string   getLiveWeather(string $city, string $format = 'json')
array | string   getForecastsWeather(string $city, string $format = 'json')
  • $city - 城市名/高德地址位置 adcode,比如:“深圳” 或者(adcode:440300);
  • $format - 输出的数据格式,默认为 json 格式,当 output 设置为 “xml” 时,输出的为 XML 格式的数据。

在 Laravel 中使用

在 Laravel 中使用也是同样的安装方式,配置写在 config/services.php 中:

    .
    .
    .
     'weather' => [
        'key' => env('WEATHER_API_KEY'),
    ],

然后在 .env 中配置 WEATHER_API_KEY

WEATHER_API_KEY=xxxxxxxxxxxxxxxxxxxxx

可以用两种方式来获取 Overtrue\Weather\Weather 实例:

方法参数注入

    .
    .
    .
    public function edit(Weather $weather)
    {
        $response = $weather->getLiveWeather('深圳');
    }
    .
    .
    .

服务名访问

    .
    .
    .
    public function edit()
    {
        $response = app('weather')->getLiveWeather('深圳');
    }
    .
    .
    .

参考

❤️ Sponsor me

Sponsor me

如果你喜欢我的项目并想支持它,点击这里 ❤️

Project supported by JetBrains

Many thanks to Jetbrains for kindly providing a license for me to work on this and other open-source projects.

PHP 扩展包开发

想知道如何从零开始构建 PHP 扩展包?

请关注我的实战课程,我会在此课程中分享一些扩展开发经验 —— 《PHP 扩展包实战教程 - 从入门到发布》

License

MIT

More Repositories

1

pinyin

🇨🇳 基于词库的中文转拼音优质解决方案
PHP
4,211
star
2

share.js

一键分享到微博、QQ空间、QQ好友、微信、腾讯微博、豆瓣、Facebook、Twitter、Linkedin、Google+、点点等
JavaScript
3,670
star
3

easy-sms

📲 一款满足你的多种发送需求的短信发送组件
PHP
3,068
star
4

laravel-wechat

微信 SDK for Laravel, 基于 overtrue/wechat
PHP
2,847
star
5

socialite

Socialite is an OAuth2 Authentication tool. It is inspired by laravel/socialite, you can easily use it without Laravel.
PHP
1,280
star
6

laravel-lang

🌏 75 languages support for Laravel application.
PHP
1,271
star
7

laravel-follow

❤️ This package helps you to add user based follow system to your model.
PHP
1,145
star
8

api.yike.io

一刻社区后端 API 源码
PHP
1,019
star
9

phplint

🐛 A tool that can speed up linting of php files by running several lint processes at once.
PHP
963
star
10

yike.io

一刻社区前端源码
Vue
653
star
11

laravel-pinyin

🇨🇳 Chinese to Pinyin translator for Laravel 5 / Lumen
PHP
524
star
12

chinese-calendar

📅 中国农历(阴历)与阳历(公历)转换与查询工具
PHP
513
star
13

vue-avatar-cropper

👧 A simple and elegant avatar cropping and upload plugin.
JavaScript
497
star
14

laravel-filesystem-qiniu

A Qiniu Storage filesystem for Laravel
PHP
471
star
15

laravel-versionable

⏱️Make Laravel model versionable
PHP
445
star
16

laravel-like

👍 User-like features for Laravel Application.
PHP
431
star
17

laravel-query-logger

📝 A dev tool to log all queries for laravel application.
PHP
403
star
18

laravel-ueditor

UEditor integration for Laravel.
JavaScript
391
star
19

laravel-shopping-cart

🛒 Shopping cart for Laravel Application.
PHP
390
star
20

laravel-favorite

❤️ User favorite feature for Laravel Application.
PHP
385
star
21

laravel-socialite

:octocat: Social OAuth Authentication for Laravel 5. drivers: facebook, github, google, linkedin, weibo, qq, wechat and douban
PHP
333
star
22

latest-laravel

【不再更新】这些东西本不应该存在。
Shell
282
star
23

weibo-dogs-killer

一段屏蔽 HWB(微博监督员) 的 js 小脚本
274
star
24

wisteria

Beautiful document tool for your project.
Blade
255
star
25

flysystem-qiniu

💾 Flysystem adapter for the Qiniu storage.
PHP
221
star
26

package-builder

📦 A composer package builder.
PHP
199
star
27

yike

PHP
165
star
28

laravel-subscribe

📧 User Subscribe/Unsubscribe features for Laravel Application.
PHP
164
star
29

laravel-emoji

😄 This package assist you in getting started with emoji easily.
PHP
150
star
30

vscode-miniapp-helper

微信小程序开发助手 for VSCode
JavaScript
149
star
31

yaf-skeleton

The Yaf testable skeleton and composer supported.
PHP
142
star
32

laravel-skeleton

Laravel Application skeleton for me.
PHP
140
star
33

laravel-uploader

🌴 An upload component for Laravel.
PHP
135
star
34

http

🌵 A simple http client wrapper.
PHP
127
star
35

writor

基于 Laravel 4 开发的博客系统
JavaScript
125
star
36

pinyin-resources

汉字拼音相关参考资料
122
star
37

laravel-vote

⬆️ ⬇️ User vote system for Laravel Application.
PHP
102
star
38

validation

Laravel Validation 简化无依赖版
PHP
99
star
39

bootstrap-theme-slim

纤细风格的bootstrap主题
HTML
92
star
40

city.js

城市选择控件
92
star
41

laravel-payment

Omnipay ServiceProvider for Laravel.
PHP
92
star
42

laravel-passport-cache-token

Make laravel/passport token cacheable.
PHP
88
star
43

laravel-filesystem-cos

Tencent Cloud COS storage for Laravel based on overtrue/flysystem-cos.
PHP
83
star
44

blog

安正超博客
Less
74
star
45

rester

基于 Slim+Eloquent 的 RESTful API 框架
PHP
72
star
46

flysystem-cos

💾 Flysystem adapter for the Qcloud COS storage.
PHP
72
star
47

laravel-mail-aliyun

📧 Aliyun DrirectMail Transport for Laravel Application.
PHP
71
star
48

php-opencc

中文简繁转换,支持词汇级别的转换、异体字转换和地区习惯用词转换(中国大陆、台湾、香港、日本新字体)。
PHP
61
star
49

laravel-youzan

【停止维护】Youzan wrapper for Laravel
PHP
59
star
50

websocket

A PHP implementation of WebSocket.
PHP
56
star
51

laravel.xyz

Source code of https://laravel.xyz
Vue
50
star
52

json-viewer

A tool for make JSON view in browser.
JavaScript
49
star
53

laravel-options

Global options module for Laravel application.
PHP
49
star
54

php-package

A PHP package template repository.
44
star
55

building-with-tailwindcss

HTML
43
star
56

phpmd-rulesets

PHP_MD 规则
42
star
57

laravel-qcloud-content-audit

腾讯云内容安全(文字图片内容审核)服务
PHP
42
star
58

sketch-data-cn

为 Sketch 准备的模拟数据中文版,包含:中文姓名,手机号,省份,城市,地区,公司名,银行名,星期几,详情地址,邮编,邮箱,颜色,广告词等。
41
star
59

qcloud-cos-client

Tencent COS Client
PHP
40
star
60

validator.js

一个类似laravel的js验证模块.
JavaScript
39
star
61

translator

PHP多语言支持工具
PHP
38
star
62

laravel-payable

Payment system for Laravel.
PHP
35
star
63

laravel-package

Laravel package template
PHP
35
star
64

laravel-revaluation

Laravel 5 model revaluation helper.
PHP
31
star
65

laravel-easy-sms

overtrue/easy-sms service provider for Laravel.
PHP
25
star
66

laravel-saml

SAML toolkit for Laravel based on OneLogin's SAML PHP Toolkit.
PHP
20
star
67

sendcloud

SendCloud Mail SDK
PHP
20
star
68

laravel-sendcloud

SendCloud Mail SDK for Laravel.
PHP
20
star
69

latest-lumen

【不再更新】这些东西本不应该存在。
Shell
19
star
70

laravel-stateless-session

A lightweight middleware to make api routing session capable.
PHP
18
star
71

laravel-single-session

A plugin provide single session authentication for Laravel 5.
PHP
17
star
72

laravel-passport-cache-client

Make laravel/passport client cacheable.
PHP
17
star
73

php-multi-process-runner

基于PHP拓展PCNTL的多进程执行工具
PHP
17
star
74

laravel-summernote

Summernote editor integration for Laravel 5.
JavaScript
16
star
75

cuttle

📃 A multi-module log wrapper.
PHP
15
star
76

laravel-qcloud-federation-token

QCloud COS FederationToken generator for Laravel.
PHP
15
star
77

stuq-laravel-course

StuQ小班课|Laravel实战经验分享及PHP后端编程思想
PHP
13
star
78

laravel.so

Source Code of http://laravel.so (old)
PHP
13
star
79

double-array-trie

PHP
12
star
80

overtrue

https://overtrue.me
12
star
81

bash-color

Generate command line colorized text.
PHP
12
star
82

pinyin-dictionary-maker

📇 Dictionary make of overtrue/pinyin.
PHP
12
star
83

relocator.js

relocate images to fit image box
JavaScript
11
star
84

laravel-open-telemetry

This package provides a simple way to add OpenTelemetry to your Laravel application.
PHP
11
star
85

youzan

【不再维护】Youzan SDK.
PHP
10
star
86

wisteria-skeleton

The skeleton of Wisteria.
PHP
10
star
87

wp-cn-excerpt

wordpress中文摘要插件
PHP
10
star
88

laravel-custom-log

📃 Make Laravel Log great again.
PHP
9
star
89

laravel-qcloud-captcha

QCloud Captcha service validator for Laravel.
PHP
7
star
90

editorjs-with-tailwindcss-in-react

create-react-app + Editorjs + Tailwindcss
JavaScript
7
star
91

vue-avatar-cropper-demo

Created with CodeSandbox
Vue
7
star
92

string2pinyin.sinaapp.com

PHP
3
star
93

responsive-preview-container

A simple and elegant responsive preview container
Vue
3
star
94

nuxt-dashboard

CSS
3
star
95

wp-auto-top

WordPress 返回顶部插件
PHP
2
star
96

redius.xyz

wip
2
star
97

overtrue.github.io

HTML
2
star
98

username-blacklist

PHP
2
star
99

dex-swap-test

JavaScript
1
star
100

easywechat-theme

Vue
1
star