 Sunrise Sunset
Sunrise Sunset
Sunrise Sunset is a simple tool for getting the sunrise and sunset times. It returns the sunrise and sunset times for a given location and date.
This API provides reliable and fast access to sunrise sunset data through a simple REST interface. Built for developers who need consistent, high-quality results with minimal setup time.
To use this API, you need an API key. You can get one by creating a free account and visiting your dashboard.
View API in DirectoryEndpoint
GET https://api.apiverve.com/v1/sunrisesunsetCode Examples
Here are examples of how to call this API in different programming languages:
curl -X GET \
  "https://api.apiverve.com/v1/sunrisesunset?lat=36.7201600&lon=-4.4203400&date=10-22-2025" \
  -H "X-API-Key: your_api_key_here"const response = await fetch('https://api.apiverve.com/v1/sunrisesunset', {
  method: 'GET',
  headers: {
    'X-API-Key': 'your_api_key_here',
    'Content-Type': 'application/json'
  }
});
const data = await response.json();
console.log(data);import requests
headers = {
    'X-API-Key': 'your_api_key_here',
    'Content-Type': 'application/json'
}
response = requests.get('https://api.apiverve.com/v1/sunrisesunset', headers=headers)
data = response.json()
print(data)const https = require('https');
const url = require('url');
const options = {
  method: 'GET',
  headers: {
    'X-API-Key': 'your_api_key_here',
    'Content-Type': 'application/json'
  }
};
const req = https.request('https://api.apiverve.com/v1/sunrisesunset', options, (res) => {
  let data = '';
  res.on('data', (chunk) => data += chunk);
  res.on('end', () => console.log(JSON.parse(data)));
});
req.end();<?php
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.apiverve.com/v1/sunrisesunset');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'GET');
curl_setopt($ch, CURLOPT_HTTPHEADER, [
    'X-API-Key: your_api_key_here',
    'Content-Type: application/json'
]);
$response = curl_exec($ch);
curl_close($ch);
$data = json_decode($response, true);
print_r($data);
?>package main
import (
    "fmt"
    "io"
    "net/http"
)
func main() {
    req, _ := http.NewRequest("GET", "https://api.apiverve.com/v1/sunrisesunset", nil)
    req.Header.Set("X-API-Key", "your_api_key_here")
    req.Header.Set("Content-Type", "application/json")
    client := &http.Client{}
    resp, err := client.Do(req)
    if err != nil {
        panic(err)
    }
    defer resp.Body.Close()
    body, _ := io.ReadAll(resp.Body)
    fmt.Println(string(body))
}require 'net/http'
require 'json'
uri = URI('https://api.apiverve.com/v1/sunrisesunset')
http = Net::HTTP.new(uri.host, uri.port)
http.use_ssl = true
request = Net::HTTP::Get.new(uri)
request['X-API-Key'] = 'your_api_key_here'
request['Content-Type'] = 'application/json'
response = http.request(request)
puts JSON.pretty_generate(JSON.parse(response.body))Authentication
This API requires authentication via API key. Include your API key in the request header:
X-API-Key: your_api_key_hereParameters
The following parameters are available for this API endpoint:
| Parameter | Type | Required | Location | Description | Example | 
|---|---|---|---|---|---|
| lat | number | Yes | query | The latitude of the location for which you want to get the sunrise and sunset times (e.g., 36.7201600) | 36.7201600 | 
| lon | number | Yes | query | The longitude of the location for which you want to get the sunrise and sunset times (e.g., -4.4203400) | -4.4203400 | 
| date | string | No | query | The date for which you want to get the sunrise and sunset times (e.g., MM-DD-YYYY : 01-01-2022) | 10-22-2025 | 
Response
The API returns responses in JSON, XML, and YAML formats:
Example Responses
{
  "status": "ok",
  "error": null,
  "data": {
    "solarNoon": "2025-02-20T12:32:53.132Z",
    "sunrise": "2025-02-20T07:01:34.082Z",
    "sunset": "2025-02-20T18:04:12.182Z",
    "sunriseEnd": "2025-02-20T07:04:17.987Z",
    "sunsetStart": "2025-02-20T18:01:28.278Z",
    "dawn": "2025-02-20T06:35:17.568Z",
    "dusk": "2025-02-20T18:30:28.696Z",
    "nauticalDawn": "2025-02-20T06:05:07.51Z",
    "nauticalDusk": "2025-02-20T19:00:38.754Z",
    "nightEnd": "2025-02-20T05:35:08.859Z",
    "night": "2025-02-20T19:30:37.405Z",
    "goldenHourEnd": "2025-02-20T07:36:59.509Z",
    "goldenHour": "2025-02-20T17:28:46.756Z"
  }
}<Root>
  <status>ok</status>
  <error />
  <data>
    <solarNoon>2025-02-20T12:32:53.132Z</solarNoon>
    <sunrise>2025-02-20T07:01:34.082Z</sunrise>
    <sunset>2025-02-20T18:04:12.182Z</sunset>
    <sunriseEnd>2025-02-20T07:04:17.987Z</sunriseEnd>
    <sunsetStart>2025-02-20T18:01:28.278Z</sunsetStart>
    <dawn>2025-02-20T06:35:17.568Z</dawn>
    <dusk>2025-02-20T18:30:28.696Z</dusk>
    <nauticalDawn>2025-02-20T06:05:07.51Z</nauticalDawn>
    <nauticalDusk>2025-02-20T19:00:38.754Z</nauticalDusk>
    <nightEnd>2025-02-20T05:35:08.859Z</nightEnd>
    <night>2025-02-20T19:30:37.405Z</night>
    <goldenHourEnd>2025-02-20T07:36:59.509Z</goldenHourEnd>
    <goldenHour>2025-02-20T17:28:46.756Z</goldenHour>
  </data>
