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


PHP Typecho_Db::update方法代碼示例

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


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

示例1: execute

 /**
  * 執行函數
  *
  * @access public
  * @return void
  */
 public function execute()
 {
     if ($this->hasLogin()) {
         $rows = $this->db->fetchAll($this->db->select()->from('table.options')->where('user = ?', $this->_user['uid']));
         $this->push($this->_user);
         foreach ($rows as $row) {
             $this->options->__set($row['name'], $row['value']);
         }
         //更新最後活動時間
         $this->db->query($this->db->update('table.users')->rows(array('activated' => $this->options->gmtTime))->where('uid = ?', $this->_user['uid']));
     }
 }
開發者ID:javanprettycool,項目名稱:jblog,代碼行數:18,代碼來源:User.php

示例2: login

 /**
  * 以用戶名和密碼登錄
  *
  * @access public
  * @param string $name 用戶名
  * @param string $password 密碼
  * @param boolean $temporarily 是否為臨時登錄
  * @param integer $expire 過期時間
  * @return boolean
  */
 public function login($name, $password, $temporarily = false, $expire = 0)
 {
     //插件接口
     $result = $this->pluginHandle()->trigger($loginPluggable)->login($name, $password, $temporarily, $expire);
     if ($loginPluggable) {
         return $result;
     }
     /** 開始驗證用戶 **/
     $user = $this->db->fetchRow($this->db->select()->from('table.users')->where('name = ?', $name)->limit(1));
     $hashValidate = $this->pluginHandle()->trigger($hashPluggable)->hashValidate($password, $user['password']);
     if (!$hashPluggable) {
         $hashValidate = Typecho_Common::hashValidate($password, $user['password']);
     }
     if ($user && $hashValidate) {
         if (!$temporarily) {
             $authCode = sha1(Typecho_Common::randString(20));
             $user['authCode'] = $authCode;
             Typecho_Cookie::set('__typecho_uid', $user['uid'], $expire, $this->options->siteUrl);
             Typecho_Cookie::set('__typecho_authCode', Typecho_Common::hash($authCode), $expire, $this->options->siteUrl);
             //更新最後登錄時間以及驗證碼
             $this->db->query($this->db->update('table.users')->expression('logged', 'activated')->rows(array('authCode' => $authCode))->where('uid = ?', $user['uid']));
         }
         /** 壓入數據 */
         $this->push($user);
         $this->_hasLogin = true;
         $this->pluginHandle()->loginSucceed($this, $name, $password, $temporarily, $expire);
         return true;
     }
     $this->pluginHandle()->loginFail($this, $name, $password, $temporarily, $expire);
     return false;
 }
開發者ID:raindali,項目名稱:express,代碼行數:41,代碼來源:User.php

示例3: execute

 /**
  * 執行函數
  *
  * @access public
  * @return void
  */
 public function execute()
 {
     $this->db->fetchAll($this->db->select()->from('table.options')->where('user = 0'), array($this, 'push'));
     /** 支持皮膚變量重載 */
     if (!empty($this->row['theme:' . $this->row['theme']])) {
         $themeOptions = NULL;
         /** 解析變量 */
         if ($themeOptions = unserialize($this->row['theme:' . $this->row['theme']])) {
             /** 覆蓋變量 */
             $this->row = array_merge($this->row, $themeOptions);
         }
     }
     $this->stack[] =& $this->row;
     /** 初始化站點信息 */
     $this->siteUrl = Typecho_Common::url(NULL, $this->siteUrl);
     $this->plugins = unserialize($this->plugins);
     /** 增加對SSL連接的支持 */
     if ($this->request->isSecure() && 0 === strpos($this->siteUrl, 'http://')) {
         $this->siteUrl = substr_replace($this->siteUrl, 'https', 0, 4);
     }
     /** 自動初始化路由表 */
     $this->routingTable = unserialize($this->routingTable);
     if (!isset($this->routingTable[0])) {
         /** 解析路由並緩存 */
         $parser = new Typecho_Router_Parser($this->routingTable);
         $parsedRoutingTable = $parser->parse();
         $this->routingTable = array_merge(array($parsedRoutingTable), $this->routingTable);
         $this->db->query($this->db->update('table.options')->rows(array('value' => serialize($this->routingTable)))->where('name = ?', 'routingTable'));
     }
 }
開發者ID:raindali,項目名稱:express,代碼行數:36,代碼來源:Options.php

