Copyscape

Copyscape Premium API

The Copyscape Premium API allows you to seamlessly integrate Copyscape Premium into your internal systems. Using the API, you can automatically check the originality of new content — whether human or AI generated — as it enters your workflow, or perform large-scale checks for plagiarism of offline content.

For WordPress users, the Copyscape Premium Wordpress plugin allows you to use your API credentials to seamlessly integrate Copyscape Premium into your WordPress workflow. If you have created a Private Index, the API also lets you add content to your private index or check new content against it.

From a technical perspective, the API (Application Programming Interface) allows your developers to write scripts on your server that query the Copyscape Premium service and receive results in common formats including JSON, XML or HTML.

The API costs the same as the web interface. Each search costs 3c for the first 200 words, plus 1c per additional 100 words or part thereof.

To use the Copyscape Premium API, please sign up for Copyscape Premium.

Using the API

To begin using the Copyscape Premium API, you may write a simple script in a server-side language such as PHP, Java or ASP that runs on your server and queries the API. The API cannot be accessed by Javascript/Ajax running within a web page, since web browsers do not allow cross-domain Ajax requests.

The following sections provide the information you need to use the Copyscape Premium API:


Sample Code - Some examples which demonstrate how to use the API.


Initial Checks and Full Comparisons - Explains the two levels of checks available via the API.

URL Search Request - Explains how to check for copies of a web page via the API.

Text Search Request - Explains how to check for copies of some text via the API.

JSON/XML Search Response - Describes JSON and XML responses that you receive from API search requests.

HTML Search Response - Describes HTML responses that you receive from API search requests.


URL Add to Private Index Request - Explains how to add the content from a URL to your private index.

Text Add to Private Index Request - Explains how to add some text to your private index.

Add to Private Index Response - Describes responses from API requests that add to your private index.

Delete from Private Index Request and Response - Explains how to delete content from your private index.


Check Balance Request and Response - Describes how to check your account balance.

Sample Code

Click to download sample code for accessing the Copyscape Premium API in PHP, Python, Ruby, Java, Perl, Coldfusion or these flavors of ASP.NET: C#, Visual Basic, C# (Razor syntax), VB (Razor syntax).

Initial Checks and Full Comparisons

Copyscape can check for matching content in two ways: an Initial Check or a Full Comparison.

Initial Check - For users who prioritize speed, the Initial Check is a fast and efficient way to search for matching content based on content indexes. The Initial Check returns an indicative text "snippet" containing a short selection of matching text from each found page. The length of this snippet, given in the minwordsmatched field of the JSON/XML search response, provides an indication of which of the found pages contain the largest quantities of matching text. However, the Initial Check does not provide an exact number of matching words for each found page.

Full Comparison - For users who don't mind longer search times, the Copyscape API can also perform an additional, more thorough check called a Full Comparison. In a Full Comparison, Copyscape attempts to fetch the complete text of a page found in the Initial Check, and compares it against the text that was submitted. For example, a Full Comparison is performed every time you click on a Copyscape result in the web interface. To perform Full Comparisons through the API, set the c parameter in the API search requests below to a value between 1 and 10. This controls the maximum number of Full Comparisons to perform, prioritizing the results with the longest snippet lengths from the Initial Check. If a Full Comparison is successfully performed for a page, additional fields such as wordsmatched are included in the JSON/XML search response for that page. Note that a Full Comparison may fail if the found page is no longer available, or uses a non-HTML format that Copyscape is not able to read.

URL Search Request

To check for copies of a web page via the Copyscape API, send an HTTP GET request to either of these URLs:

http://www.copyscape.com/api/
https://www.copyscape.com/api/

Parameters are specified on the URL (using ? and &) as follows:

Parameter Explanation Value Required? Default
u Your username [your username] Yes -
k Your API key [your API key] Yes -
o API operation csearch (or psearch or cpsearch
if you create a private index)
Yes -
q Source URL [urlencoded URL] Yes -
c Full comparisons 0 to 10 No 0
f Response format json or xml or html No xml
i Ignore sites [comma-delimited domains to ignore] No -
l Spend limit [value in dollars, e.g. 0.50] No -
x Example test 1 or omitted No -

