亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? adodb.php

?? 一個bug追蹤工具的PHP編寫的源代碼
?? PHP
字號:
<?php//// +----------------------------------------------------------------------+// | PHP Version 4                                                        |// +----------------------------------------------------------------------+// |                                                                      |// +----------------------------------------------------------------------+// | This source file is subject to version 2.02 of the PHP license,      |// | that is bundled with this package in the file LICENSE, and is        |// | available at through the world-wide-web at                           |// | http://www.php.net/license/2_02.txt.                                 |// | If you did not receive a copy of the PHP license and are unable to   |// | obtain it through the world-wide-web, please send a note to          |// | license@php.net so we can mail you a copy immediately.               |// +----------------------------------------------------------------------+// | Authors: Martin Jansen <mj@php.net>// |	Richard Tango-Lowy <richtl@arscognita.com>                                  |// +----------------------------------------------------------------------+//// $Id: ADOdb.php,v 1.3 2005/02/12 20:01:28 jlatour Exp $//require_once 'Auth/Container.php';require_once 'adodb.inc.php';require_once 'adodb-pear.inc.php';require_once 'adodb-errorpear.inc.php';/** * Storage driver for fetching login data from a database using ADOdb-PHP. * * This storage driver can use all databases which are supported * by the ADBdb DB abstraction layer to fetch login data. * See http://php.weblogs.com/adodb for information on ADOdb. * NOTE: The ADOdb directory MUST be in your PHP include_path! * * @author   Richard Tango-Lowy <richtl@arscognita.com> * @package  Auth * @version  $Revision: 1.3 $ */class Auth_Container_ADOdb extends Auth_Container{    /**     * Additional options for the storage container     * @var array     */    var $options = array();    /**     * DB object     * @var object     */    var $db = null;    var $dsn = '';    /**     * User that is currently selected from the DB.     * @var string     */    var $activeUser = '';    // {{{ Constructor    /**     * Constructor of the container class     *     * Initate connection to the database via PEAR::ADOdb     *     * @param  string Connection data or DB object     * @return object Returns an error object if something went wrong     */    function Auth_Container_ADOdb($dsn)    {        $this->_setDefaults();        if (is_array($dsn)) {            $this->_parseOptions($dsn);            if (empty($this->options['dsn'])) {                PEAR::raiseError('No connection parameters specified!');            }        } else {        	// Extract db_type from dsn string.            $this->options['dsn'] = $dsn;            $this->_parseDsn( $dsn );        }    }    // }}}    // {{{ _connect()    /**     * Connect to database by using the given DSN string     *     * @access private     * @param  string DSN string     * @return mixed  Object on error, otherwise bool     */     function _connect($dsn)    {        if (is_string($dsn) || is_array($dsn)) {        	if(!$this->db) {	        	$this->db = &ADONewConnection($this->options['db_type']);	    		if( $err = ADODB_Pear_error() ) {	   	    		return PEAR::raiseError($err);	    		}        	}        	$dbconnected = $this->db->Connect(        		$this->options['db_host'],        		$this->options['db_user'],        		$this->options['db_pass'],        		$this->options['db_name'] );        	if( !$dbconnected ) {        		PEAR::raiseError('Unable to connect to database' );        	}        } else {            return PEAR::raiseError('The given dsn was not valid in file ' . __FILE__ . ' at line ' . __LINE__,                                    41,                                    PEAR_ERROR_RETURN,                                    null,                                    null                                    );        }        if(!$this->db) {        	return PEAR::raiseError(ADODB_Pear_error());        } else {        	return true;        }    }    // }}}    // {{{ _prepare()    /**     * Prepare database connection     *     * This function checks if we have already opened a connection to     * the database. If that's not the case, a new connection is opened.     *     * @access private     * @return mixed True or a DB error object.     */    function _prepare()    {    	if(!$this->db) {    		$res = $this->_connect($this->options['dsn']);    	}        return true;    }    // }}}    // {{{ query()    /**     * Prepare query to the database     *     * This function checks if we have already opened a connection to     * the database. If that's not the case, a new connection is opened.     * After that the query is passed to the database.     *     * @access public     * @param  string Query string     * @return mixed  a DB_result object or DB_OK on success, a DB     *                or PEAR error on failure     */    function query($query)    {        $err = $this->_prepare();        if ($err !== true) {            return $err;        }        return $this->db->query($query);    }    // }}}    // {{{ _setDefaults()    /**     * Set some default options     *     * @access private     * @return void     */    function _setDefaults()    {    	$this->options['db_type']	= 'mysql';        $this->options['table']       = 'auth';        $this->options['usernamecol'] = 'username';        $this->options['passwordcol'] = 'password';        $this->options['dsn']         = '';        $this->options['db_fields']   = '';        $this->options['cryptType']   = 'md5';    }    // }}}    // {{{ _parseOptions()    /**     * Parse options passed to the container class     *     * @access private     * @param  array     */    function _parseOptions($array)    {        foreach ($array as $key => $value) {            if (isset($this->options[$key])) {                $this->options[$key] = $value;            }        }        /* Include additional fields if they exist */        if(!empty($this->options['db_fields'])){            if(is_array($this->options['db_fields'])){                $this->options['db_fields'] = join($this->options['db_fields'], ', ');            }            $this->options['db_fields'] = ', '.$this->options['db_fields'];        }    }    // }}}    // {{{ fetchData()    /**     * Get user information from database     *     * This function uses the given username to fetch     * the corresponding login data from the database     * table. If an account that matches the passed username     * and password is found, the function returns true.     * Otherwise it returns false.     *     * @param   string Username     * @param   string Password     * @return  mixed  Error object or boolean     */    function fetchData($username, $password)    {        // Prepare for a database query        $err = $this->_prepare();        if ($err !== true) {            return PEAR::raiseError($err->getMessage(), $err->getCode());        }        // Find if db_fields contains a *, i so assume all col are selected        if(strstr($this->options['db_fields'], '*')){            $sql_from = "*";        }        else{            $sql_from = $this->options['usernamecol'] . ", ".$this->options['passwordcol'].$this->options['db_fields'];        }        $query = "SELECT ".$sql_from.                " FROM ".$this->options['table'].                " WHERE ".$this->options['usernamecol']." = " . $this->db->Quote($username);        $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;        $rset = $this->db->Execute( $query );        $res = $rset->fetchRow();        if (DB::isError($res)) {            return PEAR::raiseError($res->getMessage(), $res->getCode());        }        if (!is_array($res)) {            $this->activeUser = '';            return false;        }        if ($this->verifyPassword(trim($password, "\r\n"),                                  trim($res[$this->options['passwordcol']], "\r\n"),                                  $this->options['cryptType'])) {            // Store additional field values in the session            foreach ($res as $key => $value) {                if ($key == $this->options['passwordcol'] ||                    $key == $this->options['usernamecol']) {                    continue;                }                // Use reference to the auth object if exists                // This is because the auth session variable can change so a static call to setAuthData does not make sence                if(is_object($this->_auth_obj)){                    $this->_auth_obj->setAuthData($key, $value);                } else {                    Auth::setAuthData($key, $value);                }            }            return true;        }        $this->activeUser = $res[$this->options['usernamecol']];        return false;    }    // }}}    // {{{ listUsers()    function listUsers()    {        $err = $this->_prepare();        if ($err !== true) {            return PEAR::raiseError($err->getMessage(), $err->getCode());        }        $retVal = array();        // Find if db_fileds contains a *, i so assume all col are selected        if(strstr($this->options['db_fields'], '*')){            $sql_from = "*";        }        else{            $sql_from = $this->options['usernamecol'] . ", ".$this->options['passwordcol'].$this->options['db_fields'];        }        $query = sprintf("SELECT %s FROM %s",                         $sql_from,                         $this->options['table']                         );        $res = $this->db->getAll($query, null, DB_FETCHMODE_ASSOC);        if (DB::isError($res)) {            return PEAR::raiseError($res->getMessage(), $res->getCode());        } else {            foreach ($res as $user) {                $user['username'] = $user[$this->options['usernamecol']];                $retVal[] = $user;            }        }        return $retVal;    }    // }}}    // {{{ addUser()    /**     * Add user to the storage container     *     * @access public     * @param  string Username     * @param  string Password     * @param  mixed  Additional information that are stored in the DB     *     * @return mixed True on success, otherwise error object     */    function addUser($username, $password, $additional = "")    {        if (function_exists($this->options['cryptType'])) {            $cryptFunction = $this->options['cryptType'];        } else {            $cryptFunction = 'md5';        }        $additional_key   = '';        $additional_value = '';        if (is_array($additional)) {            foreach ($additional as $key => $value) {                $additional_key .= ', ' . $key;                $additional_value .= ", '" . $value . "'";            }        }        $query = sprintf("INSERT INTO %s (%s, %s%s) VALUES ('%s', '%s'%s)",                         $this->options['table'],                         $this->options['usernamecol'],                         $this->options['passwordcol'],                         $additional_key,                         $username,                         $cryptFunction($password),                         $additional_value                         );        $res = $this->query($query);        if (DB::isError($res)) {           return PEAR::raiseError($res->getMessage(), $res->getCode());        } else {          return true;        }    }    // }}}    // {{{ removeUser()    /**     * Remove user from the storage container     *     * @access public     * @param  string Username     *     * @return mixed True on success, otherwise error object     */    function removeUser($username)    {        $query = sprintf("DELETE FROM %s WHERE %s = '%s'",                         $this->options['table'],                         $this->options['usernamecol'],                         $username                         );        $res = $this->query($query);        if (DB::isError($res)) {           return PEAR::raiseError($res->getMessage(), $res->getCode());        } else {          return true;        }    }    // }}}	function _parseDsn( $dsn )	{		if( is_string( $dsn )) {			preg_match( '/^(\w*):\/\/(\w*)(:(\w*))?@(\w*)\/(\w*)$/', $dsn, $match );			$this->options['db_type'] = $match[1];			$this->options['db_user'] = $match[2];			$this->options['db_pass'] = $match[3];			$this->options['db_host'] = $match[5];			$this->options['db_name'] = $match[6];		}	}}function showDbg( $string ) {	print "<P>$string</P>";}function dump( $var, $str, $vardump = false ) {	print "<H4>$str</H4><pre>";	( !$vardump ) ? ( print_r( $var )) : ( var_dump( $var ));	print "</pre>";}?>

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本不卡中文字幕| 一本一本大道香蕉久在线精品| 欧美日韩亚洲综合| 亚洲韩国精品一区| 欧美欧美午夜aⅴ在线观看| 日韩精品电影在线观看| 欧美日韩精品专区| 久久国产精品色| 国产网红主播福利一区二区| 成人午夜精品一区二区三区| 国产精品毛片久久久久久久| 在线日韩国产精品| 日本伊人色综合网| 国产欧美日韩亚州综合| 成人免费av在线| 一区二区三区久久久| 91麻豆精品国产自产在线| 黄一区二区三区| 国产精品久久久久久久久快鸭 | 9久草视频在线视频精品| 亚洲四区在线观看| 91精品欧美一区二区三区综合在| 激情都市一区二区| 一区二区三区在线视频播放| 日韩欧美国产精品| 99这里都是精品| 奇米影视一区二区三区| 国产精品女同一区二区三区| 在线观看视频一区二区| 国产一区二区三区四| 亚洲精品国产无天堂网2021| 日韩欧美精品三级| 91麻豆123| 国产综合久久久久久鬼色| 亚洲与欧洲av电影| 久久久久久9999| 91麻豆精品国产无毒不卡在线观看| 成人在线一区二区三区| 肉肉av福利一精品导航| 国产精品久久精品日日| 日韩一区二区三区av| a4yy欧美一区二区三区| 国产一区二区三区电影在线观看| 亚洲综合丝袜美腿| 国产精品美女久久福利网站| 欧美一级日韩不卡播放免费| 91亚洲精品乱码久久久久久蜜桃| 久久99热这里只有精品| 亚洲黄色录像片| 亚洲国产高清在线观看视频| 91精品国产综合久久精品图片| 99re成人精品视频| 国产一区亚洲一区| 精品制服美女丁香| 日韩精品久久理论片| 一区二区三区成人| 亚洲欧洲日韩一区二区三区| 2022国产精品视频| 欧美一区二区三区性视频| 欧美少妇一区二区| 91蜜桃免费观看视频| 国产美女一区二区| 精品午夜一区二区三区在线观看| 天天色 色综合| 午夜亚洲福利老司机| 一区二区在线观看免费| 亚洲精品欧美专区| 又紧又大又爽精品一区二区| 中文字幕一区二区三区在线观看| 中文一区二区在线观看| 国产网站一区二区| 久久久精品影视| 国产亚洲女人久久久久毛片| 久久久久久久久久电影| 久久久久久免费网| 国产日韩欧美电影| 国产视频一区二区在线| 亚洲国产精品二十页| 国产欧美一区二区精品婷婷 | 成人动漫av在线| 成人三级伦理片| 成人免费高清在线| 国产91丝袜在线播放| 成人亚洲一区二区一| 成人午夜在线视频| www.日韩在线| 99re这里都是精品| 欧美在线你懂得| 91精品国产综合久久国产大片| 这里只有精品视频在线观看| 日韩欧美黄色影院| 久久精品一区二区三区不卡牛牛| 日本一区二区三区电影| 最近中文字幕一区二区三区| 一区二区三区四区国产精品| 亚洲成人动漫av| 久久国产精品99久久人人澡| 国产高清精品久久久久| 91麻豆高清视频| 91精品国产91久久久久久一区二区 | 久久久亚洲午夜电影| 国产欧美日本一区视频| 日韩美女精品在线| 亚洲丰满少妇videoshd| 韩国成人精品a∨在线观看| eeuss国产一区二区三区| 欧美亚洲动漫制服丝袜| 欧美成人a∨高清免费观看| 中文字幕精品一区二区精品绿巨人 | 精品三级在线观看| 中文字幕久久午夜不卡| 亚洲国产另类av| 国产一区福利在线| 91片黄在线观看| 日韩亚洲欧美高清| 日韩美女视频一区二区 | 久久久精品蜜桃| 一区二区日韩av| 精品亚洲成av人在线观看| 91热门视频在线观看| 日韩免费高清av| 一区二区三区精品| 国产尤物一区二区| 欧美绝品在线观看成人午夜影视| 久久久久久久久蜜桃| 婷婷中文字幕一区三区| 国产成人综合精品三级| 91精品国产高清一区二区三区| 国产清纯在线一区二区www| 天堂一区二区在线| 91丨porny丨国产| 欧美精品一区二区三区蜜臀| 亚洲图片欧美综合| av在线不卡免费看| 欧美大胆一级视频| 亚洲国产日韩精品| 成人国产一区二区三区精品| 91精品黄色片免费大全| 亚洲精品v日韩精品| 国产不卡在线视频| 欧美大黄免费观看| 日韩福利电影在线| 色噜噜狠狠色综合中国| 国产丝袜欧美中文另类| 日韩国产高清影视| 欧美色综合影院| 亚洲综合一区二区三区| 91视频免费播放| 中文字幕一区av| 成人福利电影精品一区二区在线观看| 日韩一级片网址| 日韩中文字幕亚洲一区二区va在线| 99国产精品久久久久| 国产三级欧美三级日产三级99| 狠狠色综合日日| 欧美v亚洲v综合ⅴ国产v| 国产黄色精品网站| 欧美精品一区男女天堂| 麻豆91精品91久久久的内涵| 欧美精品自拍偷拍| 午夜精品久久久久久久99水蜜桃| 一本久久精品一区二区| 亚洲人成网站在线| 91丨九色丨蝌蚪富婆spa| 亚洲图片另类小说| eeuss鲁一区二区三区| 国产欧美日本一区视频| 国产精品66部| 久久久久久**毛片大全| 蜜臀a∨国产成人精品| 日韩精品一区二区三区蜜臀| 日韩精品乱码免费| 欧美三级视频在线观看| 亚洲成人综合视频| 日本国产一区二区| 一区二区三区在线免费视频| 精久久久久久久久久久| 精品国产sm最大网站免费看| 日韩激情一二三区| 91精品国产入口在线| 亚洲乱码国产乱码精品精小说 | 国产精品99久久久久久久女警| 久久香蕉国产线看观看99| 麻豆91精品91久久久的内涵| 日韩欧美在线影院| 亚洲精品国产品国语在线app| 欧美性高清videossexo| 亚洲综合成人在线| 欧美日韩国产一级片| 久久国产麻豆精品| 久久久久国产精品麻豆ai换脸 | 久久精品亚洲精品国产欧美| 国产一区免费电影| 国产欧美一区二区三区网站| 国产成人小视频| 国产精品国产成人国产三级| 成人综合激情网| 亚洲激情av在线| 欧美xxx久久| 国产成人av电影|