目次
php代码    

数据库操作类

May 25, 2016 pm 05:14 PM
php

php代码    

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

210

211

212

213

214

215

216

217

218

219

220

221

222

223

224

225

226

227

228

229

230

231

232

233

234

235

236

237

238

239

240

241

242

243

244

245

246

247

248

249

250

251

252

253

254

255

256

257

258

259

260

261

262

263

264

265

266

267

268

269

270

271

272

273

274

275

276

277

278

279

280

281

282

283

284

285

286

287

288

289

290

291

292

293

294

295

296

297

298

299

300

301

302

303

304

305

306

307

308

309

310

311

312

313

314

315

316

317

318

319

320

321

322

323

324

325

326

327

328

329

330

331

332

333

334

335

336

337

338

339

340

341

342

343

344

345

346

347

348

349

350

351

352

353

354

355

356

357

358

359

360

361

362

363

364

365

366

367

368

369

370

371

372

373

374

375

376

377

<?php

/*

 * 数据库操作类

 *

 */

 

 

class Mysql {

    private $server = "";

    private $user = "";

    private $password = "";

    private $database = "";

    private $linkMode = 1;

    private $link_id = 0;

    private $query_id = 0;

    private $query_times = 0;

    private $result = array ();

    private $fetchMode = MYSQL_ASSOC;

    private $err_no = 0;

    private $err_msg;

    private $character;

    //======================================

    // 函数: mysql()

    // 功能: 构造函数

    // 参数: 参数类的变量定义

    // 说明: 构造函数将自动连接数据库

    // 如果想手动连接去掉自动连接函数

    //======================================

    public function __construct($server, $user, $password, $database, $character = "UTF8", $linkMode = 0) {

        if (empty ( $server ) || empty ( $user ) || empty ( $database ))

            $this->halt ( "提交的数据库信息不完整!请检查服务器地址,用户和数据库是否正确有效" );

          

        $this->server = $server;

        $this->user = $user;

        $this->password = $password;

        $this->database = $database;

        $this->linkMode = $linkMode;

        $this->character = $character;

        $this->connect ();

    }

    //======================================

    // 函数: connect($server,$user,$password,$database)

    // 功能: 连接数据库

    // 参数: $server 主机名, $user 用户名

    // 参数: $password 密码, $database 数据库名称

    // 返回: 0:失败

    // 说明: 默认使用类中变量的初始值

    //======================================

