in C:\xampp\htdocs\template\vendor\yiisoft\yii2\db\Connection.php at line 579
$token = 'Opening DB connection: ' . $this->dsn; try { Yii::info($token, __METHOD__); Yii::beginProfile($token, __METHOD__); $this->pdo = $this->createPdoInstance(); $this->initConnection(); Yii::endProfile($token, __METHOD__); } catch (\PDOException $e) { Yii::endProfile($token, __METHOD__); throw new Exception($e->getMessage(), $e->errorInfo, (int) $e->getCode(), $e); } } /** * Closes the currently active DB connection. * It does nothing if the connection is already closed. */ public function close() {
* Returns the PDO instance for the currently active master connection. * This method will open the master DB connection and then return [[pdo]]. * @return PDO the PDO instance for the currently active master connection. */ public function getMasterPdo() { $this->open(); return $this->pdo; } /** * Returns the currently active slave connection. * If this method is called the first time, it will try to open a slave connection when [[enableSlaves]] is true.
* is available and `$fallbackToMaster` is false. */ public function getSlavePdo($fallbackToMaster = true) { $db = $this->getSlave(false); if ($db === null) { return $fallbackToMaster ? $this->getMasterPdo() : null; } else { return $db->pdo; } } /**
if ($this->db->getTransaction()) { // master is in a transaction. use the same connection. $forRead = false; } if ($forRead || $forRead === null && $this->db->getSchema()->isReadQuery($sql)) { $pdo = $this->db->getSlavePdo(); } else { $pdo = $this->db->getMasterPdo(); } try { $this->pdoStatement = $pdo->prepare($sql);
Yii::trace('Query result served from cache', 'yii\db\Command::query'); return $result[0]; } } } $this->prepare(true); $token = $rawSql; try { Yii::beginProfile($token, 'yii\db\Command::query'); $this->pdoStatement->execute();
* @return array all rows of the query result. Each array element is an array representing a row of data. * An empty array is returned if the query results in nothing. * @throws Exception execution failed */ public function queryAll($fetchMode = null) { return $this->queryInternal('fetchAll', $fetchMode); } /** * Executes the SQL statement and returns the first row of the result. * This method is best used when only the first row of result is needed for a query. * @param integer $fetchMode the result fetch mode. Please refer to [PHP manual](http://www.php.net/manual/en/function.PDOStatement-setFetchMode.php)
* @throws \Exception if DB query fails */ protected function findColumns($table) { $sql = 'SHOW FULL COLUMNS FROM ' . $this->quoteTableName($table->fullName); try { $columns = $this->db->createCommand($sql)->queryAll(); } catch (\Exception $e) { $previous = $e->getPrevious(); if ($previous instanceof \PDOException && strpos($previous->getMessage(), 'SQLSTATE[42S02') !== false) { // table does not exist // https://dev.mysql.com/doc/refman/5.5/en/error-messages-server.html#error_er_bad_table_error return false;
*/ protected function loadTableSchema($name) { $table = new TableSchema; $this->resolveTableNames($table, $name); if ($this->findColumns($table)) { $this->findConstraints($table); return $table; } else { return null; }
} return $this->_tables[$name]; } } return $this->_tables[$name] = $this->loadTableSchema($realName); } /** * Returns the cache key for the specified table name. * @param string $name the table name * @return mixed the cache key
* Returns the schema information of the DB table associated with this AR class. * @return TableSchema the schema information of the DB table associated with this AR class. * @throws InvalidConfigException if the table for the AR class does not exist. */ public static function getTableSchema() { $schema = static::getDb()->getSchema()->getTableSchema(static::tableName()); if ($schema !== null) { return $schema; } else { throw new InvalidConfigException("The table does not exist: " . static::tableName()); } }
* Note that an array should be returned even for a table with single primary key. * * @return string[] the primary keys of the associated database table. */ public static function primaryKey() { return static::getTableSchema()->primaryKey; } /** * Returns the list of all attribute names of the model. * The default implementation will return all column names of the table associated with this AR class. * @return array list of attribute names.
protected static function findByCondition($condition) { $query = static::find(); if (!ArrayHelper::isAssociative($condition)) { // query by primary key $primaryKey = static::primaryKey(); if (isset($primaryKey[0])) { $pk = $primaryKey[0]; if (!empty($query->join) || !empty($query->joinWith)) { $pk = static::tableName() . '.' . $pk; } $condition = [$pk => $condition];
/** * @inheritdoc * @return static|null ActiveRecord instance matching the condition, or `null` if nothing matches. */ public static function findOne($condition) { return static::findByCondition($condition)->one(); } /** * @inheritdoc * @return static[] an array of ActiveRecord instances, or an empty array if nothing matches. */
return $this->render('viewtemp', [ 'model' => $this->findModel($id), ]); } public function findModel($id) { if(($model = Template::findOne($id)) !== null && $model->temp_status!=='N') { $model->count++; $model->save(); return $model; }else if(($model = Template::findOne($id)) !== null && $model->temp_status=='N') { throw new NotFoundHttpException('Template ที่เรียกหาไม่ได้เปิดให้เข้าดูข้อมูลในขณะนี้'); }else{
} public function actionViewtemp($id) { Yii::$app->view->params['title'] = "Template"; Yii::$app->view->params['checkmenu'] = 3; return $this->render('viewtemp', [ 'model' => $this->findModel($id), ]); } public function findModel($id) { if(($model = Template::findOne($id)) !== null && $model->temp_status!=='N') { $model->count++;
$args = $this->controller->bindActionParams($this, $params); Yii::trace('Running action: ' . get_class($this->controller) . '::' . $this->actionMethod . '()', __METHOD__); if (Yii::$app->requestedParams === null) { Yii::$app->requestedParams = $args; } return call_user_func_array([$this->controller, $this->actionMethod], $args); } }
} $result = null; if ($runAction && $this->beforeAction($action)) { // run the action $result = $action->runWithParams($params); $result = $this->afterAction($action, $result); // call afterAction on modules foreach ($modules as $module) { /* @var $module Module */
$parts = $this->createController($route); if (is_array($parts)) { /* @var $controller Controller */ list($controller, $actionID) = $parts; $oldController = Yii::$app->controller; Yii::$app->controller = $controller; $result = $controller->runAction($actionID, $params); Yii::$app->controller = $oldController; return $result; } else { $id = $this->getUniqueId(); throw new InvalidRouteException('Unable to resolve the request "' . ($id === '' ? $route : $id . '/' . $route) . '".');
$params = $this->catchAll; unset($params[0]); } try { Yii::trace("Route requested: '$route'", __METHOD__); $this->requestedRoute = $route; $result = $this->runAction($route, $params); if ($result instanceof Response) { return $result; } else { $response = $this->getResponse(); if ($result !== null) { $response->data = $result;
try { $this->state = self::STATE_BEFORE_REQUEST; $this->trigger(self::EVENT_BEFORE_REQUEST); $this->state = self::STATE_HANDLING_REQUEST; $response = $this->handleRequest($this->getRequest()); $this->state = self::STATE_AFTER_REQUEST; $this->trigger(self::EVENT_AFTER_REQUEST); $this->state = self::STATE_SENDING_RESPONSE; $response->send();
require(__DIR__ . '/../../common/config/main-local.php'), require(__DIR__ . '/../config/main.php'), require(__DIR__ . '/../config/main-local.php') ); $application = new yii\web\Application($config); $application->run();
$_GET = [ 'id' => '19', ]; $_SERVER = [ 'REDIRECT_MIBDIRS' => 'C:/xampp/php/extras/mibs', 'REDIRECT_MYSQL_HOME' => '\\xampp\\mysql\\bin', 'REDIRECT_OPENSSL_CONF' => 'C:/xampp/apache/bin/openssl.cnf', 'REDIRECT_PHP_PEAR_SYSCONF_DIR' => '\\xampp\\php', 'REDIRECT_PHPRC' => '\\xampp\\php', 'REDIRECT_TMP' => '\\xampp\\tmp', 'REDIRECT_STATUS' => '200', 'MIBDIRS' => 'C:/xampp/php/extras/mibs', 'MYSQL_HOME' => '\\xampp\\mysql\\bin', 'OPENSSL_CONF' => 'C:/xampp/apache/bin/openssl.cnf', 'PHP_PEAR_SYSCONF_DIR' => '\\xampp\\php', 'PHPRC' => '\\xampp\\php', 'TMP' => '\\xampp\\tmp', 'HTTP_ACCEPT' => '*/*', 'HTTP_USER_AGENT' => 'claudebot', 'HTTP_HOST' => 'template.wu.ac.th', 'PATH' => 'C:\\Program Files\\PHP\\v5.3;C:\\oracle\\product\\10.2.0\\client_1\\bin;C:\\Windows\\system32;C:\\Windows;C:\\Windows\\System32\\Wbem;C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\;;C:\\ANT\\bin;C:\\MAVEN\\bin;C:\\Program Files (x86)\\Dell\\SysMgt\\oma\\bin;C:\\Program Files (x86)\\Dell\\SysMgt\\shared\\bin;C:\\Program Files (x86)\\Dell\\SysMgt\\idrac;C:\\Program Files (x86)\\Common Files\\Acronis\\VirtualFile\\;C:\\Program Files (x86)\\Common Files\\Acronis\\VirtualFile64\\;C:\\Program Files (x86)\\Common Files\\Acronis\\FileProtector\\;C:\\Program Files (x86)\\Common Files\\Acronis\\FileProtector64\\;C:\\Program Files (x86)\\Common Files\\Acronis\\SnapAPI\\;', 'SystemRoot' => 'C:\\Windows', 'COMSPEC' => 'C:\\Windows\\system32\\cmd.exe', 'PATHEXT' => '.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC', 'WINDIR' => 'C:\\Windows', 'SERVER_SIGNATURE' => 'Apache/2.4.10 (Win32) OpenSSL/1.0.1i PHP/5.6.3 Server at template.wu.ac.th Port 80 ', 'SERVER_SOFTWARE' => 'Apache/2.4.10 (Win32) OpenSSL/1.0.1i PHP/5.6.3', 'SERVER_NAME' => 'template.wu.ac.th', 'SERVER_ADDR' => '202.28.69.38', 'SERVER_PORT' => '80', 'REMOTE_ADDR' => '3.238.12.0', 'DOCUMENT_ROOT' => 'C:/xampp/htdocs/template/frontend/web', 'REQUEST_SCHEME' => 'http', 'CONTEXT_PREFIX' => '', 'CONTEXT_DOCUMENT_ROOT' => 'C:/xampp/htdocs/template/frontend/web', 'SERVER_ADMIN' => 'postmaster@localhost', 'SCRIPT_FILENAME' => 'C:/xampp/htdocs/template/frontend/web/index.php', 'REMOTE_PORT' => '35156', 'REDIRECT_QUERY_STRING' => 'id=19', 'REDIRECT_URL' => '/site/viewtemp', 'GATEWAY_INTERFACE' => 'CGI/1.1', 'SERVER_PROTOCOL' => 'HTTP/1.1', 'REQUEST_METHOD' => 'GET', 'QUERY_STRING' => 'id=19', 'REQUEST_URI' => '/site/viewtemp?id=19', 'SCRIPT_NAME' => '/index.php', 'PHP_SELF' => '/index.php', 'REQUEST_TIME_FLOAT' => 1711711562.881999969482421875, 'REQUEST_TIME' => 1711711562, ];