天气查询-24小时
<h3>接口描述</h3>
<ul>
<li>根据地名查询24小时的天气</li>
</ul>
<h3>请求地址</h3>
<p><code>https://api.jumdata.com/weather/query/24h</code></p>
<h3>请求方式</h3>
<ul>
<li>GET/POST</li>
</ul>
<h3>请求格式</h3>
<ul>
<li>x-www-form-urlencoded</li>
</ul>
<h3>请求参数</h3>
<table>
<thead>
<tr>
<th>名称</th>
<th>类型</th>
<th>必须</th>
<th><div style="width:400px">说明</div></th>
</tr>
</thead>
<tbody>
<tr>
<td>appId</td>
<td>String</td>
<td>是</td>
<td>服务商分配的唯一标识</td>
</tr>
<tr>
<td>timestamp</td>
<td>Long</td>
<td>是</td>
<td>当前时间戳</td>
</tr>
<tr>
<td>sign</td>
<td>String</td>
<td>是</td>
<td>签名,详见签名算法说明</td>
</tr>
<tr>
<td>area</td>
<td>String</td>
<td>否</td>
<td>地名,详见地名说明</td>
</tr>
<tr>
<td>areaId</td>
<td>String</td>
<td>否</td>
<td>地名Id,详见地名说明</td>
</tr>
</tbody>
</table>
<h3>地名说明</h3>
<ul>
<li>area和areaId必须传入一个,同时传入,以areaId为准</li>
<li>地名不能带有“市”、“县”,比如查杭州,area传入“杭州”,而不是传入“杭州市”</li>
<li><a href="https://file.jumdata.com/support/weather/weather-area.xlsx" title="支持的地名">支持的地名</a></li>
</ul>
<h3>签名算法说明</h3>
<p><code>sign = sha256(appId  + appSecret + timestamp)</code></p>
<p>用服务商分配的 appId、服务商分配的 appSecret,当前时间时间戳  timestamp,按上述顺序拼接成字符串,再进行 sha256 哈希得到。如下:</p>
<pre><code class="language-java">String appId = "xyzxy2121zxyz";
String timestamp = "1555378976238";
String appSecret = "efcefcef1121cefcefc1212121";
String str = appId  + appSecret + timestamp;
String sign = sha256(str);</code></pre>
<h3>成功返回样例</h3>
<pre><code class="language-json">{
  "code": 200, // 详见code返回码说明
  "msg": "成功", // code 对应的描述
  "charge": true, // 计费标志
  "taskNo": "30853523396532582768",  // 本次请求号
  "data": {
    "area": "北京", // 地名 详见 地名说明
    "areaId": "101010100", // 地名id 详见 地名说明
    "province": "北京", // 省份
    "city": "北京", // 城市
    "hourWeathers": [ // 24 小时天气, 共24个元素,按时间从早到晚排序
      {
        "time": "202111160800", // 时间
        "weather": "阴", // 天气
        "weather_code": "02",  // 天气编号,详见天气编号
        "temperature": "13", // 温度
        "wind_direction": "东风", // 风向
        "wind_power": "0-3级" // 风级
      },
      {
        "time": "202111160900",
        "temperature": "14",
        "weather": "阴",
        "wind_direction": "东风",
        "weather_code": "02",
        "wind_power": "0-3级"
      },
      {
        "temperature": "15",
        "weather": "阴",
        "wind_direction": "东风",
        "time": "202111161000",
        "weather_code": "02",
        "wind_power": "0-3级"
      },
      ...
    ]
  }
}</code></pre>
<p><a href="https://file.jumdata.com/support/weather/weather-code.xlsx" title="天气编号">天气编号</a></p>
<h3>失败返回样例</h3>
<pre><code class="language-json">{
    "msg": "地名不能为空",
    "code": 400
}</code></pre>
<h3>返回字段说明</h3>
<table>
<thead>
<tr>
<th>字段名</th>
<th><div style="width:400px">说明</div></th>
</tr>
</thead>
<tbody>
<tr>
<td>code</td>
<td>返回码,详见返回码说明</td>
</tr>
<tr>
<td>msg</td>
<td>code对应的描述</td>
</tr>
<tr>
<td>charge</td>
<td>计费标志</td>
</tr>
<tr>
<td>taskNo</td>
<td>本次请求号</td>
</tr>
<tr>
<td>data</td>
<td>返回具体结果,详见成功返回样例</td>
</tr>
</tbody>
</table>
<h3>code返回码说明</h3>
<table>
<thead>
<tr>
<th>code</th>
<th><div style="width:400px">说明</div></th>
</tr>
</thead>
<tbody>
<tr>
<td>200</td>
<td>成功(计费)</td>
</tr>
<tr>
<td>400</td>
<td>参数错误</td>
</tr>
<tr>
<td>404</td>
<td>请求地址不正确</td>
</tr>
<tr>
<td>500</td>
<td>服务商维护,请稍候再试</td>
</tr>
<tr>
<td>601</td>
<td>接口未开通</td>
</tr>
<tr>
<td>602</td>
<td>账号停用</td>
</tr>
<tr>
<td>603</td>
<td>余额不足请充值</td>
</tr>
<tr>
<td>604</td>
<td>接口停用</td>
</tr>
<tr>
<td>606</td>
<td>调用超限,请稍候再试</td>
</tr>
<tr>
<td>607</td>
<td>ip不在白名单</td>
</tr>
<tr>
<td>609</td>
<td>请求过于频繁,请稍候再试</td>
</tr>
<tr>
<td>610</td>
<td>请求超时</td>
</tr>
<tr>
<td>701</td>
<td>无数据</td>
</tr>
<tr>
<td>702</td>
<td>未找到该地区</td>
</tr>
<tr>
<td>999</td>
<td>其他,以实际返回为准</td>
</tr>
</tbody>
</table>