API operation (o): Use csearch to search against the public Internet or psearch to search against your private index. You can also use cpsearch to search against both the Internet and your private index, for the cost of two searches.

Source URL (q): As per the HTTP specification, this must be urlencoded. For example, ? should be replaced by %3F and & replaced by %26. Most languages provide a built-in function for urlencoding - see examples in PHP, Java and ASP.

Full comparisons (c): Set to a value between 1 and 10 to request a full comparison (with an exact count of matching words) between the query text and the top (one to ten) results found. Note that full comparisons may add a delay of a few seconds – more info.

Ignore sites (i): Subdomains are also omitted from the results. For example, if set to site1.com,site2.com then www.site1.com and blog.site2.com would also be ignored. Ignore sites listed in your user settings are always applied.

Spend limit (i): If this parameter is omitted, the limit per search set in your User Settings is applied.

Example test (x): If set to 1, the API will search the Internet for copies of http://www.copyscape.com/example.html and you will not be charged.

Text Search Request

To check for copies of some text via the Copyscape API, send an HTTP POST request to either of these URLs:

http://www.copyscape.com/api/
https://www.copyscape.com/api/

The text to be searched and other parameters can be specified in one of two ways:

The parameters are as follows:

Parameter Explanation Value Required? Default
u Your username [your username] Yes -
k Your API key [your API key] Yes -
o API operation csearch (or psearch or cpsearch
if you create a private index)
Yes -
e Text encoding [encoding name] Yes -
t Text to be searched [the text] Yes -
c Full comparisons 0 to 10 No 0
f Response format json or xml or html No xml
i Ignore sites [comma-delimited domains to ignore] No -
l Spend limit [value in dollars, e.g. 0.50] No -
x Example test 1 or omitted No -

API operation (o): Use csearch to search against the public Internet or psearch to search against your private index. You can also use cpsearch to search against both the Internet and your private index, for the cost of two searches.

Text encoding (e): Use an IANA name, such as UTF-8 (Unicode), ISO-8859-1 (Latin-1) or WINDOWS-1251 (Cyrillic).

Text to be searched (t): If you are using the Raw POST method, as described above, the raw text should be supplied in the POST payload without a parameter name and without any urlencoding.

Full comparisons (c): Set to a value between 1 and 10 to request a full comparison (with an exact count of matching words) between the query text and the top (one to ten) results found. Note that full comparisons may add a delay of a few seconds – more info.

Ignore sites (i): Subdomains are also omitted from the results. For example, if set to site1.com,site2.com then www.site1.com and blog.site2.com would also be ignored. Ignore sites listed in your user settings are always applied.

Spend limit (i): If this parameter is omitted, the limit per search set in your User Settings is applied.

Example test (x): If set to 1, the API will search the Internet for copies of the text on http://www.copyscape.com/example.html and you will not be charged.

JSON/XML Search Response

For searches with JSON responses, the API returns a JSON object with the fields listed below. For searches with XML responses, the API returns a <response> XML element with the subelements listed below, UTF-8 encoded.

Name Explanation Present? Example
query URL searched If a URL search http://mydomain.com/ page.html
error Reason for API request failure If request failed No credits remaining
querywords Number of words checked If succeeded 583
cost Cost in dollars of this search If succeeded 0.09
count Number of results found If succeeded 6
allwordsmatched Number of source words matched If succeeded and c>=3
and o is not cpsearch
387
allpercentmatched Percentage of source words matched If succeeded and c>=3
and o is not cpsearch
56
alltextmatched Full extract of source text matched If succeeded and c>=3
and o is not cpsearch
When in the Course of human events...
allviewurl URL for viewing found results If succeeded and
o is csearch
http://view.copyscape.com/ search/a1b2c3d4e5

The query value may differ from the original URL you supplied if there was a frameset or redirection.

The allwordsmatched, allpercentmatched and alltextmatched values are based on full comparisons performed between the source text and the top (up to 10) results found. They summarize the portion of the source text that was matched in any of these full comparisons – more info. They are present if the c parameter is 3 or more, and the search was not performed against both the Internet and your private index simultaneously.

