Salta al contenuto principale
Versione: 1.x

Conflitti dei Plugin

I conflitti tra plugin sono una delle cause più comuni di problemi con WCPOS. Quando altri plugin di WordPress interferiscono con la funzionalità di WooCommerce o WCPOS, potresti sperimentare crash, problemi di prestazioni o comportamenti inattesi.

Segni di Conflitti dei Plugin

Potresti avere un conflitto di plugin se riscontri:

  • Errori fatali - "Si è verificato un errore critico su questo sito web"
  • Problemi di prestazioni - Caricamento lento, timeout o carico elevato del server
  • Problemi di funzionalità - Funzionalità che non funzionano come previsto
  • Problemi di sincronizzazione dei dati - Prodotti, ordini o clienti che non si sincronizzano correttamente
  • Problemi con il gateway di pagamento - Fallimenti al checkout o errori durante l'elaborazione dei pagamenti

Prima di Iniziare: Usa un Sito di Staging

Importante

Non risolvere mai i conflitti dei plugin sul tuo sito live. Usa sempre un ambiente di staging per evitare di interrompere le operazioni commerciali.

Cos'è un Sito di Staging?

Un sito di staging è una copia esatta del tuo sito web live dove puoi testare modifiche in sicurezza senza influenzare i tuoi clienti. La maggior parte dei moderni fornitori di hosting offre ambienti di staging come funzionalità standard.

Se il Tuo Hosting Non Offre Staging

Se il tuo fornitore di hosting non offre siti di staging, prendi in considerazione di passare a un hosting che lo fa. Questa è una funzionalità standard al giorno d'oggi e fondamentale per:

  • Test sicuri di plugin/temi
  • Aggiornamenti di WordPress
  • Risoluzione dei problemi
  • Lavoro di sviluppo

Hosting consigliati con staging:

  • WP Engine
  • SiteGround
  • Kinsta
  • Cloudways
  • Molti altri

Passo 1: Controlla gli Errori Fatali

Se stai riscontrando crash o errori critici, inizia controllando i log degli errori:

  1. Controlla i log di WCPOS - Apri la schermata Logs in WCPOS per eventuali messaggi di errore
  2. Controlla i log degli errori fatali - Segui la guida alla risoluzione dei problemi degli Errori Critici per trovare messaggi di errore dettagliati
  3. Annota i dettagli dell'errore - Cerca nomi di plugin o percorsi di file menzionati nell'errore

Se trovi un errore fatale che menziona un plugin specifico, è probabile che sia quello il colpevole. Puoi disabilitare quel plugin e testare se il problema è risolto.

Passo 2: Il Metodo di Eliminazione dei Plugin

Se non ci sono errori fatali nei log, o vuoi identificare conflitti relativi alle prestazioni, usa questo approccio sistematico:

2.1 Crea una Linea di Base

  1. Accedi al tuo sito di staging
  2. Testa la funzionalità problematica - Annota esattamente cosa non funziona o è lento
  3. Registra le metriche delle prestazioni - Se si tratta di un problema di prestazioni, annota i tempi di esecuzione dai Logs

2.2 Disabilita Tutti i Plugin (Tranne Quelli Essenziali)

Mantieni attivi questi plugin:

  • WooCommerce
  • WCPOS
  • WCPOS Pro (se lo hai)

Disabilita tutto il resto:

  1. Vai a WP Admin > Plugins
  2. Seleziona tutti gli altri plugin
  3. Scegli "Disattiva" dal menu a discesa delle azioni di massa
  4. Clicca su "Applica"

2.3 Testa il Problema

  1. Pulisci eventuali cache - Se usi plugin di caching, svuota tutte le cache
  2. Testa la funzionalità problematica - Funziona ora?
  3. Controlla le prestazioni - I tempi di esecuzione sono migliorati?

Se il problema è risolto: Hai un conflitto di plugin. Procedi al Passo 2.4.

Se il problema persiste: Il problema probabilmente non è un conflitto di plugin. Considera:

  • Problemi delle risorse server (vedi Performance del Server)
  • Conflitti del tema (vedi Passo 3)
  • Problemi del core di WordPress/WooCommerce

2.4 Abilita i Plugin Uno alla Volta

Ora devi identificare quale plugin causa il conflitto:

  1. Abilita un plugin - Inizia con i più essenziali
  2. Testa la funzionalità - Controlla se il problema ritorna
  3. Se non ci sono problemi - Abilita il plugin successivo e testa di nuovo
  4. Se il problema ritorna - Hai trovato il plugin in conflitto!