</Root>status: ok
error: 
data:
  solarNoon: 2025-02-20T12:32:53.1320000Z
  sunrise: 2025-02-20T07:01:34.0820000Z
  sunset: 2025-02-20T18:04:12.1820000Z
  sunriseEnd: 2025-02-20T07:04:17.9870000Z
  sunsetStart: 2025-02-20T18:01:28.2780000Z
  dawn: 2025-02-20T06:35:17.5680000Z
  dusk: 2025-02-20T18:30:28.6960000Z
  nauticalDawn: 2025-02-20T06:05:07.5100000Z
  nauticalDusk: 2025-02-20T19:00:38.7540000Z
  nightEnd: 2025-02-20T05:35:08.8590000Z
  night: 2025-02-20T19:30:37.4050000Z
  goldenHourEnd: 2025-02-20T07:36:59.5090000Z
  goldenHour: 2025-02-20T17:28:46.7560000ZResponse Structure
All API responses follow a consistent structure with the following fields:
| Field | Type | Description | Example | 
|---|---|---|---|
| status | string | Indicates whether the request was successful ("ok") or failed ("error") | ok | 
| error | string | null | Contains error message if status is "error", otherwise null | null | 
| data | object | null | Contains the API response data if successful, otherwise null | {...} | 
Response Data Fields
When the request is successful, the data object contains the following fields:
| Field | Type | Sample Value | 
|---|---|---|
| solarNoon | string | "2025-02-20T12:32:53.132Z" | 
| sunrise | string | "2025-02-20T07:01:34.082Z" | 
| sunset | string | "2025-02-20T18:04:12.182Z" | 
| sunriseEnd | string | "2025-02-20T07:04:17.987Z" | 
| sunsetStart | string | "2025-02-20T18:01:28.278Z" | 
| dawn | string | "2025-02-20T06:35:17.568Z" | 
| dusk | string | "2025-02-20T18:30:28.696Z" | 
| nauticalDawn | string | "2025-02-20T06:05:07.51Z" | 
| nauticalDusk | string | "2025-02-20T19:00:38.754Z" | 
| nightEnd | string | "2025-02-20T05:35:08.859Z" | 
| night | string | "2025-02-20T19:30:37.405Z" | 
| goldenHourEnd | string | "2025-02-20T07:36:59.509Z" | 
| goldenHour | string | "2025-02-20T17:28:46.756Z" | 
Headers
Required and optional headers for API requests:
| Header Name | Required | Example Value | Description | 
|---|---|---|---|
| X-API-Key | Yes | your_api_key_here | Your APIVerve API key. Found in your dashboard under API Keys. | 
| Accept | No | application/json | Specify response format: application/json (default), application/xml, or application/yaml | 
| User-Agent | No | MyApp/1.0 | Identifies your application for analytics and debugging purposes | 
| X-Request-ID | No | req_123456789 | Custom request identifier for tracking and debugging requests | 
| Cache-Control | No | no-cache | Control caching behavior for the request and response | 
Client Libraries
To get started with minimal code, most of our APIs are available through client libraries and clients:
Error Codes
The API uses standard HTTP status codes to indicate success or failure:
| Status Code | Message | Description | 
|---|---|---|
| 200 | OK | Request successful, data returned | 
| 400 | Bad Request | Invalid request parameters or malformed request | 
| 401 | Unauthorized | Missing or invalid API key | 
| 403 | Forbidden | API key does not have permission for this endpoint | 
| 429 | Too Many Requests | Rate limit exceeded, please slow down requests | 
| 500 | Internal Server Error | Server error, please try again later | 
Was this page helpful?
Help us improve our documentation





