WordPress ブログのルック アンド フィール/テンプレートが CodeIgniter で作成されたページに引き継がれるように、CodeIgniter と WordPress を統合するにはどうすればよいですか?
5 に答える
最初のステップは、CodeIgniter と WordPress ファイルを独自のディレクトリに移動することです。
その後、CodeIgniter のindex.php
ファイルの先頭に次の行を追加します。必要に応じてパスを変更しwp-blog-header.php
て、WordPress のルート ディレクトリを指すようにします。
<?php
require('../wp-blog-header.php');
次に、ビュー内で次の関数を使用できます。
<?php
get_header();
get_sidebar();
get_footer();
?>
他のヘルパー関数も WordPress のドキュメントに記載されており、デザインの統合に役立ちます。
wp-blog-header.php ファイルを Codeigniter の index.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 ページが見つかりません」をヘッダーに追加していたため、最後の行を追加する必要があります。
これで、WordPress 関数を使用して CodeIgniter を呼び出すことができます。
codeigniterプロジェクトでWordPressテンプレートを使用する別の方法は次のとおりです。これは私にとってはうまくいくので、共有したいと思いました。WordPress3.3.1およびCodeigniter2.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;
}
これで、WordPressget_header()
やget_footer()
関数を使用して、CIプロジェクトにテンプレートを描画できます。
カスタム CI 電子商取引 Web サイトで記事を管理するために 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);
}
Jérôme Jaglale ( http://jeromejaglale.com/doc/php/codeigniter_i18n ) による CI 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 を使用できるようになるため、既に大量のリンクとコンテンツをプロジェクトに追加している場合は、それが役立つ可能性があります。