Ordine di Priorità dei Plugin (abilita in questo ordine):

  1. Plugin di Sicurezza - Wordfence, Sucuri, ecc.
  2. Plugin SEO - Yoast, RankMath, ecc.
  3. Plugin di Prestazioni - Caching, ottimizzazione
  4. Gateway di Pagamento - Stripe, PayPal, ecc.
  5. Altre estensioni di WooCommerce
  6. Plugin generali di WordPress

2.5 Documenta le Tue Scoperte

Quando identifichi il plugin in conflitto:

  1. Annota il nome e la versione del plugin
  2. Documenta il problema specifico che causa
  3. Controlla se è disponibile una versione aggiornata
  4. Cerca plugin alternativi che forniscano funzionalità simili

Passo 3: Controlla i Conflitti del Tema

Sebbene i temi raramente influenzino WCPOS (dato che utilizza la propria interfaccia), a volte possono causare problemi con:

  • Processi di checkout (se usi un gateway di checkout web)
  • Funzionalità dell'area admin
  • Risposte API

Testa con un Tema Predefinito

  1. Sul tuo sito di staging, passa a un tema predefinito di WordPress:
    • Twenty Twenty-Four
    • Twenty Twenty-Three
    • Twenty Twenty-Two
  2. Testa la funzionalità problematica
  3. Se il problema è risolto - Il tuo tema ha un conflitto
Impatto del Tema

I temi sono molto meno probabili per causare problemi a WCPOS rispetto ai plugin. L'interfaccia POS funziona in modo indipendente dal tuo tema. Tuttavia, i temi possono influenzare:

  • Pagine di checkout di WooCommerce
  • Funzionalità dell'amministrazione di WordPress
  • Risposte dell'API REST

Passo 4: Risoluzione dei Conflitti dei Plugin

Una volta identificato il plugin in conflitto, hai diverse opzioni:

Opzione 1: Aggiorna il Plugin

  1. Controlla aggiornamenti - Il conflitto potrebbe essere risolto in una versione più recente
  2. Aggiorna il plugin prima sul tuo sito di staging
  3. Testa a fondo prima di aggiornare sul sito live

Opzione 2: Trova un Alternativa

  1. Ricerca plugin alternativi che offrono la stessa funzionalità
  2. Testa le alternative sul tuo sito di staging
  3. Migra le impostazioni se cambi plugin

Opzione 3: Contatta lo Sviluppatore del Plugin

  1. Riporta il conflitto allo sviluppatore del plugin
  2. Fornisci informazioni dettagliate:
    • Versioni dei plugin coinvolti
    • Versioni di WordPress e WooCommerce
    • Messaggi di errore esatti o comportamenti
    • Passaggi per riprodurre il problema

Opzione 4: Soluzione Personalizzata

Per plugin essenziali che non possono essere sostituiti:

  1. Contatta uno sviluppatore di WordPress per creare una soluzione personalizzata
  2. Considera i ganci specifici per il plugin per disabilitare la funzionalità in conflitto
  3. Usa logica condizionale per disabilitare il plugin sulle pagine correlate al POS

Tipi di Plugin in Conflitto Comuni

Categorie di Plugin ad Alto Rischio

Plugin di Sicurezza:

  • Possono bloccare le richieste API
  • Possono interferire con l'autenticazione
  • Spesso hanno regole firewall aggressive

Plugin di Caching:

  • Possono memorizzare nella cache le risposte API in modo inappropriato
  • Possono interferire con i dati in tempo reale
  • Possono causare problemi con dati obsoleti

Plugin SEO:

  • Plugin pesanti possono rallentare l'area admin
  • Possono aggiungere query non necessarie al database
  • Possono interferire con le risposte dell'API REST

Page Builders:

  • Spesso caricano script pesanti nell'area admin
  • Possono entrare in conflitto con le pagine admin di WooCommerce
  • Possono interferire con i processi di checkout

Plugin di Membri/Restrizione:

  • Possono bloccare l'accesso API
  • Possono interferire con l'autenticazione dell'utente
  • Possono limitare l'accesso alle risorse necessarie

Categorie di Plugin a Rischio Inferiore

Moduli di Contatto: Di solito non interferiscono con WCPOS
Plugin per Social Media: Raramente causano conflitti
Plugin di Analisi: Generalmente sicuri a meno che non siano molto pesanti
Plugin di Contenuto di Base: Di solito compatibili

Conflitti di Plugin Noti

I plugin elencati di seguito sono noti per interferire con WCPOS. Molti problemi sono già stati risolti automaticamente nelle versioni recenti di WCPOS — l'aggiornamento all'ultima versione li risolve senza alcuna configurazione.