    public function connect($server = "", $user = "", $password = "", $database = "") {

        $server = $server ? $server : $this->server;

        $user = $user ? $user : $this->user;

        $password = $password ? $password : $this->password;

        $database = $database ? $database : $this->database;

          

        $this->link_id = $this->linkMode ? mysql_pconnect ( $server, $user, $password, $database ) : mysql_connect ( $server, $user, $password, $database );

          

        if (! $this->link_id) {

            $this->halt ( "数据库连接失败!请检查各项参数!" );

            return 0;

        }

          

        if (! mysql_select_db ( $database, $this->link_id )) {

            $this->halt ( "无法选择数据库" );

            return 0;

        }

          

        if ($this->character != "GBK" && $this->character != "UTF8") {

            $this->halt ( "输入的编码模式不正确!" );

            return 0;

        }

          

        $this->query ( &#39;SET NAMES &#39; . $this->character );

        return $this->link_id;

    }

    //======================================

    // 函数: query($sql)

    // 功能: 数据查询

    // 参数: $sql 要查询的SQL语句

    // 返回: 0:失败

    //======================================

    public function query($sql) {

        $this->query_times ++;

        $this->query_id = mysql_query ( $sql, $this->link_id );

        if (! $this->query_id) {

            $this->halt ( "<font color=red>" . $sql . "</font> 语句执行不成功!" );

            return 0;

        }

          

        return $this->query_id;

    }

    //======================================

    // 函数: setFetchMode($mode)

    // 功能: 设置取得记录的模式

    // 参数: $mode 模式 MYSQL_ASSOC, MYSQL_NUM, MYSQL_BOTH

    // 返回: 0:失败

    //======================================

    public function setFetchMode($mode) {

        if ($mode == MYSQL_ASSOC || $mode == MYSQL_NUM || $mode == MYSQL_BOTH) {

            $this->fetchMode = $mode;

            return 1;

        } else {

            $this->halt ( "错误的模式." );

            return 0;

        }

    }

    //======================================

    // 函数: fetchRow()

    // 功能: 从记录集中取出一条记录

    // 返回: 0: 出错 record: 一条记录

    //======================================

    public function fetchRow() {

        $this->record = mysql_fetch_array ( $this->query_id, $this->fetchMode );

          

        return $this->record;

    }

    //======================================

    // 函数: fetchAll()

    // 功能: 从记录集中取出所有记录

    // 返回: 记录集数组

    //======================================

    public function fetchAll() {

        $arr [] = array ();

          

        while ( $this->record = mysql_fetch_array ( $this->query_id, $this->fetchMode ) )

            $arr [] = $this->record;

          

        mysql_free_result ( $this->query_id );

        return $arr;

    }

    //======================================

    // 函数: getValue()

    // 功能: 返回记录中指定字段的数据

    // 参数: $field 字段名或字段索引

    // 返回: 指定字段的值

    //======================================

    public function getValue($filed) {

        return $this->record [$filed];

    }

    //======================================

    // 函数: getquery_id()

    // 功能: 返回查询号

    //======================================    

    public function getquery_id() {

        return $this->query_id;

    }

    //======================================

    // 函数: affectedRows()

    // 功能: 返回影响的记录数

    //======================================    

    public function affectedRows() {

        return mysql_affected_rows ( $this->link_id );

    }

    //======================================

    // 函数: recordCount()

    // 功能: 返回查询记录的总数

    // 参数: 无

    // 返回: 记录总数

    //======================================    

    public function recordCount() {

        return mysql_num_rows ( $this->query_id );

    }

    //======================================

    // 函数: getquery_times()

    // 功能: 返回查询的次数

    // 参数: 无

    // 返回: 查询的次数

    //======================================    

    public function getquery_times() {

        return $this->query_times;

    }

    //======================================

    // 函数: getVersion()

    // 功能: 返回mysql的版本

    // 参数: 无

    //======================================    

    public function getVersion() {

        $this->query ( "select version() as ver" );

        $this->fetchRow ();

        return $this->getValue ( "ver" );

    }

    //======================================

    // 函数: getDBSize($database, $tblPrefix=null)

    // 功能: 返回数据库占用空间大小

    // 参数: $database 数据库名

    // 参数: $tblPrefix 表的前缀,可选

    //======================================    

    public function getDBSize($database, $tblPrefix = null) {

        $sql = "SHOW TABLE STATUS FROM " . $database;

        if ($tblPrefix != null) {

            $sql .= " LIKE &#39;$tblPrefix%&#39;";

        }

        $this->query ( $sql );

        $size = 0;

        while ( $this->fetchRow () )

            $size += $this->getValue ( "Data_length" ) + $this->getValue ( "Index_length" );

        return $size;

    }

    //======================================

    // 函数: halt($err_msg)

    // 功能: 处理所有出错信息

    // 参数: $err_msg 自定义的出错信息

    //=====================================    

    public function halt($err_msg = "") {

        if ($err_msg == "") {

            $this->errno = mysql_errno ();

            $this->error = mysql_error ();

            echo "<b>mysql error:<b><br>";

            echo $this->errno . ":" . $this->error . "<br>";

            exit ();

        } else {

            echo "<b>mysql error:<b><br>";

            echo $err_msg . "<br>";

            exit ();

        }

    }

    //======================================

    // 函数: insertID()

    // 功能: 返回最后一次插入的自增ID

    // 参数: 无

    //======================================    

    public function insertID() {

        return mysql_insert_id ();

    }

    //======================================

    //函数:close()

    //功能:关闭非永久的数据库连接

    //参数:无

    //======================================

    public function close() {

        $link_id = $link_id ? $link_id : $this->link_id;

        mysql_close ( $link_id );

    }

    //======================================

    // 函数: sqlSelect()

    // 功能: 返回组合的select查询值

    // 参数: $tbname 查询的表名

    // 参数: $where 条件

    // 参数: $fields 字段值

    // 参数: $orderby 按某字段排序

    // 参数: $sort 正序ASC,倒序DESC,$orderby 不为空是有效

    // 参数: $limit 取得记录的条数,0,8

    // 返回: 查询语句

    //======================================

    function sqlSelect($tbname, $where = "", $limit = 0, $fields = "*", $orderby = "", $sort = "DESC") {

        $sql = "SELECT " . $fields . " FROM " . $tbname . ($where ? " WHERE " . $where : "") . ($orderby ? " ORDER BY " . $orderby . " " . $sort : "") . ($limit ? " limit " . $limit : "");

        return $sql;

    }

    //======================================

    // 函数: sqlInsert()

    // 功能: Insert插入数据函数

    // 参数: $taname 要插入数据的表名

    // 参数: $row 要插入的内容 (数组)

    // 返回: 记录总数

    // 返回: 插入语句

    //======================================

    function sqlInsert($tbname, $row) {

        foreach ( $row as $key => $value ) {

            $sqlfield .= $key . ",";

            $sqlvalue .= "&#39;" . $value . "&#39;,";

        }

        return "INSERT INTO " . $tbname . "(" . substr ( $sqlfield, 0, - 1 ) . ") VALUES (" . substr ( $sqlvalue, 0, - 1 ) . ")";

    }

    //======================================

    // 函数: sqlUpdate()

    // 功能: Update更新数据的函数

    // 参数: $taname 要插入数据的表名

    // 参数: $row 要插入的内容 (数组)

    // 参数: $where 要插入的内容 的条件

    // 返回: Update语句

    //======================================    

    function sqlUpdate($tbname, $row, $where) {

        foreach ( $row as $key => $value ) {

            $sqlud .= $key . "= &#39;" . $value . "&#39;,";

        }

        return "UPDATE " . $tbname . " SET " . substr ( $sqlud, 0, - 1 ) . " WHERE " . $where;

    }

    //======================================

    // 函数: sqlDelete()

    // 功能: 删除指定条件的行

    // 参数: $taname 要插入数据的表名

    // 参数: $where 要插入的内容 的条件

    // 返回: DELETE语句

    //======================================    

    function sqlDelete($tbname, $where) {

        if (! $where) {

            $this->halt ( "删除函数没有指定条件!" );

            return 0;

        }

        return "DELETE FROM " . $tbname . " WHERE " . $where;

    }

      

    //======================================

    //函数:checkSql SQL语句的过滤

    //功能:过滤一些特殊语法

    //参数:$db_string 查询的SQL语句

    //参数:$querytype 查询的类型

    //======================================

    function checkSql($db_string, $querytype = &#39;select&#39;) {

        $clean = &#39;&#39;;

        $old_pos = 0;

        $pos = - 1;

          

        //如果是普通查询语句,直接过滤一些特殊语法

        if ($querytype == &#39;select&#39;) {

            $notallow1 = "[^0-9a-z@\._-]{1,}(union|sleep|benchmark|load_file|outfile)[^0-9a-z@\.-]{1,}";

              

            //$notallow2 = "--|/\*";

            if (eregi ( $notallow1, $db_string )) {

                exit ( "<font size=&#39;5&#39; color=&#39;red&#39;>Safe Alert: Request Error step 1 !</font>" );

            }

        }

          

        //完整的SQL检查

        while ( true ) {

            $pos = strpos ( $db_string, &#39;\&#39;&#39;, $pos + 1 );

            if ($pos === false) {

                break;

            }

            $clean .= substr ( $db_string, $old_pos, $pos - $old_pos );

            while ( true ) {

                $pos1 = strpos ( $db_string, &#39;\&#39;&#39;, $pos + 1 );

                $pos2 = strpos ( $db_string, &#39;\\&#39;, $pos + 1 );

                if ($pos1 === false) {

                    break;

                } elseif ($pos2 == false || $pos2 > $pos1) {

                    $pos = $pos1;

                    break;

                }

                $pos = $pos2 + 1;

            }

            $clean .= &#39;$s$&#39;;

            $old_pos = $pos + 1;

        }

        $clean .= substr ( $db_string, $old_pos );

        $clean = trim ( strtolower ( preg_replace ( array (&#39;~\s+~s&#39; ), array (&#39; &#39; ), $clean ) ) );

          

        //老版本的Mysql并不支持union,常用的程序里也不使用union,但是一些黑客使用它,所以检查它

        if (strpos ( $clean, &#39;union&#39; ) !== false && preg_match ( &#39;~(^|[^a-z])union($|[^[a-z])~s&#39;, $clean ) != 0) {

            $fail = true;

        }

 

        //发布版本的程序可能比较少包括--,#这样的注释,但是黑客经常使用它们

        elseif (strpos ( $clean, &#39;/*&#39; ) > 2 || strpos ( $clean, &#39;--&#39; ) !== false || strpos ( $clean, &#39;#&#39; ) !== false) {

            $fail = true;

        }

 

        //这些函数不会被使用,但是黑客会用它来操作文件,down掉数据库

        elseif (strpos ( $clean, &#39;sleep&#39; ) !== false && preg_match ( &#39;~(^|[^a-z])sleep($|[^[a-z])~s&#39;, $clean ) != 0) {

            $fail = true;

        } elseif (strpos ( $clean, &#39;benchmark&#39; ) !== false && preg_match ( &#39;~(^|[^a-z])benchmark($|[^[a-z])~s&#39;, $clean ) != 0) {

            $fail = true;

        } elseif (strpos ( $clean, &#39;load_file&#39; ) !== false && preg_match ( &#39;~(^|[^a-z])load_file($|[^[a-z])~s&#39;, $clean ) != 0) {

            $fail = true;

        } elseif (strpos ( $clean, &#39;into outfile&#39; ) !== false && preg_match ( &#39;~(^|[^a-z])into\s+outfile($|[^[a-z])~s&#39;, $clean ) != 0) {

            $fail = true;

        }

 

        //老版本的MYSQL不支持子查询,我们的程序里可能也用得少,但是黑客可以使用它来查询数据库敏感信息

        elseif (preg_match ( &#39;~\([^)]*?select~s&#39;, $clean ) != 0) {

            $fail = true;

        }

        if (! empty ( $fail )) {

            exit ( "<font size=&#39;5&#39; color=&#39;red&#39;>Safe Alert: Request Error step 2!</font>" );

        } else {

            return $db_string;

        }

    }

    //======================================

    //函数:析构函数

    //功能:释放类,关闭非永久的数据库连接

    //参数:无

    //======================================

    public function __destruct() {

        $this->close ();

    }

}

?>

ログイン後にコピー

                   

                   

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

See all articles