質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.63%

cakephpで作った一覧画面が表示できない

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 996

kosuke4649

score 10

cakephp2.8.6とxampp5.5.37を使って、sqlsever2008 R2のデータを一覧画面に
表示させるプロジェクトを作り、画面に表示するところまでできていました。

ですが、ある事情で開発環境を古いバージョンに、具体的には
apache2.2
php5.3.6
cakephp1.3.11
を使って開発しなおすことになりました。

そこでapacheとphpを上記したバージョンでローカルに入れ直し、
localhost/phpinfo.phpの画面はみられるようになったのですが、
いざ
localhost/myproject/ichiran
をアドレスバーに入力してアクセスしようとしても、

Fatal Error (256): ConnectionManager::loadDataSource - 
Unable to import DataSource class .Database/sqlserverSource 
[CORE\cake\libs\model\connection_manager.php, line 185]

というエラーがでて表示されません。
自分はこのエラーを、sqlserverに接続するためのクラスが存在しないから
発生しているエラーだと判断し、私の前の質問「sqlserverにphpからアクセスしたい」で
回答していただいた方法でdriverもphp5.3.6バージョンのをいれれたし、
いけるだろうと思っていたのですが、driverをいれても解決されず、同じ内容の
エラーが表示されてしまっています。

このエラーに関して調査はしたのですが、解決方法が結局わからないままとなっております。
どなたかわかる方がいらっしゃいましたら、教えていただけると助かります。よろしくお願いします。

追記
database.phpは、

<?php

class DATABASE_CONFIG {

    public $default = array(
        'datasource' => 'Database/Sqlserver',
        'persistent' => false,
        'host' => 'localhost\SQLExpress',
        'login' => 'kosuke4649',
        'password' => 'xxxxx',
        'database' => 'kosuke_db',
        'prefix' => ''
    );

}


「ichiran」のコントローラーは、コントローラー名を「ichiran_controller.php」に変更し、 

class ichiranController extends AppController {

    public $uses = array('ichiran', 'makers', 'users');
    public $name = 'ichiran';
    //ページング設定
    public $paginate = array(
        'ichiran' => array(
            'limit' => 1000,
            'maxLimit' => 300,
            'joins' => array(
                array(
                    'type' => 'LEFT',
                    'table' => 'makers',
                    'alias' => 'MAKER',
                    'conditions' => array('ichiran.maker_code = MAKER.id')
                ),
                array(
                    'type' => 'LEFT',
                    'table' => 'users',
                    'alias' => 'ADMIN_USER',
                    'conditions' => array('ichiran.administrator_code = ADMIN_USER.id')
                ),
                array(
                    'type' => 'LEFT',
                    'table' => 'users',
                    'alias' => 'USER_USER',
                    'conditions' => array('ichiran.user_code = USER_USER.id')
                )
            )
        )
    );

    function index() {

と書いております。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • kosuke4649

    2016/08/05 10:51

    すみません、コメント欄に書いたら非常に読みづらいと知らなかったので、
    質問に補足として書き直します。

    キャンセル

  • kunai

    2016/08/05 13:23

    質問欄でも見辛くて仕方がないのですが、コードブロックの中に書いていただき、インデントも整えていただけませんか。
    また、最初の質問に書いた前半部分のご回答はいかがでしょうか。

    キャンセル

  • kosuke4649

    2016/08/05 13:44

    すみません、コードを見やすく書き直しました。
    また前半部分のご質問の回答ですが、
    ・ファイルの名前をアンダーバーと小文字で書き換える
     (IchiranController→ichiran_controller)
    ・モデルのichiran.phpのはじめのApp::uses('AppModel', 'Model')を
     App::import('AppModel', 'Model')に書き換える
    の2点のみを書き換えました。

    キャンセル

回答 1

0

CakePHP 1.3には、デフォルトで’Database/Sqlserver’が含まれていないと思いますが、こちらはご自分で準備されたのでしょうか。
CakePHP 2.8.6に含まれていたSqlserver.php を使われているのであれば、versionが違う事もあって動かないのではないかなと思います。
(実際試したわけではないので、動くのかもしれませんが)

そもそもそのdatabase.phpはCakePHP2系用の記述ですので、そのままでは動かないと思います。
cakephp1.3系のマニュアルを参照し、

'driver' => 'sqlsrv'


と設定して頂ければ、ひとまずそのエラーは解消するのではないでしょうか。

ただ、他にもConfigディレクトリ内の設定ファイルもCakePHP2系の記述になっていると思いますので、すべてCakePHP1.3系の記述に修正してください。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/08/05 14:45 編集

    回答いただき、ありがとうございます。
    database.phpをcakephp1.3の仕様に書き直し、
    'driver' = 'sqlsrv'
    を追加したのですが、やはり同じエラーが出てしまいます。
    ので、Configディレクトリ内の設定ファイルでおかしなところが
    ないかを調査してみます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.63%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る