This project is a package for developers to validate backlinks in SEO. Unlike other tools that scan the Internet or analyze Google Search results to find backlinks, our tool focuses exclusively on verifying backlinks from a list you already have.
You might get this list of backlinks through:
- Purchasing backlinks: Receiving a list of donor web pages from the seller or backlinks market.
- Creating backlinks yourself: Posting on forums, third-party websites, or other platforms.
- SEO service providers: your SEO expert or company shares a reports with backlinks as one of the SEO strategies.
Once you have a list of donor web pages, it's crucial to confirm that the backlinks are present and functional. Moreover, ongoing validation is necessary to ensure the backlinks remain active and haven’t been removed over time.
This package simplifies backlink checking and verification by:
- Verifying the presence of fixed backlinks, such as
https://example.com
. - Supporting powerful search patterns, like
*.example.com
, using regular expressions defined by you.
With this package, monitoring and maintaining your backlinks becomes efficient and hassle-free.
Pros:
- Fast: Simple mode is faster.
- Low resource consumption: Simple mode uses fewer resources.
- Minimal dependencies: Simple mode requires fewer dependencies.
- Shared hosting: Simple mode works on shared hosting.
Cons:
- No JavaScript: Simple mode does not support JavaScript, so it works only for simple or static HTML, for example, generated by Joomla, WordPress or Drupal. It will not find backlinks on websites that require JavaScript-enabled browser, for example, websites made with Laravel, Yii, React, etc.
The Chromium headless mode is used for JavaScript-enabled browsing. This approach allows parsing any website, and this is the universal mode, but it uses more resources on the server and requires a little bit more time to configure the server.
Pros:
- Universal: Chromium mode supports JavaScript, so it can parse any website.
Cons:
- Slower: Chromium mode is slower.
- Higher resource consumption: Chromium mode uses more resources.
- Advanced hosting plan: requires a VPS or dedicated server, does not work on shared hosting.
You must have a Composer installed. Run the following command:
php composer require rvalitov/backlink-checker-php
- Versions starting from 3.0.0 support PHP 8.0 and later.
- If you need to use an earlier version of PHP, please use the 1.x.x or 2.x.x releases.
Note: You can skip this step if you don't need the Chromium mode.
You need to install the following packages first, to make the Chromium work.
For Debian/Ubuntu:
apt-get update
apt-get install gconf-service libasound2 libatk1.0-0 libc6 libcairo2 libcups2 libdbus-1-3 libexpat1 libfontconfig1 libgcc1 libgconf-2-4 libgdk-pixbuf2.0-0 libglib2.0-0 libgtk-3-0 libnspr4 libpango-1.0-0 libpangocairo-1.0-0 libstdc++6 libx11-6 libx11-xcb1 libxcb1 libxcomposite1 libxcursor1 libxdamage1 libxext6 libxfixes3 libxi6 libxrandr2 libxrender1 libxss1 libxtst6 ca-certificates fonts-liberation libappindicator1 libnss3 lsb-release xdg-utils wget
You must have a Node.js installed. If it's not installed, install it using the official manual. Then run the following command to install the Chromium:
npm install
Include the autoload.php
in your source PHP file, for example:
<?php
require __DIR__ . '/vendor/autoload.php';
First, include the dependencies:
<?php
require __DIR__ . "/vendor/autoload.php";
use Valitov\BacklinkChecker;
Then decide which mode to use, for Chromium mode use:
$checker = new BacklinkChecker\ChromeBacklinkChecker();
Or if you want a simple mode without JavaScript support use:
$checker = new BacklinkChecker\SimpleBacklinkChecker();
Make a scan of the desired URL with a desired pattern (use the PCRE pattern syntax):
$url = "https://example.com";
$pattern = "@https?://(www\.)?website\.com.*@";
$scanBacklinks = true;
$scanHotlinks = false;
$makeScreenshot = true;
try {
$result = $checker->getBacklinks($url, $pattern, $scanBacklinks, $scanHotlinks, $makeScreenshot);
} catch (\Exception $e) {
die("Error: " . $e->getMessage());
}
The function getBacklinks
has the following additional options:
$scanBacklinks
- if set totrue
, then it scans for the backlinks (the text of thehref
attribute of<a>
tag); otherwise scanning is not performed.$scanHotlinks
- if set totrue
, then it scans for the hotlink (the text of thesrc
attribute of<img>
tag); otherwise scanning is not performed.$makeScreenshot
- if set totrue
, then we also take a screenshot of the viewport; otherwise screenshot is not made. This option makes sense only for Chromium mode (default viewport size is800 x 600
px, image format:JPEG
, image quality:90
, image encoding:binary
); for simple mode this option is ignored.
Now we should check the $result
, if the function succeeded:
$response = $result->getResponse();
if ($response->isSuccess()) {
$links = $result->getBacklinks();
if (sizeof($links) > 0)
//Backlinks found
else {
//No backlinks found
}
} else {
//Error, usually network error, or server error
die("Error, HTTP Code " . $response->getStatusCode());
}
The function $result->getBacklinks()
returns an array of objects that describe the backlink. Each object supports the
following functions:
getBacklink
returnsstring
, a backlink - an exact URL that matches the target domain;getTag
returnsstring
, the tag that is used for the backlink, can bea
orimg
;getTarget
returnsstring
, contents oftarget
attribute of thehref
;getNoFollow
returnstrue
if the backlink hasnofollow
attribute;getAnchor
returnsstring
- anchor of the link, for example, inner text of<a>
tag. This text is returned in a plain text format, all HTML tags are stripped.
The $response
object supports the following functions:
getUrl
returnsstring
, the URL of that was analyzedgetStatusCode
returnsint
, the HTTP status code, or0
or-1
if there was a network error.getScreenshot
returnsstring
, the screenshot in binary format. If the screenshot was not taken or is not available, then the string is empty. If you want to display this screenshot as an image on a web page, then you should first save it to disk and use a link to it, or encode it into base64 and insert into the web page directly. In this case, you can use a function like:
$base64_image = "data:image/jpeg;base64," . base64_encode($response->getScreenshot());
Note. If you use function json_encode
on an object that
contains the screenshot, then this screenshot will be converted
to base64 format automatically.
Examples are available in a dedicated project on GitHub.
Tests are in tests
folder.
PHP 8.0.7+ required with the following extensions: