ホームページ >PHPフレームワーク >ThinkPHP >Thinkphp5 がフロントエンドとバックエンドの分離をどのように実現するかを分析する

Thinkphp5 がフロントエンドとバックエンドの分離をどのように実現するかを分析する

藏色散人
藏色散人転載
2021-05-20 15:31:144314ブラウズ

次の thinkphp フレームワーク チュートリアル コラムでは、Thinkphp5 のフロントエンドとバックエンドの分離について紹介します。困っている友人の役に立てば幸いです。

Thinkphp5 を使用して純粋な API 開発を実装し、フロントエンドとバックエンドの分離を実現します

一般的な手順は次のとおりです

1. ドメイン リクエストの問題
2. 出力データ形式を一般的に使用される API リターン JSON 形式に変更します
3. 例外処理をカスタマイズします (アダプテーション API の使用法を変更します)
4. 開始強制ルーティング

クロスドメインの問題の解決
# application\targs.php 拡張定義ファイルを見つけて、api\Crossdomain 内の app_init

// 应用行为扩展定义文件
return [
    // 应用初始化
    'app_init'     => [
        'app\api\Crossdomain\Cdom'
    ],
    // 应用开始
    'app_begin'    => [],
    // 模块初始化
    'module_init'  => [],
    // 操作开始执行
    'action_begin' => [],
    // 视图内容过滤
    'view_filter'  => [],
    // 日志写入
    'log_write'    => [],
    // 应用结束
    'app_end'      => [],
];

の値を変更します。アプリケーションフォルダーのディレクトリに新しい Cdom.php コードを作成します。コードは次のとおりです。

<?php
namespace app\api\Crossdomain;
class Cdom
{
    public function appInit($params)
    {
        //配置IP白名单 在测试环境下可以为 * 号 生产环境下建议根据实际环境进行修改。
        header(&#39;Access-Control-Allow-Origin: *&#39;);
        header("Access-Control-Allow-Headers: token,Origin, X-Requested-With, X_Requested_With,Content-Type, Accept");
        header(&#39;Access-Control-Allow-Methods: POST,GET,PUT&#39;);
        if(request()->isOptions()){
            exit();
        }
    }
}

出力データ形式を共通 API の戻り JSON 形式に変更します
TP5 のデフォルトの出力データ形式は HTML ですが、これは明らかに共通 API インターフェースのデータ仕様に準拠していないため、対応する変更を加える必要があります。アプリケーション ディレクトリで config.php を見つけ、次の構成を変更して、毎回手動で json または json_encode を実行する必要を回避します

// 默认输出类型
    &#39;default_return_type&#39;    => &#39;json&#39;,

変更後にデータを返す場合は、次の

  return [&#39;code&#39;=>1];

を直接返すことができます。データを json 形式で直接出力します。
カスタマイズされた例外処理 (アダプテーション API の使用を変更します)

TP5 独自の例外処理メカニズムは、TP5 として使用するとリクエストが直接クラッシュします。 API インターフェース. 異常な状況では、API インターフェースが正常な JSON データを受信できず、エラーが発生しました。このためには、TP の例外処理メカニズムをカスタマイズする必要があります。
アプリケーション ディレクトリで config.php 構成ファイルを見つけます。次のオプションを

    'exception_handle'       => 'app\api\Crossdomain\CdomHandle',

に変更します。対応するディレクトリを見つけて、CdomHandle.php ファイルを追加し、次のコードを追加します。

<?php
namespace app\api\Crossdomain;

use think\exception\Handle;
use think\Env;
use Exception;
use MyCLabs\Enum\Enum;

class CdomHandle extends Handle
{
    private $code = 999;
    private $msg;
    private $errCode;
    private $errFile = &#39;&#39;;
    private $errline = &#39;&#39;;
    private $errtrace = &#39;&#39;;
    private $errtracestring = &#39;&#39;;
    protected function getSourceCode(Exception $exception)
    {
        // 读取前9行和后9行
        $line  = $exception->getLine();
        $first = ($line - 9 > 0) ? $line - 9 : 1;

        try {
            $contents = file($exception->getFile());
            $source   = [
                &#39;first&#39;  => $first,
                &#39;source&#39; => array_slice($contents, $first - 1, 19),
            ];
        } catch (Exception $e) {
            $source = [&#39;code&#39;=>1];
        }
        return $source;
    }
    public function render(Exception $e)
    {
        $app_debug = Env::get(&#39;APP_DEBUG&#39;);
        //如果是调试模式
        if($app_debug)
        {
            $this->msg = $e->getMessage();
            $this->errCode = $e->getCode();
            $this->errFile = json($this->getSourceCode($e));
            $this->errline = $e->getLine();
            if(Env::get(&#39;APP_TRACE&#39;))
            {
                $this->errtrace = $e->getTrace();
                $this->errtracestring = $e->getTraceAsString();
            }
        }
        else
        {
            $result = [
                &#39;msg&#39; => $e->getMessage(),
                &#39;errFile&#39; => ($this->getSourceCode($e)),

                &#39;code&#39; => 999,
            ];
            return json($result);
        }
        return json([
            &#39;code&#39;=>$this->code,
            &#39;msg&#39;=>$this->msg,
            &#39;errCode&#39;=>$this->errCode,
            &#39;errFile&#39;=>$this->errFile,
            &#39;errLine&#39;=>$this->errline,
            &#39;errtrace&#39;=>$this->errtrace,
            &#39;errtracestring&#39;=>$this->errtracestring
        ]);
    }
}

強力なルーティングを有効にする

    // 是否开启路由
    'url_route_on'           => true,
    // 路由使用完整匹配
    'route_complete_match'   => true,
    // 是否强制使用路由
    'url_route_must'         => true,

Env の使用法については、こちらの TP マニュアルを参照してください。

BaseException说明:https://docs.python.org/3.1/library/exceptions.html#BaseException

関連する推奨事項: 最新の 10 件の thinkphp ビデオ チュートリアル

以上がThinkphp5 がフロントエンドとバックエンドの分離をどのように実現するかを分析するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はcsdn.netで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。