The allviewurl value can be used to display the list of results in an iframe or window. If used, the contents of this page must be displayed in full, without modification. Please note that these links are temporary, and are valid for no longer than a few weeks, after which they expire.


For successful searches with JSON responses, the top-level object contains a result array of zero or more objects, each describing one result that was found. For successful searches with XML responses, the top-level <response> element contains zero or more <result> subelements, each describing one result that was found. In either case, each result has the fields below:

Name Explanation Present? Example
index Position in results Yes 1
url URL of found page or source URL of page in private index Yes http://www.law.indiana.edu/ uslawdocs/declaration.html
handle Handle of found article If private index SIA_1_4487334_3978624
id ID of found article If private index MY_ARTICLE_123
articlewords Number of words in found article If private index 639
added When the found article was added (GMT) If private index 2025-01-18 01:27:00
title Title of the found web page or article in your private index Yes Declaration of Independence
textsnippet Text snippet showing some of the matching text Yes ... separate and equal station to which ...
htmlsnippet HTML version of snippet for display in web pages Yes <font color="#777777">...</font> <font color="#000000">separate and equal station</font>
minwordsmatched Minimum number of words matching Yes 96
viewurl URL for viewing found page If Internet result http://view.copyscape.com/ compare/a1b2c3d4e5/1

The minwordsmatched value is an approximate and relative measure of the amount of matching content found for each result. For an exact count of matching words in the top results, use the c API parameter to request full comparisons – more info.

The viewurl value can be used to display the found page, with the matching content highlighted, in an iframe or window. If used, the contents of this page must be displayed in full, without modification.


If a full comparison was performed for a result, it may also contain:

Name Explanation Present? Example
urlwords Number of words in found page If Internet page retrieved OK 950
wordsmatched Exact number of words matching If page retrieved OK 133
percentmatched Percentage of submitted content matched on page If page retrieved OK 13
textmatched Matching text in full If page retrieved OK When in the Course of human events...
urlerror Error retrieving URL If Internet page not retrieved The document could not be retrieved - error code 404

Please note that additional fields may be added in future, so your JSON or XML parser must safely ignore any that are not recognized.

HTML Search Response

For HTML responses, the API returns UTF-8 encoded content with minimal HTML formatting.

If the search request succeeded, the title of the HTML page contains the URL queried (if appropriate) and the number of results found. The body of the page includes a series of paragraphs, one for each result, for example:

Declaration of Independence : Indiana Law
... for opposing with manly firmness his invasions on the rights of the people. ... For transporting us beyond Seas to be tried for pretended offences: ... He has plundered our seas, ravaged our Coasts, burnt our towns, and destroyed the ... He has excited domestic insurrections amongst us, and has endeavoured to bring on ... the merciless Indian Savages, whose known rule of warfare, ... by their legislature to extend an unwarrantable jurisdiction over us. ... which, would inevitably interrupt our connections and correspondence. ... by the Authority of the good People of these Colonies, solemnly publish and declare, ...
http://www.law.indiana.edu/uslawdocs/declaration.html

If the API request failed, the HTML response will contain some red text describing the error.

The HTML format may change in the future, so you should not rely on its structure. The HTML also contains less information than the JSON and XML formats, and excludes full comparisons. To show more information or ensure consistent formatting, please use the JSON or XML response format and build your own HTML based on the information in the JSON or XML responses.

URL Add to Private Index Request

This API operation requires a private index to be created for your account.

To add the content from a URL to your private index, send an HTTP GET request to either of these URLs:

http://www.copyscape.com/api/
https://www.copyscape.com/api/

Parameters are specified on the URL (using ? and &) as follows:

Parameter Explanation Value Required? Default
u Your username [your username] Yes -
k Your API key [your API key] Yes -
o API operation pindexadd Yes -
q Source URL [urlencoded URL] Yes -
i Article ID [ID for private index] No [none]
f Response format json or xml or html No xml

Source URL (q) and Article ID (i): These parameters must be urlencoded. For example, ? should be replaced by %3F, & by %26 and space by + or %20. Most languages provide a built-in function for urlencoding - see examples in PHP, Java and ASP.

