1

Kohana 2では、カスタムkohana_error_page.phpファイルを作成し、それをビューディレクトリに配置することで、デフォルトのエラーページを上書きできます。ただし、これは404だけでなくすべてのエラーをオーバーライドします。500エラーの場合でも、わかりやすいオレンジ色のコハナエラーページを取得したいと思います。

誰かがこれを行った経験がありますか?

4

2 に答える 2

3

KO2では、フックを使用してこれを非常に簡単に行うことができます。イベントを見ると、system.404 次のようなものを使用して置き換える必要があるイベントが見つかります。

<?php defined('SYSPATH') or die('No direct script access.');

// Replace the default kohana 404
Event::replace('system.404', array('Kohana', 'show_404'), 
    array('hook_404', 'show'));

class hook_404 {
    public function show()
    {
        // first param is URI of page, second param is template to use
        Kohana::show_404(FALSE, 'custom_404');
    }

}

これをアプリフォルダー(またはモジュール)のhooksディレクトリに保存します。構成でフックを有効にすることを忘れないでください。

$config['enable_hooks'] = TRUE;

そして、カスタム404ビューを追加しますviews/custom_404.php

注:$config['display_errors']に設定している場合、これらは表示されません(IN_PRODUCTIONが正しい場合は、おそらく表示されますか?)FALSEconfig.phpそのためには、何かを出力して死ぬ必要があります。次のように置き換えKohana::show_404ます。

require Kohana::find_file('views', 'custom_404');
die();
于 2012-04-04T12:50:56.010 に答える
2

私はこれをテストしていません!! したがって、これを行う前にコードをバックアップしてください。

私が間違っていなければ、Kohana2には例外処理がハードコーディングされており、新しい例外を追加するための適切な方法はありません。これを回避するには、コアを変更する必要があります。

ファイル内system/i18n/en_US/errors.php

  • 新しいエントリを追加します。

    E_PAGE_ACCESS_DENIED => array( 1, 'Access Denied', ' -- message text-- ')
    

ファイル内system/i18n/en_US/core.php

  • 新しいエントリを追加します。

    'page_access_denied' => 'You are not permitted to access %s .'
    

system/core/Koahana.php

  • Kohana :: setup()メソッドの上部近くに、新しい定数を追加します。

    define('E_PAGE_ACCESS_DENIED', 69);
    
  • カスタムエラーのイベントを登録します(同じエラーの終わり近くに、Kohana::setup()404番目のエラーの登録が表示されます):

    Event::add('system.403', array('Kohana', 'show_403'));
    
  • 次に、の場所を見つけて、Kohana::show_404()独自のメソッドを作成します。

    public static function show_403($page = FALSE, $template = FALSE)
    {
        throw new Kohana_403_Exception($page, $template);
    }
    
  • ファイルの一番下までスクロールします..そこにError_404_Exception...のクラス定義があります403。次のことを忘れないでください。

    1. 新しい変数を定義するprotected $template = 'file_name_for_template';
    2. protected $code = E_PAGE_ACCESS_DENIED;
    3. Exception::__construct(Kohana::lang('core.page_access_denied', $page));
    4. header('HTTP/1.1 403 Forbidden');

    テンプレートファイルはsystem/views/に配置する必要があります

これで、アプリケーションのどこからでも呼び出すことができるはずです。Event::run('system.403');

于 2012-03-22T02:01:51.810 に答える