How to Create a ViewBits API Backend for Your Website

When you visit a website, your web browser (like Chrome, Firefox, or Safari) works by downloading and running code sent from the website. This code often includes HTML, CSS, and JavaScript. These files are what make the website look and function the way it does.

Since this code runs in your browser, anyone can view it using developer tools, which are built into most browsers. Developer tools allow you to inspect the website’s code, see how it works, and even view any data being sent or received by the site.

The Problem: JavaScript Code Reveals Your API Key

If your JavaScript code includes a sensitive API key (a kind of password that lets your code access an external service), that key is visible to anyone who checks the code using developer tools. This means someone could copy your API key and use it themselves, potentially costing you money, violating terms of use, or exposing your account to misuse.

The solution is to keep your API key hidden by moving it to a backend server. Instead of including the key in the JavaScript code that runs in the browser, you set up your own backend API wrapper. A backend is like the “brain” of a website that runs on a secure server (not visible to visitors).

Your backend takes requests from your website, adds the hidden API key, forwards the request to the external service, and then sends the result back to your website. This way, the key stays on your server, where it’s safe from prying eyes.

The Solution: Move API Keys to a Backend Server

The most secure way to handle sensitive information like API keys is to never expose it on the client side. In this example we will be creating a simple API wrapper using PHP that will take your website API requests and append your key on the backend to prevent hijacking.

This works because the frontend sends requests to your backend server, which forwards the requests to the ViewBits API using the stored key. Your backend returns the data to the frontend, and the API key remains hidden on the server.

Using the example script below, you can add your API key and make calls to ViewBits using https://yourwebsite.tld/api.viewbits.php instead of using https://api.viewbits.com directly.

Important: When using a wrapper, the data to retrieve is specified using the “dataset” tag rather than slashes in the URL. The version is also not required as this is specified on the backend.

For example:

https://yourwebsite.com/api.viewbits.php?dataset=headlines&c=tech

would take the place of

https://api.viewbits.com/v1/headlines/?c=tech

You can use the example code below to create an ViewBits API wrapper for your website. Simply copy the example to a new file on your server named api.viewbits.php and make your calls to the wrapper.

Example Code:

Backend (PHP)

<?php

// api.viewbits.php

header("Content-Type: application/json");

// Security Checks - See Additional Code in Guide
// Place Your Security Checks Here

// Your API key
$apiKey = 'YOUR_API_KEY';

// Base URL of the API
$apiBaseUrl = 'https://api.viewbits.com/v1/';

// Collect all user-provided GET parameters
$queryParams = $_GET;

// Add supplied API key to the query parameters
$queryParams['key'] = $apiKey;

// Build the query string for the API
$queryString = http_build_query($queryParams);

// Final API URL with the API key and user-provided parameters
$apiUrl = $apiBaseUrl . '?' . $queryString;

// Initialize a cURL session
$ch = curl_init();

// Set cURL options
curl_setopt($ch, CURLOPT_URL, $apiUrl);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
"Content-Type: application/json"
));

// Execute the request
$response = curl_exec($ch);

// Check for errors
if ($response === false) {
$error = curl_error($ch);
http_response_code(500);
echo json_encode(array("error" => "Request failed: $error"));
curl_close($ch);
exit;
}

// Close the cURL session
curl_close($ch);

// Return the response from the API
echo $response;

?>

Frontend (Javascript)

<script type="text/javascript">
const apiUrl = 'https://yourwebsite.com/api.viewbits.php?dataset=headlines';

async function fetchData() {
try {
const response = await fetch(apiUrl, { method: 'POST' });

const data = await response.json();
console.log(data); // Log the fetched data
} catch (error) {
console.error('Error:', error); // Handle errors
}
}

fetchData(); // Call the function to send the request
</script>

Now you can make JavaScript calls to ViewBits without revealing your API key on the front end!

Adding Security

To prevent unauthorized access to our API wrapper we can add a few additional checks. Place these items at the beginning of your file, under the line that contains header(“Content-Type: application/json”);

1. Access-Control-Allow-Origin Headers: This will prevent client-side JavaScript running in the browser from calling your wrapper. It doesn’t affect server-side requests like cURL, as these don’t enforce CORS policies.

PHP

// Replace with your domain
$allowedOrigin = 'https://www.yourdomain.com';

// Set the Origin Control header
header("Access-Control-Allow-Origin: ".$allowedOrigin);

2. Require POST Method: This will prevent direct access via web browser requests, which use GET by default.

PHP

// Prevent Direct Access to Wrapper, Use Post in Js
if ($_SERVER['REQUEST_METHOD'] !== 'POST') {
echo "No direct access allowed!";
exit;
}

3. Check Server Origin: In PHP, we can use $_SERVER[‘HTTP_ORIGIN’] to get the value of the origin header. This well help prevent unauthorized server-to-server POST requests.

PHP

// Check if the HTTP_ORIGIN header is set
if (isset($_SERVER['HTTP_ORIGIN'])) {
// Get the value of the Origin header
$origin = $_SERVER['HTTP_ORIGIN'];

// Compare the origin with the allowed origin
if ($origin !== $allowedOrigin) {
// If the origin doesn't match, block the request
header('HTTP/1.1 403 Forbidden');
echo $_SERVER['HTTP_ORIGIN'];
exit;
}
}
else {
// If the origin is not set, block the request
header('HTTP/1.1 403 Forbidden');
echo 'No origin';
exit;
}