The title of the article in your private index is taken from the web page at the URL provided. The request returns a response confirming if the operation was successful.

Text Add to Private Index Request

This API operation requires a private index to be created for your account.

To add some text to your private index, send an HTTP POST request to either of these URLs:

http://www.copyscape.com/api/
https://www.copyscape.com/api/

The text to be added and other parameters can be specified in one of two ways:

The parameters are as follows:

Parameter Explanation Value Required? Default
u Your username [your username] Yes -
k Your API key [your API key] Yes -
o API operation pindexadd Yes -
e Text encoding [encoding name] Yes -
t Text to be added [the text] Yes -
a Article title [title for private index] No [none]
i Article ID [ID for private index] No [none]
f Response format json or xml or html No xml

Text encoding (e): Use an IANA name, such as UTF-8 (Unicode), ISO-8859-1 (Latin-1) or WINDOWS-1251 (Cyrillic).

Text to be added (t): If you are using the Raw POST method, as described above, the raw text should be supplied in the POST payload without a parameter name and without any urlencoding.

The request returns a response confirming if the operation was successful.

Add to Private Index Response

For JSON responses, the API returns a JSON object with the fields listed below. For XML responses, the API returns a <response> XML element with the subelements listed below, UTF-8 encoded.

Name Explanation Present? Example
url URL whose content was added If succeeded and URL specified http://mydomain.com/ page.html
words Number of words in content added If succeeded 472
handle Reference for article created If succeeded SIA_1_4487334_3978624
id Article ID from API request If succeeded and ID provided Article 123
title Title of article added If succeeded and title available Declaration of Independence
cost Cost of operation in dollars If succeeded 0.01
error Explanation of problem If failed A private index has not been created

The handle returned may contain up to 32 ASCII characters and can be used to delete the article in the future.

The title is taken from the web page, if a URL was specified. Otherwise it contains the title provided in the API request.

Please note that additional fields may be added in future, so your JSON or XML parser must safely ignore any that are not recognized.

For HTML responses, the API will return a message confirming whether the content was added successfully.

Delete from Private Index Request and Response

This API operation requires a private index to be created for your account.

To delete an item of content from your private index, send an HTTP GET request to either of these URLs:

http://www.copyscape.com/api/
https://www.copyscape.com/api/

Parameters are specified on the URL (using ? and &) as follows:

Parameter Explanation Value Required? Default
u Your username [your username] Yes -
k Your API key [your API key] Yes -
o API operation pindexdel Yes -
h Handle Handle of article Yes -
f Response format json or xml or html No xml

For JSON responses, the API returns a JSON object with the fields listed below. For XML responses, the API returns a <response> XML element with the subelements listed below, UTF-8 encoded.

Name Explanation Present? Example
handle Handle of deleted article If succeeded SIA_1_4487334_3978624
id ID of deleted article If succeeded MY_ARTICLE_123
error Explanation of problem If failed An article with this handle could not be found

For HTML responses, a textual description of the result of the request is returned as basic HTML.

There is no charge for deleting articles from your private index.

Check Balance Request and Response

To check how much credit you have remaining, send an HTTP GET request to either of these URLs:

http://www.copyscape.com/api/
https://www.copyscape.com/api/

Parameters are specified on the URL (using ? and &) as follows:

Parameter name Explanation Value Required?
u Your username [your username] Yes
k Your API key [your API key] Yes
o Name of operation balance Yes
f Response format json or xml or html No - xml by default

For JSON responses, the API returns a JSON object with the fields listed below. For XML responses, the API returns a <remaining> XML element with the subelements listed below, UTF-8 encoded.

Name Explanation Example
value Monetary value of your remaining credit in dollars 999.50
today Number of Internet searches remaining today 9990

For backwards compatibility, the response also contains a total field, but this no longer has a valid meaning. In the past, Copyscape Premium had a fixed price per search, so it was possible to know how many searches were available for a given balance. With the current per-word pricing, this is no longer possible.

For HTML responses, a textual description of your balance is returned as basic HTML.

Getting Assistance

If you have any questions or problems regarding the API, please contact us.