Pages, Articles & News
Tools & Plugins
Example / Placeholder Title


Description as an example placeholder. Sample text content for further customization of the "Index36" template.

You are free to edit and customize the template however you like. If you don’t have time or enough knowledge — you can always order template adaptation by contacting me via GitHub or private messages on the digital goods marketplace.

2026-02-09 19:21

Плагин "usercategories" и проблема с "%2F" при переключении языка интерфейса сайта
проблема Cotonti + urleditor + language selector в связке с плагином структуры категорий пользователей, специализаций и навыков.

att_964.webp

Хронология проблемы. 
файл частично public_html/.htaccess
 


################ Block spamers by IP address #######################
# https://httpd.apache.org/docs/2.4/howto/access.html

################ Cotonti Handy URLs for Apache #######################
# Below are the rules to be included in your main .htaccess file or httpd.conf
# Rewrite engine options
Options -Indexes
RewriteEngine On
RewriteBase "/"
# Language selector
RewriteRule ^(ru|en)/(.*) $2?l=$1 [QSA,NC,NE,DPI]
# .....
# users
RewriteRule ^customers/?$ index.php?e=users&group=customer [QSA,NC,NE,L]
RewriteRule ^contractors/?$ index.php?e=users&group=contractor [QSA,NC,NE,L]
RewriteRule ^customers/([a-zA-Z0-9_./%-]+)/?$ index.php?e=users&group=customer&cat=$1 [QSA,NC,NE,L]
RewriteRule ^contractors/([a-zA-Z0-9_./%-]+)/?$ index.php?e=users&group=contractor&cat=$1 [QSA,NC,NE,L]
# .....

 

дальше файл полностью 
public_html/plugins/urleditor/presets/marketplace.dat  


forums    m=posts&q=&d=    forums/{forums_url_structure()}/page{$d}
forums    m=posts&q=*    forums/{forums_url_structure()}
forums    m=posts&id=*    forums/{forums_url_structure()}
forums    m=topics&s=&d=    forums/{forums_url_structure()}/page{$d}{!$m}
forums    m=topics&s=*    forums/{forums_url_structure()}{!$m}
forums    c=*    forums/{$c}
forums    *    forums
page    m=*                        page?m={$m}
page    c=system&al=*            {$al}{!$c}
page    c=*&al=*                {cot_url_catpath()}/{$al}
page    c=*&id=*                {cot_url_catpath()}/{$id}
page    c=*                        {cot_url_catpath()}
index    *                        {$_path}
plug    e=tags&a=pages&t=*        {$e}/{$t}{!$a}
plug    e=tags&a=*&t=*            {$e}/{$a}/{$t}
plug    e=*                        {$e}
users    group=customer&cat=*            customers/{$cat}/{!$group}
users    group=contractor&cat=*            contractors/{$cat}/{!$group}
users    group=customer            customers/{!$group}
users    group=contractor            contractors/{!$group}
users    m=details&u=*            users/{cot_url_username()}
login    *                        {$_area}
message    *                        {$_area}
admin    m=*                        admin/{$m}
admin    *                        {$_area}
rss        m=*&c=*                    {$_area}/{$m}/{$c}
rss        m=*&id=*                {$_area}/{$m}/{$id}
rss        c=*                        {$_area}/{$c}
rss        m=*                        {$_area}/{$m}
*        c=*&al=*                {$_area}/{cot_url_catpath()}/{$al}
*        c=*&id=*                {$_area}/{cot_url_catpath()}/{$id}
*        c=*                        {$_area}/{cot_url_catpath()}
*        al=*                    {$_area}/{$al}
*        id=*                    {$_area}/{$id}
*        *                        {$_area}


Если мы находимся на странице https://siteoncotonti.com/ru/contractors/ (группа исполнители) мы легко можем переключиться на https://siteoncotonti.com/en/contractors/ кнопкой переключения языка интерефеса, и эти ссылки всегда корректно "подсвечиваются" при наведении на кнопки английского и русского языка сайта.
вот они в исходном коде браузера:

``` 
<div class="px-3">  
<a href="en/contractors/" class="selected mx-2"><img src="images/flags/gb.png" alt="gb"></a>  
<a href="ru/contractors/" class=" mx-2"><img src="images/flags/ru.png" alt="ru"></a>  
</div>
```

Но если зашли уже в категорию пользователей, https://siteoncotonti.com/en/contractors/websites/ то переключиться на русский не получается, где подставляется дополнительный слеш, и кнопки смены языка уже имеют вот такие ссылки в исходном коде браузера:

```
<div class="px-3">   
<a href="en/contractors/websites%2F/" class="selected mx-2"><img src="images/flags/gb.png" alt="gb"></a>  
<a href="ru/contractors/websites%2F/" class=" mx-2"><img src="images/flags/ru.png" alt="ru"></a>  
</div> 
```

вместо рабочей ссылки: https://siteoncotonti.com/ru/contractors/websites/  
нас отправляет на https://siteoncotonti.com/ru/contractors/websites%2F/  
и как результат:  

404 - Not Found
The requested object or URL was not found on this server.
The link you followed is either outdated, inaccurate, or the server has been instructed not to let you access the page.

как это исправить? проблема наблюдается именно, когда находимся внутри категорий плагина "usercategories".


Анализ и решение проблемы декодирования "%2F"

Суть проблемы (коротко и точно)

Проблема НЕ в .htaccess напрямую и НЕ в Apache.
Проблема в том, что плагин usercategories формирует cat со слешем в конце (websites/), а Cotonti при генерации ссылки переключения языка прогоняет путь через rawurlencode().

👉 / внутри параметра превращается в %2F
👉 дальше mod_rewrite НЕ декодирует %2F обратно в /
👉 итог: websites%2F/ → 404

 

Где именно ломается

На странице:

/en/contractors/websites/


внутренне формируется:

cat = "websites/"


При генерации ссылки языка получается:

en/contractors/websites%2F/


А правило:

RewriteRule ^(ru|en)/(.*) $2?l=$1


получает websites%2F/ как literal, Apache %2F не трогает → Cotonti не может сопоставить категорию → 404.

 

РЕШЕНИЕ №1 (ПРАВИЛЬНОЕ, РЕКОМЕНДУЕМОЕ)


❗ Убрать слеш из значения cat

Категория НЕ должна заканчиваться /.

Исправление в urleditor preset

Файл:

plugins/urleditor/presets/marketplace.dat

БЫЛО:

users    group=customer&cat=*            customers/{$cat}/{!$group}
users    group=contractor&cat=*            contractors/{$cat}/{!$group}

 

ДОЛЖНО БЫТЬ:

users    group=customer&cat=*            customers/{$cat}{!$group}
users    group=contractor&cat=*            contractors/{$cat}{!$group}


🔴 УБРАТЬ слеш после {$cat}

Обязательно Затем: очистить кеш Cotonti

 

This post was edited by webitproff (2026-02-09 20:50, 3 months ago)
Account