亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

mysql數據庫連接程序

2024-09-04 11:44:16
字體:
來源:轉載
供稿:網友

這里提供的數據庫連接類程序,后面還提供了一個sql安全檢測函數與sql語句完整性檢測函數,實例代碼如下:

  1. class db_mysql { 
  2.  var $connid
  3.  var $querynum = 0; 
  4.  var $expires
  5.  var $cursor = 0; 
  6.  var $cache_id = '';  
  7.  var $cache_file = ''
  8.  var $cache_expires = ''
  9.  var $halt = 0; 
  10.  var $result = array(); 
  11.  
  12.  function connect($dbhost$dbuser$dbpw$dbname$pconnect = 0) { 
  13.   global $cfg
  14.   $this->expires = $cfg['db_expires']; 
  15.   $func = $pconnect == 1 ? 'mysql_pconnect' : 'mysql_connect'
  16.   if(!$this->connid = $func($dbhost$dbuser$dbpw)) { 
  17.    $this->halt('can not connect to mysql server'); 
  18.   } 
  19.   if($this->version() > '4.1' && $cfg['db_charset']) { 
  20.    mysql_query("set names '".$cfg['db_charset']."'" , $this->connid); 
  21.   } 
  22.   if($this->version() > '5.0') { 
  23.    mysql_query("set sql_mode=''" , $this->connid); 
  24.   } 
  25.   if($dbname) { 
  26.    if(!mysql_select_db($dbname , $this->connid)) { 
  27.     $this->halt('cannot use database '.$dbname); 
  28.    } 
  29.   } 
  30.   return $this->connid; 
  31.  } 
  32.  
  33.  function select_db($dbname) { 
  34.   return mysql_select_db($dbname , $this->connid); 
  35.  } 
  36.  
  37.  function query($sql , $type = ''$expires = 0, $save_id = false) { 
  38.         $sql=checksql($sql); 
  39.   if($type == 'cache' && stristr($sql'select')) { 
  40.    $this->cursor = 0; 
  41.    $this->cache_id = md5($sql); 
  42.    $this->result = array(); 
  43.    $this->cache_expires = $expires ? $expires + mt_rand(-9, 9) : $this->expires; 
  44.    return $this->_query($sql); 
  45.   } 
  46.   if(!$save_id$this->cache_id = 0; 
  47.   $func = $type == 'unbuffered' ? 'mysql_unbuffered_query' : 'mysql_query'
  48.   if(!($query = $func($sql , $this->connid)) && $this->halt) { 
  49.    $this->halt('mysql query error'$sql); 
  50.   } 
  51.   $this->querynum++; 
  52.   return $query
  53.  } 
  54.  
  55.  function get_one($sql$type = ''$expires = 0) { 
  56.   $query = $this->query($sql$type$expires); 
  57.   $r = $this->fetch_array($query); 
  58.   $this->free_result($query); 
  59.   return $r ; 
  60.  } 
  61.   
  62.  function counter($table$condition = ''$type = ''$expires = 0) { 
  63.   global $cfg
  64.   $table = strpos($table$cfg['tb_pre']) === false ? $cfg['tb_pre'].$table : $table
  65.   $sql = "select count(*) as num from {$table}"
  66.   if($condition$sql .= " where $condition"
  67.   $r = $this->get_one($sql$type$expires); 
  68.   return $r ? $r['num'] : 0; 
  69.  } 
  70.  
  71.  function fetch_array($query$result_type = mysql_assoc) { 
  72.   return $this->cache_id ? $this->_fetch_array($query) : @mysql_fetch_array($query$result_type); 
  73.  } 
  74.  
  75.  function affected_rows() { 
  76.   return mysql_affected_rows($this->connid); 
  77.  } 
  78.  
  79.  function num_rows($query) { 
  80.   return mysql_num_rows($query); 
  81.  } 
  82.  
  83.  function num_fields($query) { 
  84.   return mysql_num_fields($query); 
  85.  } 
  86.  function escape_string($str){ 
  87.   return mysql_escape_string($str); 
  88.  } 
  89.  function result($query$row) { 
  90.   return @mysql_result($query$row); 
  91.  } 
  92.  
  93.  function free_result($query) { 
  94.   return @mysql_free_result($query); 
  95.  } 
  96.  
  97.  function insert_id() { 
  98.   return mysql_insert_id($this->connid); 
  99.  } 
  100.  
  101.  function fetch_row($query) { 
  102.   return mysql_fetch_row($query); 
  103.  } 
  104.  
  105.  function version() { 
  106.   return mysql_get_server_info($this->connid); 
  107.  } 
  108.  
  109.  function close() { 
  110.   return mysql_close($this->connid); 
  111.  } 
  112.  
  113.  function error() { 
  114.   return @mysql_error($this->connid); 
  115.  } 
  116.  
  117.  function errno() { 
  118.   return intval(@mysql_errno($this->connid)) ; 
  119.  } 
  120.  
  121.  function halt($message = ''$sql = '') { 
  122.   global $cfg
  123.   if($message) { 
  124.    if($cfg['errlog']) { 
  125.     $log = "query:$sql|errno:".$this->errno()."|error:".$this->error()."|errmsg:$message"
  126.     log_write($log'sql'); 
  127.    } 
  128.   } 
  129.         showmsg("mysqlerror:$message",'-1'); 
  130.         exit(); 
  131.  } 
  132.  
  133.  function _query($sql) { 
  134.   global $fr_time
  135.   $this->cache_file = cache_root.'/sql/'.substr($this->cache_id, 0, 2).'/'.$this->cache_id.'.php教程'
  136.   if(!is_file($this->cache_file) || ($fr_time - @filemtime($this->cache_file) > $this->cache_expires)) { 
  137.    $tmp = array();  
  138.    $result = $this->query($sql'''', true); 
  139.    while($r = mysql_fetch_array($result, mysql_assoc)) { 
  140.     $tmp[] = $r;  
  141.    } 
  142.    $this->result = $tmp
  143.    $this->free_result($result); 
  144.    file_put($this->cache_file, "<?php /*".( $fr_time+$this->cache_expires)."*/ return ".var_export($this->result, true).";n?>"); 
  145.   } else { 
  146.       $this->result = include $this->cache_file; 
  147.   } 
  148.   return $this->result; 
  149.  } 
  150.  
  151.  function _fetch_array($query = array()) { 
  152.   if($query$this->result = $query;  
  153.   if(isset($this->result[$this->cursor])) { 
  154.    return $this->result[$this->cursor++]; 
  155.   } else { 
  156.    $this->cursor = $this->cache_id = 0; 
  157.    return array(); 
  158.   } 
  159.  } 
  160.  
  161. function checksql($dbstr,$querytype='select'){ 
  162.  $clean = ''
  163.  $old_pos = 0; 
  164.  $pos = -1; 
  165.  //普通語句,直接過濾特殊語法 
  166.  if($querytype=='select'){ 
  167.   $nastr = "/[^0-9a-z@._-]{1,}(union|sleep|benchmark|load_file|outfile)[^0-9a-z@.-]{1,}/i"
  168.   if(preg_match($nastr,$dbstr)){ 
  169.             log_write($dbstr,'sql'); 
  170.             showmsg('safeerror:10001''網頁特效:;'); 
  171.             exit(); 
  172.   } 
  173.  } 
  174.  //完整的sql檢查 
  175.  while (true){ 
  176.   $pos = strpos($dbstr''', $pos + 1); 
  177.   if ($pos === false){ 
  178.    break
  179.   } 
  180.   $clean .= substr($dbstr$old_pos$pos - $old_pos); 
  181.   while (true){ 
  182.    $pos1 = strpos($dbstr''', $pos + 1); 
  183.    $pos2 = strpos($dbstr''$pos + 1); 
  184.    if ($pos1 === false){ 
  185.     break
  186.    } 
  187.    elseif ($pos2 == false || $pos2 > $pos1){ 
  188.     $pos = $pos1
  189.     break
  190.    } 
  191.    $pos = $pos2 + 1; 
  192.   } 
  193.   $clean .= '$s$'
  194.   $old_pos = $pos + 1; 
  195.  } 
  196.  $clean .= substr($dbstr$old_pos); 
  197.  $clean = trim(strtolower(preg_replace(array('~s+~s' ), array(' '), $clean))); 
  198.  if (strpos($clean'union') !== false && preg_match('~(^|[^a-z])union($|[^[a-z])~s'$clean) != 0){ 
  199.   $fail = true; 
  200.  } 
  201.  elseif (strpos($clean'/*') > 2 || strpos($clean'--') !== false || strpos($clean'#') !== false){ 
  202.   $fail = true; 
  203.  } 
  204.  elseif (strpos($clean'sleep') !== false && preg_match('~(^|[^a-z])sleep($|[^[a-z])~s'$clean) != 0){ 
  205.   $fail = true; 
  206.  } 
  207.  elseif (strpos($clean'benchmark') !== false && preg_match('~(^|[^a-z])benchmark($|[^[a-z])~s'$clean) != 0){ 
  208.   $fail = true; 
  209.  } 
  210.  elseif (strpos($clean'load_file') !== false && preg_match('~(^|[^a-z])load_file($|[^[a-z])~s'$clean) != 0){ 
  211.   $fail = true; 
  212.  } 
  213.  elseif (strpos($clean'into outfile') !== false && preg_match('~(^|[^a-z])intos+outfile($|[^[a-z])~s'$clean) != 0){ 
  214.   $fail = true; 
  215.  } 
  216.  elseif (preg_match('~([^)]*?select~s'$clean) != 0){ 
  217.   $fail = true; 
  218.  } 
  219.  if (!emptyempty($fail)){ 
  220.         log_write($dbstr,'sql'); 
  221.         showmsg('safeerror:10002''javascript:;');exit
  222.  }//開源代碼Vevb.com 
  223.  else 
  224.  { 
  225.   return $dbstr
  226.  } 
  227. }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久久国产精品| 成人免费大片黄在线播放| 国产精品夫妻激情| 欧美二区乱c黑人| 国产精品三级美女白浆呻吟| 亚洲精品综合久久中文字幕| 国产成人+综合亚洲+天堂| 精品视频偷偷看在线观看| 国产精品久久久久久av下载红粉| 69av在线视频| 欧美视频在线看| 国产成人久久久精品一区| 欧美性理论片在线观看片免费| wwwwwwww亚洲| 久久69精品久久久久久久电影好| 日韩精品亚洲视频| 欧美国产中文字幕| 国产精品爽爽爽| 欧美性极品xxxx做受| www.日韩视频| 亚洲人成网在线播放| 国产99久久久欧美黑人| 日韩精品在线观看视频| 久久成人av网站| 欧美性生交大片免网| 欧美日韩国产精品| 日韩二区三区在线| 秋霞午夜一区二区| 精品人伦一区二区三区蜜桃免费| 菠萝蜜影院一区二区免费| 美女黄色丝袜一区| 久久久成人精品| 欧美极品美女电影一区| 一区二区三区回区在观看免费视频| 亚洲高清久久久久久| 美女性感视频久久久| 精品国产欧美一区二区三区成人| 成人美女av在线直播| 国产一区二区黑人欧美xxxx| 国产伦精品免费视频| 久久久久久网站| 亚洲男人天堂九九视频| 欧美丰满少妇xxxxx| 色综合久久天天综线观看| 亚洲国产精品人久久电影| 伊人成人开心激情综合网| 成人伊人精品色xxxx视频| 日韩成人中文电影| 久久乐国产精品| 亚洲欧洲中文天堂| 亚洲欧美日韩精品| 欧美限制级电影在线观看| 国产精品成人观看视频国产奇米| 亚洲精品电影在线观看| 欧美日韩中文字幕综合视频| 成人深夜直播免费观看| 亚洲欧洲xxxx| 亚洲欧美国产一区二区三区| 色www亚洲国产张柏芝| 国内精品在线一区| 欧美大片在线影院| 国产美女扒开尿口久久久| 亚洲男人av在线| 欧美二区乱c黑人| 96sao精品视频在线观看| 亚洲最新中文字幕| 国产精品美女久久| 亚洲国产精品久久| 18一19gay欧美视频网站| 91久久嫩草影院一区二区| 5566日本婷婷色中文字幕97| 欧美激情国产精品| 欧美色视频日本版| 久久久之久亚州精品露出| 欧美日韩国产精品一区| 国产免费成人av| 色视频www在线播放国产成人| 久久婷婷国产麻豆91天堂| 精品国产成人在线| 亚洲精品第一页| 日韩精品有码在线观看| 欧美激情啊啊啊| 91地址最新发布| 岛国视频午夜一区免费在线观看| 国产精品成人观看视频国产奇米| 亚洲电影免费观看高清完整版在线观看| 国内免费精品永久在线视频| 欧洲成人在线视频| 日韩av一区二区在线观看| 欧美日韩在线视频一区| www.亚洲成人| 色综合久久精品亚洲国产| 91av视频在线免费观看| 在线看日韩av| 国产精品高潮呻吟久久av黑人| 亚洲理论在线a中文字幕| 国产国语刺激对白av不卡| 欧美激情乱人伦一区| 国产精品视频一区国模私拍| 久久香蕉国产线看观看av| 精品无码久久久久久国产| 欧美夫妻性生活视频| 精品亚洲国产成av人片传媒| 日韩av网站电影| 亚洲精品美女久久久| 91成人国产在线观看| 亚洲成人av在线| 欧美国产亚洲精品久久久8v| 日韩经典一区二区三区| 尤物九九久久国产精品的分类| 亚洲一级一级97网| 久久久精品欧美| 91在线无精精品一区二区| 久热精品视频在线观看一区| 亚洲va欧美va国产综合久久| 国产精品狼人色视频一区| 久久久噜噜噜久久| 亚洲а∨天堂久久精品9966| 日韩精品视频观看| 欧美精品免费播放| 日韩不卡中文字幕| 岛国视频午夜一区免费在线观看| 日韩av电影中文字幕| 欧美激情视频免费观看| 26uuu亚洲国产精品| 日韩小视频在线观看| 欧美性高潮床叫视频| 久久久久久中文| 日韩中文字幕在线观看| 欧美激情一级二级| 色狠狠久久aa北条麻妃| 夜夜嗨av色综合久久久综合网| 国产精品com| 欧美另类69精品久久久久9999| 日韩男女性生活视频| 久久视频在线免费观看| 亚洲香蕉成视频在线观看| 久久亚洲精品毛片| 欧美性猛交xxxxx免费看| 久久久这里只有精品视频| 亚洲国产精品成人一区二区| 国产精品久久久久久久久久尿| 亚洲欧洲美洲在线综合| 欧美精品www在线观看| 欧美一级大片视频| 亚洲人成免费电影| 91精品国产综合久久久久久久久| 国产精品久久色| 精品国产1区2区| 久久91亚洲人成电影网站| 色婷婷综合久久久久中文字幕1| 日韩中文字幕在线播放| 国产精品久久久av久久久| 91热福利电影| 亚洲欧美日韩在线高清直播| 国产一区二区三区在线视频| 国产精品电影久久久久电影网| 一个人看的www久久| 日韩av理论片| 啊v视频在线一区二区三区| 亚洲成人av片| 久久这里有精品视频| 91久久久久久国产精品| 欧美日韩国产va另类|