質問

どのようにCodeIgniterのとWordPressは外観とはの/テンプレートを感じるように統合することができます WordPressのブログはCodeIgniterの-作成したページに持ち越される?

役に立ちましたか?

解決

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

この後、あなたのCodeIgniterのindex.phpファイルの先頭に以下の行を置きます。必要に応じてお使いのWordPressのルートディレクトリを指すようにwp-blog-header.phpするパスを変更します。

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

次に、あなたはあなたのビュー内の以下の機能を使用することができます:

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

他のヘルパー関数は、ワードプレスのドキュメントで見つけることができたことができます デザインを統合するのに役立ちます。

他のヒント

私はCodeIgniterのindex.phpページで、ファイルのwp-ブログ - header.phpのを含める場合は、

、私は両方のCodeIgniterのURLヘルパーやワードプレスで定義されている()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");

最後の行は、ヘッダに「HTTP / 1.0 404ページが見つかりません」HTTPレスポンスヘッダを付加したワードプレスファイルとして追加する必要があります。

CodeIgntierに呼び出すために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;
}

今、あなたのCIプロジェクトにテンプレートを描画するためのWordPress get_header()および/またはget_footer()機能を使用することができます。

私は、カスタムCI電子商取引のウェブサイトに記事を管理するためのWordpressを使用しています。 CIは、私のメインのサイトです。ディレクトリ構造は、次のされます:

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

私はCIのののindex.php のの先頭に次のコードを追加するとき、私のURLが台無しにされることなく、私のCIコントローラにWordpressの機能を使用することができるよ。

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);
}

ジェローム・Jaglale( http://jeromejaglale.com/doc/phpにより、CIの国際化ライブラリを使用した場合にも作品/ codeigniter_i18n に)。

あなたのコード内のコードの点火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を使用することができます。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top