La maggior parte delle correzioni è "escludere il POS"

Il filo conduttore: WCPOS si basa sull'API REST di WooCommerce e renderizza alcuni flussi (login, pagamento, ricevute) in iframe. La correzione abituale è escludere gli endpoint/URL del POS (/wp-json/wcpos/, /wp-json/wc/v3/ e il percorso /pos/) dall'altro plugin — non disabilitarlo del tutto.

Plugin di sicurezza e di login

Questi sono la fonte più comune di conflitti, specialmente per il login dell'app desktop/mobile.

PluginSintomoCorrezione
WordfenceIl firewall blocca l'API REST; il campo del codice 2FA non si renderizza nell'iframe di login; una CSP restrittiva può bloccare gli asset del POSInserisci nella whitelist /wp-json/wcpos/ e /wp-json/wc/v3/ nel firewall. Per la 2FA: disabilitala temporaneamente per gli utenti del POS. La CSP viene rimossa automaticamente in v1.9.0+
Really Simple SecurityBlocca l'accesso API / forza i reindirizzamentiDisabilita eventuali restrizioni dell'API REST nelle impostazioni Advanced del plugin
WPS Hide LoginL'URL di login personalizzato interrompe l'iframe di login dell'appUsa l'URL di login standard /wp-admin/ per l'accesso al POS
iThemes / Solid SecurityBlocca l'API REST o attiva blocchi anti brute-force dalle chiamate del POSInserisci nella whitelist solo gli endpoint del POS e l'IP del server stesso — evita regole IP generalizzate
SucuriIl WAF blocca le richieste APIInserisci nella whitelist gli endpoint dell'API REST nella dashboard di Sucuri
Security OptimizerBlocca il login del POS admin ("use customize login URL")Accedi prima a WP Admin tramite l'URL personalizzato, poi vai su /pos
Force Login (e plugin di autenticazione REST simili)/wp-json/ restituisce 401/403; le app più vecchie segnalavano "Site does not seem to be a WordPress site"Consenti l'accesso non autenticato agli endpoint del POS, oppure disabilitalo durante la connessione iniziale. Le app v1.x ora mostrano il messaggio di errore reale
LoginPressForza il login basato su email; interrompe il login multi-utente del POSConsenti il login con nome utente, oppure disabilitalo per l'accesso al POS
JWT Authentication plugins403 su tutte le richieste dell'API POS dopo l'attivazione (il login può riuscire, tutto il resto fallisce)Risolto automaticamente in v1.8.x+. Sulle versioni più vecchie, disattiva il plugin JWT o escludi gli endpoint del POS
Captcha / reCAPTCHALoop di login nell'app desktop (il captcha non può renderizzarsi nell'iframe)Disabilita il captcha per l'URL di login del POS
Defender ProL'header X-Frame-Options blocca tutti gli iframe del POS (login, pagamento, ricevute)Aggiungi un'eccezione specifica per il POS per /pos/ invece di disabilitare X-Frame-Options a livello di sito
Jetpack CRM Client PortalInterrompe completamente il login del POSDisabilita solo l'estensione Client Portal

Plugin di prestazioni, caching e ottimizzazione

PluginSintomoCorrezione
WP Rocket, Autoptimize, Hummingbird, SmushIl defer/minify del JS interrompe il checkout e Stripe TerminalEscludi gli URL /pos/ dall'ottimizzazione del JS
LiteSpeed CacheLoop di ricaricamento costante al checkout nell'app desktop; CSP restrittivaAggiorna WCPOS, svuota la cache, escludi le pagine del POS dal caching. CSP rimossa automaticamente in v1.9.0+
Image PrioritizerRiempie di spam l'header HTTP Link, interrompendo la scoperta dell'API REST; l'app desktop mostra "does not appear to be a WordPress site"Disattiva il plugin

Page builder e iniettori front-end

PluginSintomoCorrezione
Elementorelementor-frontend.js interrompe la fisarmonica del checkout all'interno dell'iframe del POS — i metodi di pagamento non si espandonoEscludi le pagine del POS dal caricamento degli script di Elementor
Omnisend / marketing pluginsIniettano script nell'iframe del checkout, interrompendo il layout e i pagamentiUsa le Checkout Settings del POS per disabilitare gli script non essenziali
MyStickyElements / ComplianzIniettano overlay (pulsanti fissi, banner dei cookie) nell'iframe del checkoutConfigurali per escludere gli URL /pos/

