當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Profiler::profiles方法代碼示例

本文整理匯總了PHP中Profiler::profiles方法的典型用法代碼示例。如果您正苦於以下問題:PHP Profiler::profiles方法的具體用法?PHP Profiler::profiles怎麽用?PHP Profiler::profiles使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Profiler的用法示例。


在下文中一共展示了Profiler::profiles方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: dispatch

 private function dispatch()
 {
     try {
         $this->call = self::$req->scheme();
         $action = self::$req->action;
         // the request action (method)
         $obj = $this->call->class;
         $method = $this->call->method;
         $preflight = $this->call->preflight;
         $type = self::$req->type;
         $model = null;
         $res = $this->call->resource;
         // the root resource
         presto_lib::_trace('REQUEST', "[{$this->call->file}] {$obj}::{$method} ({$this->call->type})", json_encode($this->call->params), json_encode($this->call->options));
         // Create an an instance of the API subclass (autoloaded)
         autoload_delegate($this->call);
         if (!class_exists($obj)) {
             throw new Exception("API class not found for {$obj}::{$method}", 404);
         }
         // Start the response setup
         self::$resp = new response($this->call);
         API::attach($this->call, self::$resp, self::$req);
         $o = new $obj();
         // Verify the request
         if ($obj == 'error') {
             // disallow root component access
             throw new Exception('Root access not allowed', 403);
         }
         if (!method_exists($obj, $preflight)) {
             if (method_exists($obj, 'autoload_model')) {
                 // try a default model autoloader "preflight"
                 $model = $o->autoload_model($this->call->params, $this->call->options, self::$req->body(), $this->call->type);
             } else {
                 // skip + trace missing preflight functions (data will be passed as standard HTTP params)
                 presto_lib::_trace('PREFLIGHT', 'skipped', "[{$this->call->file}] {$obj}::{$preflight} ({$this->call->type})", json_encode($this->call->params), json_encode($this->call->options));
             }
         } else {
             // attempt a custom "preflight" model autoload call
             $model = $o->{$preflight}($this->call->params, $this->call->options, self::$req->body(), $this->call->type);
         }
         if (!method_exists($obj, $method)) {
             // valid route?
             throw new Exception("Resource {$obj}->{$method} not found.", 404);
         }
         $this->call->exists = true;
         // Perform the actual sub delegation
         if (isset($model)) {
             $this->call->data = $o->{$method}($model, $this->call->type);
         } else {
             $this->call->data = $o->{$method}($this->call->params, $this->call->options, self::$req->body(), $this->call->type);
         }
         // Produce a response for the client
         presto_lib::_trace(PRESTO_TRACE_KEY, json_encode(Presto::trace_info()));
         $profiles = Profiler::profiles();
         // add any process profiling to trace
         if (!empty($profiles)) {
             presto_lib::_trace(PROFILER_TRACE_KEY, json_encode($profiles));
         }
         $encode = is_object($this->call->data) || is_array($this->call->data);
         return self::$resp->ok($this->call, $encode, $o->status(), $o->headers());
     } catch (Exception $e) {
         if (self::$resp === null) {
             self::$resp = new response();
         }
         self::$resp->hdr($e->getCode());
         throw $e;
     }
 }
開發者ID:robotpony,項目名稱:Presto,代碼行數:68,代碼來源:presto.php


注:本文中的Profiler::profiles方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。