Passando i parametri a un modello di pagina personalizzato utilizzando URL puliti


8

Ora sto passando parametri a un modello personalizzato nel seguente formato

www.example.com/?pageid=12&rid=24&title=this-is-the-title

Ho creato due tabelle. Quindi ho bisogno di recuperare i dati e visualizzarli su quelle pagine.

Vorrei che usasse un formato URL pulito come:

www.example.com/pageid/12/rid/24/title/this-is-the-title

Qualcuno può dire come questo può essere raggiunto?

Grazie


Totalmente possibile, ma devi essere consapevole delle tue variabili variabili per evitare conflitti. Dai un'occhiata a questo articolo sul codice WordPress ... questo è probabilmente l'hook che vorresti usare e mostra un esempio di matrice di riscrittura ... codex.wordpress.org/Plugin_API/Filter_Reference/…
Matt van Andel

Risposte:


3

add_rewrite_rule() ti permette di trasformare l'url grazioso in variabili.

  • numeri: (\d*)
  • sezione: /rid/o/pageid/
  • slug: ([a-zA-Z0-9-]+

Ecco una classe per registrare la riscrittura e gestire la richiesta se è stata trovata una corrispondenza.

<?php

if ( ! class_exists( 'CPTURLRewrite' ) ):

    class CPTURLRewrite {
        const ENDPOINT_QUERY_NAME  = 'pageid';
        const ENDPOINT_QUERY_PARAM = '__pageid';

        // WordPress hooks

        public function init() {
            add_filter( 'query_vars', array ( $this, 'add_query_vars' ), 0 );
            add_action( 'parse_request', array ( $this, 'sniff_requests' ), 0 );
            add_action( 'init', array ( $this, 'add_endpoint' ), 0 );
        }

        // Add public query vars

        public function add_query_vars( $vars ) {

            // add all the things we know we'll use

            $vars[] = static::ENDPOINT_QUERY_PARAM;
            $vars[] = 'pageid';
            $vars[] = 'rid';
            $vars[] = 'title';

            return $vars;
        }

        // Add API Endpoint

        public function add_endpoint() {

            // numbers:   (\d*)
            // section:   /rid/
            // slug:      ([a-zA-Z0-9-]+

            add_rewrite_rule( '^' . static::ENDPOINT_QUERY_NAME . '/(\d*)/rid/(\d*)/title/([a-zA-Z0-9-]+)?', 'index.php?' . static::ENDPOINT_QUERY_PARAM . '=1&pageid=$matches[1]&rid=$matches[2]&title=$matches[3]', 'top' );

            //////////////////////////////////
            flush_rewrite_rules( false ); //// <---------- REMOVE THIS WHEN DONE
            //////////////////////////////////
        }

        // Sniff Requests

        public function sniff_requests( $wp_query ) {
            global $wp;

            if ( isset(
                $wp->query_vars[ static::ENDPOINT_QUERY_PARAM ],
                $wp->query_vars[ 'pageid' ],
                $wp->query_vars[ 'rid' ],
                $wp->query_vars[ 'title' ] ) ) {
                $this->handle_request(); // handle it
            }
        }

        // Handle Requests

        protected function handle_request() {
            global $wp;

            // (optional) act on the query vars

            $pageid = $wp->query_vars[ 'pageid' ];
            $rid = $wp->query_vars[ 'rid' ];
            $title = $wp->query_vars[ 'title' ];

            // (optional) select your custom template

            add_filter( 'template_include', function( $original_template ) {
                return __DIR__ . '/custom.php';
            } );
        }
    }

    $wpCPTURLRewrite = new CPTURLRewrite();
    $wpCPTURLRewrite->init();

endif; // CPTURLRewrite

AGGIORNARE

Ho trovato un modo più semplice di gestirlo.

http://example.com/pageid/333/rid/444/title/your-title-here/

Questo nuovo modo utilizza add_rewrite_tagcon _per eseguire la query per l'ID di una pagina senza rovinare la query principale. Nell'esempio sopra, 333modificherebbe semplicemente la query per cercare l'ID post in pre_get_posts. Si potrebbe facilmente modificare template_redirecto template_include.

/**
 * Register a rewrite endpoint for the API.
 */
function prefix__init() {

    // add tags with `_` prefix to avoid screwing up query
    add_rewrite_tag( '%_pageid%', '(\d*)' );
    add_rewrite_tag( '%_rid%', '(\d*)' );
    add_rewrite_tag( '%_title%', '([a-zA-Z\d\-_+]+)' );

    // create URL rewrite
    add_rewrite_rule( '^pageid/(\d*)/rid/(\d*)/title/([a-zA-Z\d\-_+]+)?', 'index.php?_pageid=$matches[1]&_rid=$matches[2]&_title=$matches[3]', 'top' );

    // required once after rules added/changed
    // flush_rewrite_rules( true );
}

add_action( 'init', 'prefix__init' );

/**
 * Handle data (maybe) passed to the API endpoint.
 *
 * @param $query
 */
function prefix__pre_get_posts( $query ) {

    if ( isset( $query->query_vars[ '_pageid' ], $query->query_vars[ '_rid' ], $query->query_vars[ '_title' ] ) ) {

        // set the query to search for a page using `_pageid`
        $query->set( 'p', $query->query_vars[ '_pageid' ] );
    }
}

add_action( 'pre_get_posts', 'prefix__pre_get_posts' );

Per fare riferimento a tutti i parametri passati in seguito:

/**
* Debug the query params at any point
*/
function prefix__show_query_args() {
 global $wp_query;

    echo "<pre>";
    print_r( array (
        'pageid' => $wp_query->query_vars[ '_pageid' ],
        'rid'    => $wp_query->query_vars[ '_rid' ],
        'title'  => $wp_query->query_vars[ '_title' ],
        'file'   => __FILE__,
        'line'   => __LINE__,
    ) );
    echo "</pre>";
}

RIFERIMENTO


0

Se vuoi una soluzione semplice, potrebbe essere (non hai testato il codice, quindi potrebbe non essere così semplice se non funziona ...) o almeno dare qualche suggerimento su cosa devi fare. Se visiti http://thereforei.am/2011/10/28/advanced-taxonomy-queries-with-pretty-urls/ troverai un premio bonus: un generatore di regole di riscrittura nell'articolo. L'ho usato prima ma non in una situazione esattamente come questa. Prova a combinare quella funzione con qualcosa del genere:

add_rewrite_tag('%pageid%','([^&]+)');
add_rewrite_tag('%rid%','([^&]+)');
add_rewrite_tag('%title%','([^&]+)');

/* Generate rewrite rules. */
add_action( 'generate_rewrite_rules', 'example_add_rewrite_rules' );
function example_add_rewrite_rules() {
    global $wp_rewrite;
    $new_rules = eg_generate_rewrite_rules( 'post' , array('pageid','rid','title')); //    post = the post type you use
    $wp_rewrite->rules = $new_rules + $wp_rewrite->rules;
}

/* Flush rewrite rules on theme activation only. */
add_action( 'load-themes.php', 'frosty_flush_rewrite_rules' );
function frosty_flush_rewrite_rules() {
    global $pagenow;
    if ( 'themes.php' == $pagenow && isset( $_GET['activated'] ) )
        flush_rewrite_rules();
}

Se non vuoi usare la funzione eg_generate_rewrite_rules, devi impostare tu stesso le regole. Puoi trovare informazioni su come farlo in quell'articolo.

Ulteriori informazioni: http://codex.wordpress.org/Rewrite_API/add_rewrite_tag

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.