Estensioni di WooCommerce e altri plugin

PluginSintomoCorrezione
WooCommerce SubscriptionsConflitto dello script di migrazione durante l'aggiornamento v1.7→v1.8Disattiva Subscriptions, attiva POS Pro (lascia eseguire la migrazione), poi riabilitalo
WP Activity LogRegistra ogni azione del POS → gonfiore dei postmeta → "only 10 products"Disabilitalo, oppure escludi i tipi di post del POS dalla registrazione
Jetpack / Astra / Xero (qualsiasi cosa si agganci a save_post)Righe meta duplicate a ogni chiamata dell'API POS (un negozio ha raggiunto 36.867 righe su un prodotto)Risolto automaticamente in v1.8.12+ (gratuito) / v1.8.14+ (Pro) con una migrazione di pulizia — basta aggiornare
Stripe TaxIncompatibile con gli ordini creati tramite API REST (il modo in cui il POS crea gli ordini)Nessuna soluzione alternativa — incompatibile
MolliePuò nascondere il metodo BACS (bonifico bancario) dal checkout del POSAggiorna Mollie all'ultima versione
CTX FeedErrori 403 intermittenti nella pagina delle impostazioni del POSDisattivalo per confermare; nessuna soluzione alternativa nota
Plugin di scanner di codici a barre di terze partiCorrompono il JSON dell'API dell'ordine, interrompendo la creazione/visualizzazione degli ordiniDisabilitali; usa la scansione di codici a barre integrata nel POS
MailerLite (Signup Forms + WooCommerce)Errore 500 durante la creazione dell'ordine POS (esaurimento della memoria)Disattivalo per confermare, poi contatta MailerLite
The Courier Guy ShippingLa creazione dell'ordine POS fallisce con un errore del serverTorna a una versione precedente, oppure contatta lo sviluppatore
PixelYourSite / PixelMySiteErrore fatale: call to member function is_type() on boolDisabilitalo temporaneamente
Google Listings & AdsConflitto dell'autoloader → errore critico "Class WCPOS\…\Stores not found"Elimina tutti i plugin POS e reinstalla solo l'ultimo Pro standalone
Stripe Terminal: non abilitarlo globalmente

Il gateway Stripe Terminal dovrebbe essere abilitato solo all'interno delle Impostazioni POS, mai in WooCommerce > Settings > Payments. Abilitarlo globalmente lo fa apparire al checkout del tuo negozio pubblico e manda in crash il flusso di checkout online.

Conflitti a livello di server

OrigineSintomoCorrezione
Header CSP personalizzati (.htaccess, Nginx o un plugin di sicurezza)POS bloccato sul logo; JS/CSS bloccatiRimossi automaticamente sulle pagine del POS in v1.9.0+. Per la CSP a livello di server, consenti cdn.jsdelivr.net in script-src/style-src, oppure aggiungi un'eccezione /pos/
GoDaddy Website FirewallBlocca /wp-json/ ("Received 'undefined'")Consenti il percorso URL /wp-json/ nel firewall — vedi Performance del Server

Suggerimenti per la Prevenzione

Manutenzione Regolare

  1. Mantieni i plugin aggiornati - Usa sempre le versioni più recenti
  2. Rimuovi i plugin inutilizzati - Non solo disattivarli, ma eliminali
  3. Testa gli aggiornamenti su staging prima di applicarli al sito live
  4. Monitora le prestazioni regolarmente utilizzando le metriche Performance del Server

Migliori Pratiche per la Selezione dei Plugin

  1. Scegli sviluppatori rinomati - Controlla le recensioni e la frequenza degli aggiornamenti
  2. Evita funzionalità ridondanti - Non installare più plugin che fanno la stessa cosa
  3. Leggi le informazioni di compatibilità - Controlla se i plugin sono testati con WooCommerce
  4. Inizia con un numero minimo di plugin - Aggiungi funzionalità gradualmente secondo necessità

Ottenere Aiuto

Se non riesci a risolvere il conflitto del plugin:

Per Utenti Pro

Supporto Pro

Gli utenti Pro ricevono supporto prioritario per la risoluzione dei conflitti dei plugin. Il nostro team può aiutare a identificare e risolvere i conflitti per te.

Supporto della Comunità

Quando Contatti il Supporto

Si prega di fornire:

  1. Elenco dei plugin attivi con versioni
  2. Versioni di WordPress e WooCommerce
  3. Descrizione dettagliata del problema
  4. Passaggi che hai già provato
  5. Messaggi di errore dai log
  6. Metriche delle prestazioni del server se pertinenti