/
WS-hreflang-Verlinkungen (EN)

WS-hreflang-Verlinkungen (EN)

General

If you operate several subshops, then a hreflang specification is helpful for Google, e.g. to avoid duplicate content.

Example:
You have 4 subshops:

  • a German subshop (SubshopId "de")

  • a German mobile subshop (SubshopId "m-de")

  • an Austrian subshop (SubshopId "at")

  • an Austrian, mobile subshop (SubshopId "m-at")

In all 4 subshops identical products and categories are offered.

WEBSALE offers an automatic hreflang assignment for product and category pages.

The automatic assignment is done for product pages using the same product index in the subshops.

Automatic mapping is done for category pages by default using the same category index in the subshops.

However, some ERP systems manage the categories/products in different subshops with different category indexes/product indexes, even though they are the same categories/products. In this case, you need to pass an assignment list to the shop which categories/products are the same. This documentation describes the structure and import of this mapping list.

Format of the assignment list

The mapping list can be passed either in a JSON file or in a CSV file (tab-delimited), both in UTF-8 format.

Structure of the JSON file for categories

As an example we use our 4 subshops

  • de

  • m-de

  • at

  • m-at

In all 4 subshops the same categories are managed, but with different category indexes. As an example, 3 categories "Shirts", "Trousers" and "Shoes" are offered in the shop:

Subshop

Category name

Category index

Subshop

Category name

Category index

de

Shirts

111-1

m-de

Shirts

111-2

at

Shirts

111-3

m-at

Shirts

111-4

de

Trousers

222-1

m-de

Trousers

222-2

at

Trousers

222-3

m-at

Trousers

222-4

de

Shoes

333-1

m-de

Shoes

333-2

at

Shoes

333-3

m-at

Shoes

333-4

Structure of the JSON file:

{ "cat": [ { "MasterID": "M1", "maps": [ { "subshop": "de", "index": "111-1" }, { "subshop": "m-de", "index": "111-2" }, { "subshop": "at", "index": "111-3" }, { "subshop": "m-at", "index": "111-4" } ] }, { "MasterID": "M2", "maps": [ { "subshop": "de", "index": "222-1" }, { "subshop": "m-de", "index": "222-2" }, { "subshop": "at", "index": "222-3" }, { "subshop": "m-at", "index": "222-4" } ] }, { "MasterID": "M3", "maps": [ { "subshop": "de", "index": "333-1" }, { "subshop": "m-de", "index": "333-2" }, { "subshop": "at", "index": "333-3" }, { "subshop": "m-at", "index": "333-4" } ] } ] }

The MasterID must be a unique alphanumeric ID for each "maps" array element. Within a "maps" array element, the same categories are assigned in the subshops.

The name of the file is configurable in the shop. However, the ending is mandatory ".json". As default name we recommend "catalloc_complete_g1.json". Currently, only a complete import is possible.

The following hreflang links are then output on the shop category pages:

Subshop

Category name

Example link to category

Subshop

Category name

Example link to category

de

Shirts

https://www.xyz.de/Shirts

m-de

Shirts

https://m.xyz.de/Shirts

at

Shirts

https://www.xyz.at/Shirts

m-at

Shirts

https://m.xyz.at/Shirts

de

Trousers

https://www.xyz.de/Trousers

m-de

Trousers

https://m.xyz.de/Trousers

at

Trousers

https://www.xyz.at/Trousers

m-at

Trousers

https://m.xyz.at/Trousers

de

Shoes

https://www.xyz.de/Shoes

m-de

Shoes

https://m.xyz.de/Shoes

at

Shoes

https://www.xyz.at/Shoes

m-at

Shoes

https://m.xyz.at/Shoes

Subshop: de
Category: Shirts

<link rel="alternate" hreflang="de-DE" href="https://m.xyz.de/Shirts" /> <link rel="alternate" hreflang="de-AT" href="https://www.xyz.at/Shirts" /> <link rel="alternate" hreflang="de-AT" href="https://m.xyz.at/Shirts" />

Subshop: m-de
Category: Shirts

<link rel="alternate" hreflang="de-DE" href="https://www.xyz.de/Shirts" /> <link rel="alternate" hreflang="de-AT" href="https://www.xyz.at/Shirts" /> <link rel="alternate" hreflang="de-AT" href="https://m.xyz.at/Shirts" />

Subshop: at
Category: Shirts

Subshop: m-at
Category: Shirts

Subshop: de
Category: Trousers

etc.

Other import files

In the above example we have grouped 4 German language subshops in the file "catalloc_complete_g1.json". For each additional subshop group, another file must be created and imported into the shop.

Example:

In addition to the 4 German-language subshops, you have 2 English subshops that should also be grouped together in another group.

Subshop

Category name

Category index

Subshop

Category name

Category index

gb

Shirts

444-1

m-gb

Shirts

444-2

gb

Trousers

555-1

m-gb

Trousers

555-2

gb

Shoes

666-1

m-gb

Shoes

666-2

Structure of the JSON file:

The name of this file is then "catalloc_complete_g2.json".

Please note:
The MasterIDs of the 2nd file must be different from the 1st file or from all other files.

Structure of the CSV file for categories

According to our examples above, the CSV files then have the following content:

File "catalloc_complete_g1.csv":

MasterID
M1
M1
M1
M1
M2
M2
M2
M2
M3
M3
M3
M3

SubShop
de
m-de
at
m-at
de
m-de
at
m-at
de
m-de
at
m-at

CatIndex
111-1
111-2
111-3
111-4
222-1
222-2
222-3
222-4
333-1
333-2
333-3
333-4

File "catalloc_complete_g2.csv":

MasterID
M4
M4
M5
M5
M6
M6

SubShop
gb
m-gb
gb
m-gb
gb
m-gb

CatIndex
444-1
444-2
555-1
555-2
666-1
666-2

The first line contains the column headers. From the 2nd line the data follow. The columns are tab-separated.

Structure of the JSON file for products

Analogous to the mapping list for categories (see above) the mapping for products is done. The only difference is the first element of the JSON object "prod" instead of "cat".

Example:

In 2 subshops (de and at) 2 identical products with different product indexes are offered:

Structure of the CSV file for products

Analogous to the assignment list for categories (see above) the assignment for products is done. The only difference is the column header "ProdIndex" instead of "CatIndex":

MasterID
P001
P001
P002
P002

SubShop
de
at
de
at

ProdIndex
1234
4321
5678
8765

Checksum file

A checksum file must be created and transferred for each JSON or CSV file. Form a SHA512 hash value from the complete content of the JSON/CSV file and write it to the first line of the checksum file.

The extension of the checksum file is ".sha512sum".

Example:

You have 2 JSON files

  • catalloc_complete_g1.json

  • catalloc_complete_g2.json

then the checksum files are

  • catalloc_complete_g1.sha512sum

  • catalloc_complete_g2.sha512sum

Importing the files

The JSON/CSV and checksum files are transferred via SFTP. You will receive an SFTP access from WEBSALE AG for this purpose. Save the files directly in your root directory. The import is done once a day (at night) via cron job

Alternatively, the import can also be triggered via REST API. Then the files can also be transferred and imported several times a day. You can find out how to start the "hrefCollector" via REST in the REST interface for OSB services: REST hreflang-Erzeugung

© 2025 WEBSALE AG | Impressum | Datenschutz