web-dev-qa-db-ja.com

WordPressテンプレートをCodeIgniterと統合する方法

CodeIgniterとWordPressを統合して、WordPressブログのルックアンドフィール/テンプレートをBlogがCodeIgniterが作成したページに引き継がれるようにするには、どうすればよいですか?

45
Click Upvote

最初のステップは、CodeIgniterとWordPressファイルを独自のディレクトリに移動することです。

その後、CodeIgniterのindex.phpファイルの先頭に次の行を追加します。 WordPressのルートディレクトリを指すように、必要に応じてパスをwp-blog-header.phpに変更します。

<?php
    require('../wp-blog-header.php');

次に、ビュー内で次の関数を使用できます。

<?php
    get_header();
    get_sidebar();
    get_footer();    
?>

他のヘルパー関数もWordPressのドキュメントにあり、デザインの統合に役立ちます。

32
Click Upvote

Codeigniterのindex.phpページにwp-blog-header.phpファイルを含めたところ、codeigniterのURLヘルパーとWordPressの両方でsite_url()が定義されているという問題が発生しました。私は次のコードを使用してこれを解決しました:

require('blog/wp-blog-header.php');

add_filter('site_url', 'ci_site_url', 1);

function ci_site_url() {
    include(BASEPATH.'application/config/config.php');
    return $config['base_url'];
}

header("HTTP/1.0 200 OK");

WordPressファイルはHTTP応答ヘッダー「HTTP/1.0 404ページが見つかりません」をヘッダーに追加していたため、最後の行を追加する必要があります。

CodeIgntierで呼び出すWordPress関数を使用しても問題ありません。

16
sumanchalki

WordPressテンプレートをcodeigniterプロジェクトで使用する別の方法を次に示します。これは私にとってよりうまく機能するので、共有したいと思います。WordPress 3.3.1でテストされ、 Codeigniter 2.1。

ディレクトリ構造:

_/ - WordPress
/ci/ - codeigniter
_

/ci/index.php(CIインデックスファイルの上部)

_$wp_did_header = true;

if ( defined('E_RECOVERABLE_ERROR') )
    error_reporting(E_CORE_ERROR | E_CORE_WARNING | E_COMPILE_ERROR | E_ERROR |   E_WARNING | E_PARSE | E_USER_ERROR | E_USER_WARNING | E_RECOVERABLE_ERROR);
else
    error_reporting(E_CORE_ERROR | E_CORE_WARNING | E_COMPILE_ERROR | E_ERROR | E_WARNING | E_PARSE | E_USER_ERROR | E_USER_WARNING);

require_once("../wp-config.php");
_

デフォルトのcodeigniterバージョンを上書きして、site_url関数の衝突に対処します。代わりにsite_url()を使用するには、codeigniterでci_site_url()を使用した場所を変更する必要があります。

/ci/application/helpers/MY_url_helper.php

_<?php
function anchor($uri = '', $title = '', $attributes = '')
{
    $title = (string) $title;

    if ( ! is_array($uri))
    {
        $site_url = ( ! preg_match('!^\w+://! i', $uri)) ? ci_site_url($uri) : $uri;
    }
    else
    {
        $site_url = ci_site_url($uri);
    }

    if ($title == '')
    {
        $title = $site_url;
    }

    if ($attributes != '')
    {
        $attributes = _parse_attributes($attributes);
    }

    return '<a href="'.$site_url.'"'.$attributes.'>'.$title.'</a>';
}


if ( ! function_exists('ci_site_url'))
{
    function ci_site_url($uri = '')
    {
        $CI =& get_instance();
        return $CI->config->site_url($uri);
    }
}

function current_url()
{
    $CI =& get_instance();
    return $CI->config->ci_site_url($CI->uri->uri_string());
}


function anchor_popup($uri = '', $title = '', $attributes = FALSE)
{
    $title = (string) $title;

    $site_url = ( ! preg_match('!^\w+://! i', $uri)) ? ci_site_url($uri) : $uri;

    if ($title == '')
    {
        $title = $site_url;
    }

    if ($attributes === FALSE)
    {
        return "<a href='javascript:void(0);' onclick=\"window.open('".$site_url."', '_blank');\">".$title."</a>";
    }

    if ( ! is_array($attributes))
    {
        $attributes = array();
    }

    foreach (array('width' => '800', 'height' => '600', 'scrollbars' => 'yes', 'status' => 'yes', 'resizable' => 'yes', 'screenx' => '0', 'screeny' => '0', ) as $key => $val)
    {
        $atts[$key] = ( ! isset($attributes[$key])) ? $val : $attributes[$key];
        unset($attributes[$key]);
    }

    if ($attributes != '')
    {
        $attributes = _parse_attributes($attributes);
    }

    return "<a href='javascript:void(0);' onclick=\"window.open('".$site_url."', '_blank', '"._parse_attributes($atts, TRUE)."');\"$attributes>".$title."</a>";
}



function redirect($uri = '', $method = 'location', $http_response_code = 302)
{
    if ( ! preg_match('#^https?://#i', $uri))
    {
        $uri = ci_site_url($uri);
    }

    switch($method)
    {
        case 'refresh'  : header("Refresh:0;url=".$uri);
            break;
        default         : header("Location: ".$uri, TRUE, $http_response_code);
            break;
    }
    exit;
}
_

WordPress get_header()および/またはget_footer()関数を使用して、CIプロジェクトにテンプレートを描画できます。

6
sschueller

私はWordpress=を使用して、カスタムCI電子商取引Webサイトの記事を管理しています。CIは私のメインサイトです。ディレクトリ構造は次のとおりです。

 /application (CI)
 /... (directories like javascript, stylesheets ...)
 /system (CI)
 /wordpress
 /.htaccess
 /index.php (CI)

次のコードをCIの先頭に追加すると、URLがめちゃくちゃにならずに、Wordpress関数をCIコントローラーで使用できますindex.php

require_once './wordpress/wp-blog-header.php';

add_filter('site_url', 'ci_site_url', 1);

function ci_site_url($uri = '') {
    $CI =& get_instance();
    $uri = ltrim(str_replace($CI->config->base_url('wordpress/'), '', $uri),'/'); // "wordpress/" is in my case the name of the directory where I installed Wordpress. See directory structure above.
    return $CI->config->site_url($uri);
}

JérômeJaglale( http://jeromejaglale.com/doc/php/codeigniter_i18n )によるCI i18nライブラリを使用する場合にも機能します。

3
Chris Aelbrecht

コードでコードのignitor site_url関数を使用することを計画している場合、または既存のCIサイトとWPのマージを実行している場合、これは役立つ場合があります。

cI index.phpの上部:

require_once '../wp-blog-header.php';

add_filter('site_url', 'ci_site_url', 4);

function ci_site_url($url, $path, $orig_scheme, $blog_id) {
    $CI =& get_instance();
    $new_path = str_replace("YOURSITEURLGOESHERE", "", $url);
    return  $CI->config->site_url($new_path);
}

これにより、CIでsite_urlを効果的に使用できるようになるため、すでに大量のリンクとコンテンツをプロジェクトに追加している場合は、役立つ可能性があります。

0
Eric