示例4: execute

 /**
  * 執行函數
  *
  * @access public
  * @return void
  */
 public function execute()
 {
     $this->db->fetchAll($this->db->select()->from('table.options')->where('user = 0'), array($this, 'push'));
     /** 支持皮膚變量重載 */
     if (!empty($this->row['theme:' . $this->row['theme']])) {
         $themeOptions = NULL;
         /** 解析變量 */
         if ($themeOptions = unserialize($this->row['theme:' . $this->row['theme']])) {
             /** 覆蓋變量 */
             $this->row = array_merge($this->row, $themeOptions);
         }
     }
     $this->stack[] =& $this->row;
     /** 初始化站點信息 */
     if (defined('__TYPECHO_SITE_URL__')) {
         $this->siteUrl = __TYPECHO_SITE_URL__;
     }
     $this->originalSiteUrl = $this->siteUrl;
     $this->siteUrl = Typecho_Common::url(NULL, $this->siteUrl);
     $this->plugins = unserialize($this->plugins);
     /** 動態判斷皮膚目錄 */
     $this->theme = is_dir($this->themeFile($this->theme)) ? $this->theme : 'default';
     /** 動態獲取根目錄 */
     $this->rootUrl = $this->request->getRequestRoot();
     if (defined('__TYPECHO_ADMIN__')) {
         $adminDir = '/' . trim(defined('__TYPECHO_ADMIN_DIR__') ? __TYPECHO_ADMIN_DIR__ : '/admin/', '/');
         $this->rootUrl = substr($this->rootUrl, 0, -strlen($adminDir));
     }
     /** 增加對SSL連接的支持 */
     if ($this->request->isSecure() && 0 === strpos($this->siteUrl, 'http://')) {
         $this->siteUrl = substr_replace($this->siteUrl, 'https', 0, 4);
     }
     //$router = include __TYPECHO_ROOT_DIR__.'/var/config.php';
     //$parser = new Typecho_Router_Parser($router);
     //$parsedRoutingTable = $parser->parse();
     //$this->routingTable = array($parsedRoutingTable);
     /** 自動初始化路由表 */
     $this->routingTable = unserialize($this->routingTable);
     if (!isset($this->routingTable[0])) {
         /** 解析路由並緩存 */
         $parser = new Typecho_Router_Parser($this->routingTable);
         $parsedRoutingTable = $parser->parse();
         $this->routingTable = array_merge(array($parsedRoutingTable), $this->routingTable);
         $this->db->query($this->db->update('table.options')->rows(array('value' => serialize($this->routingTable)))->where('name = ?', 'routingTable'));
     }
 }
開發者ID:veryer,項目名稱:sisome,代碼行數:52,代碼來源:Options.php

示例5: login

 /**
  * 以用戶名和密碼登錄
  *
  * @access public
  * @param string $name 用戶名
  * @param string $password 密碼
  * @param boolean $temporarily 是否為臨時登錄
  * @param integer $expire 過期時間
  * @return boolean
  */
 public function login($name, $password, $temporarily = false, $expire = 0)
 {
     //插件接口
     $result = $this->pluginHandle()->trigger($loginPluggable)->login($name, $password, $temporarily, $expire);
     if ($loginPluggable) {
         return $result;
     }
     /** 開始驗證用戶 **/
     $user = $this->db->fetchRow($this->db->select()->from('table.users')->where((strpos($name, '@') ? 'mail' : 'name') . ' = ?', $name)->limit(1));
     if (empty($user)) {
         return false;
     }
     $hashValidate = $this->pluginHandle()->trigger($hashPluggable)->hashValidate($password, $user['password']);
     if (!$hashPluggable) {
         if ('$P$' == substr($user['password'], 0, 3)) {
             $hasher = new PasswordHash(8, true);
             $hashValidate = $hasher->CheckPassword($password, $user['password']);
         } else {
             $hashValidate = Typecho_Common::hashValidate($password, $user['password']);
         }
     }
     if ($user && $hashValidate) {
         if (!$temporarily) {
             $authCode = function_exists('openssl_random_pseudo_bytes') ? bin2hex(openssl_random_pseudo_bytes(16)) : sha1(Typecho_Common::randString(20));
             $user['authCode'] = $authCode;
             Typecho_Cookie::set('__typecho_uid', $user['uid'], $expire);
             Typecho_Cookie::set('__typecho_authCode', Typecho_Common::hash($authCode), $expire);
             //更新最後登錄時間以及驗證碼
             $this->db->query($this->db->update('table.users')->expression('logged', 'activated')->rows(array('authCode' => $authCode))->where('uid = ?', $user['uid']));
         }
         /** 壓入數據 */
         $this->push($user);
         $this->_hasLogin = true;
         $this->pluginHandle()->loginSucceed($this, $name, $password, $temporarily, $expire);
         return true;
     }
     $this->pluginHandle()->loginFail($this, $name, $password, $temporarily, $expire);
     return false;
 }
開發者ID:r0ker,項目名稱:hctf2015-all-problems,代碼行數:49,代碼來源:User.php

示例6: v0_8r10_2_27

 /**
  * 升級至10.2.27
  *
  * @access public
  * @param Typecho_Db $db 數據庫對象
  * @param Typecho_Widget $options 全局信息組件
  * @return void
  */
 public static function v0_8r10_2_27($db, $options)
 {
     /** 增加若幹選項 */
     $db->query($db->insert('table.options')->rows(array('name' => 'commentsAvatar', 'user' => 0, 'value' => 1)));
     $db->query($db->insert('table.options')->rows(array('name' => 'commentsAvatarRating', 'user' => 0, 'value' => 'G')));
     //更新擴展
     if (NULL != $options->attachmentTypes) {
         $attachmentTypes = array_map('trim', explode(';', $options->attachmentTypes));
         $attachmentTypesResult = array();
         foreach ($attachmentTypes as $type) {
             $type = trim($type, '*.');
             if (!empty($type)) {
                 $attachmentTypesResult[] = $type;
             }
         }
         if (!empty($attachmentTypesResult)) {
             $db->query($db->update('table.options')->rows(array('value' => implode(',', $attachmentTypesResult)))->where('name = ?', 'attachmentTypes'));
         }
     }
 }
開發者ID:menmenweiwei,項目名稱:blog,代碼行數:28,代碼來源:Upgrade.php

示例7: array

             $dbPrefix = $config['prefix'];
             $tableArray = array($dbPrefix . 'comments', $dbPrefix . 'contents', $dbPrefix . 'fields', $dbPrefix . 'metas', $dbPrefix . 'options', $dbPrefix . 'relationships', $dbPrefix . 'users');
             foreach ($tableArray as $table) {
                 if ($type == 'Mysql') {
                     $installDb->query("DROP TABLE IF EXISTS `{$table}`");
                 } elseif ($type == 'Pgsql') {
                     $installDb->query("DROP TABLE {$table}");
                 } elseif ($type == 'SQLite') {
                     $installDb->query("DROP TABLE {$table}");
                 }
             }
             echo '<p class="message success">' . _t('已經刪除完原有數據') . '<br /><br /><button type="submit" class="primary">' . _t('繼續安裝 &raquo;') . '</button></p>';
         } elseif (_r('goahead')) {
             //使用原有數據
             //但是要更新用戶網站
             $installDb->query($installDb->update('table.options')->rows(array('value' => $config['siteUrl']))->where('name = ?', 'siteUrl'));
             unset($_SESSION['typecho']);
             Typecho_Cookie::delete('__typecho_config');
             header('Location: ./install.php?finish&use_old');
             exit;
         } else {
             echo '<p class="message error">' . _t('安裝程序檢查到原有數據表已經存在.') . '<br /><br />' . '<button type="submit" name="delete" value="1" class="btn-warn">' . _t('刪除原有數據') . '</button> ' . _t('或者') . ' <button type="submit" name="goahead" value="1" class="primary">' . _t('使用原有數據') . '</button></p>';
         }
     } else {
         echo '<p class="message error">' . _t('安裝程序捕捉到以下錯誤: "%s". 程序被終止, 請檢查您的配置信息.', $e->getMessage()) . '</p>';
     }
     ?>
             </form>
         </div>
                                 <?php 
 }
開發者ID:menmenweiwei,項目名稱:blog,代碼行數:31,代碼來源:install.php

示例8: array

                     $dbPrefix = _r('dbPrefix');
                     $tableArray = array($dbPrefix . 'comments', $dbPrefix . 'contents', $dbPrefix . 'metas', $dbPrefix . 'options', $dbPrefix . 'relationships', $dbPrefix . 'users');
                     foreach ($tableArray as $table) {
                         if ($type == 'Mysql') {
                             $installDb->query("DROP TABLE IF EXISTS `{$table}`");
                         } elseif ($type == 'Pgsql') {
                             $installDb->query("DROP TABLE {$table}");
                         } elseif ($type == 'SQLite') {
                             $installDb->query("DROP TABLE {$table}");
                         }
                     }
                     echo '<p class="message success typecho-radius-topleft typecho-radius-topright typecho-radius-bottomleft typecho-radius-bottomright">已經刪除完原有數據,請點擊繼續安裝<button type="submit">下一步</button></p>';
                 } elseif (_r('goahead')) {
                     //使用原有數據
                     //但是要更新用戶網站
                     $installDb->query($installDb->update('table.options')->rows(array('value' => _r('userUrl')))->where('name = ?', 'siteUrl'));
                     header('Location: install.php?finish&use_old');
                     exit;
                 } else {
                     echo '<p class="message error typecho-radius-topleft typecho-radius-topright typecho-radius-bottomleft typecho-radius-bottomright">' . _t('安裝程序檢查到原有數據表已經存在,請先刪除該表然後再繼續進行安裝.') . '您可以選擇<button type="submit" name="delete" value="1">刪除數據原有數據</button>或者直接<button type="submit" name="goahead" value="1">使用原有數據</button>安裝</p>';
                 }
             } else {
                 echo '<p class="message error typecho-radius-topleft typecho-radius-topright typecho-radius-bottomleft typecho-radius-bottomright">' . _t('安裝程序捕捉到以下錯誤: "%s". 程序被終止, 請檢查您的配置信息.', $e->getMessage()) . '</p>';
             }
         }
     }
     if ($success != true && file_exists(__TYPECHO_ROOT_DIR__ . '/config.inc.php')) {
         unlink(__TYPECHO_ROOT_DIR__ . '/config.inc.php');
     }
 }
 ?>
開發者ID:raindali,項目名稱:express,代碼行數:31,代碼來源:install.php


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