分类
vps综合利用

PHP 简介

PHP 简介


PHP 是服务器端脚本语言。


您应当具备的基础知识

在继续学习之前,您需要对以下知识有基本的了解:

  • HTML
  • CSS

如果您希望首先学习这些项目,请在我们的 首页 访问这些教程。


PHP 是什么?

  • PHP(全称:PHP:Hypertext Preprocessor,即”PHP:超文本预处理器”)是一种通用开源脚本语言。
  • PHP 脚本在服务器上执行。
  • PHP 可免费下载使用。
PHP 简介 PHP 对初学者而言简单易学。

PHP 也为专业的程序员提供了许多先进的功能。


PHP 文件是什么?

  • PHP 文件可包含文本、HTML、JavaScript代码和 PHP 代码
  • PHP 代码在服务器上执行,结果以纯 HTML 形式返回给浏览器
  • PHP 文件的默认文件扩展名是 “.php”

PHP 能做什么?

  • PHP 可以生成动态页面内容
  • PHP 可以创建、打开、读取、写入、关闭服务器上的文件
  • PHP 可以收集表单数据
  • PHP 可以发送和接收 cookies
  • PHP 可以添加、删除、修改您的数据库中的数据
  • PHP 可以限制用户访问您的网站上的一些页面
  • PHP 可以加密数据

通过 PHP,您不再限于输出 HTML。您可以输出图像、PDF 文件,甚至 Flash 电影。您还可以输出任意的文本,比如 XHTML 和 XML。


为什么使用 PHP?

  • PHP 可在不同的平台上运行(Windows、Linux、Unix、Mac OS X 等)
  • PHP 与目前几乎所有的正在被使用的服务器相兼容(Apache、IIS 等)
  • PHP 提供了广泛的数据库支持
  • PHP 是免费的,可从官方的 PHP 资源下载它: www.php.net
  • PHP 易于学习,并可高效地运行在服务器端

分类
vps综合利用

PHP 安装

PHP 安装


您需要做什么?

为了开始使用 PHP,您可以:

  • 找一个支持 PHP 和 MySQL 的 Web 主机
  • 在您自己的 PC 机上安装 Web 服务器,然后安装 PHP 和 MySQL

使用支持 PHP 的 Web 主机

如果您的服务器支持 PHP,那么您不需要做任何事情。

只要在您的 web 目录中创建 .php 文件即可,服务器将自动为您解析这些文件。

您不需要编译任何软件,或安装额外的工具。

由于 PHP 是免费的,大多数的 Web 主机都提供对 PHP 的支持。


在您自己的 PC 机上建立 PHP

然而,如果您的服务器不支持 PHP,您必须:

  • 安装 Web 服务器
  • 安装 PHP
  • 安装数据库,比如 MySQL

官方 PHP 网站(PHP.net)有 PHP 的安装说明: http://php.net/manual/en/install.php


PHP 服务器组件

对于初学者建议使用集成的服务器组件,它已经包含了 PHP、Apache、Mysql 等服务,免去了开发人员将时间花费在繁琐的配置环境过程。

WampServer

Windows 系统可以使用 WampServer,下载地址:http://www.wampserver.com/,支持32位和64位系统,根据自己的系统选择版本。

WampServer 安装也简单,你只需要一直点击 “Next” 就可以完成安装了。

XAMPP

XAMPP 支持 Mac OS 和 Windows 系统,下载地址:https://www.apachefriends.org/zh_cn/index.html


IDE (Integrated Development Environment,集成开发环境)

Eclipse for PHP(免费)

Eclipse 是一个开放源代码的、基于Java的可扩展开发平台(如果未安装JDK,则需要先 下载 JDK 安装)。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括Java开发工具(Java Development Kit,JDK)。

支持 Windows、Linux 和 Mac OS 平台。

Eclipse for PHP 官方下载地址:http://www.eclipse.org/downloads/packages/eclipse-php-developers/heliosr

PhpStorm(收费)

PhpStorm是一个轻量级且便捷的PHP IDE,其旨在提供用户效率,可深刻理解用户的编码,提供智能代码补全,快速导航以及即时错误检查。

PhpStorm 非常适合于PHP开发人员及前端工程师。提供诸于:智能HTML/CSS/JavaScript/PHP编辑、代码质量分析、版本控制集成(SVN、GIT)、调试和测试等功能。

支持 Windows、Linux 和 Mac OS 平台。

PhpStorm 官方下载地址:http://www.jetbrains.com/phpstorm/download/

分类
vps综合利用

PHP 连接 MySQL

PHP 连接 MySQL


PHP 5 及以上版本建议使用以下方式连接 MySQL :

  • MySQLi extension (“i” 意为 improved)
  • PDO (PHP Data Objects)

在 PHP 早期版本中我们使用 MySQL 扩展。但该扩展在 2012 年开始不建议使用。


我是该用 MySQLi ,还是 PDO?

如果你需要一个简短的回答,即 “你习惯哪个就用哪个”。

MySQLi 和 PDO 有它们自己的优势:

PDO 应用在 12 种不同数据库中, MySQLi 只针对 MySQL 数据库。

所以,如果你的项目需要在多种数据库中切换,建议使用 PDO ,这样你只需要修改连接字符串和部分查询语句即可。 使用 MySQLi, 如果不同数据库,你需要重新编写所有代码,包括查询。

两者都是面向对象, 但 MySQLi 还提供了 API 接口。

两者都支持预处理语句。 预处理语句可以防止 SQL 注入,对于 web 项目的安全性是非常重要的。


MySQLi 和 PDO 连接 MySQL 实例

在本章节及接下来的章节中,我们会使用以下三种方式来演示 PHP 操作 MySQL:

  • MySQLi (面向对象)
  • MySQLi (面向过程)
  • PDO

MySQLi 安装

Linux 和 Windows: 在 php5 mysql 包安装时 MySQLi 扩展多数情况下是自动安装的。

安装详细信息,请查看: http://php.net/manual/en/mysqli.installation.php

可以通过 phpinfo() 查看是否安装成功:

PHP 连接 MySQL


PDO 安装

For 安装详细信息,请查看: http://php.net/manual/en/pdo.installation.php

可以通过 phpinfo() 查看是否安装成功:

PHP 连接 MySQL


连接 MySQL

在我们访问 MySQL 数据库前,我们需要先连接到数据库服务器:

实例 (MySQLi – 面向对象)

<?php $servername = "localhost"; $username = "username"; $password = "password"; // 创建连接 $conn = new mysqli($servername, $username, $password); // 检测连接 if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } echo "连接成功"; ?>

PHP 连接 MySQL 注意在以上面向对象的实例中 $connect_error 是在 PHP 5.2.9 和 5.3.0 中添加的。如果你需要兼容更早版本 请使用以下代码替换:

// 检测连接
if (mysqli_connect_error()) {
    die(“数据库连接失败: ” . mysqli_connect_error());
}

实例 (MySQLi – 面向过程)

<?php $servername = "localhost"; $username = "username"; $password = "password"; // 创建连接 $conn = mysqli_connect($servername, $username, $password); // 检测连接 if (!$conn) { die("Connection failed: " . mysqli_connect_error()); } echo "连接成功"; ?>

实例 (PDO)

<?php $servername = "localhost"; $username = "username"; $password = "password"; try { $conn = new PDO("mysql:host=$servername;dbname=myDB", $username, $password); echo "连接成功"; } catch(PDOException $e) { echo $e->getMessage(); } ?>

PHP 连接 MySQL 注意在以上 PDO 实例中我们已经指定了数据库 (myDB)。PDO 在连接过程需要设置数据库名。如果没有指定,则会抛出异常。

关闭连接

连接在脚本执行完后会自动关闭。你也可以使用以下代码来关闭连接:

实例 (MySQLi – 面向对象)

$conn->close();

实例 (MySQLi – 面向过程)

mysqli_close($conn);

实例 (PDO)

$conn = null;

分类
vps综合利用

PHP FTP 函数

PHP FTP 函数


PHP FTP 简介

FTP 函数通过文件传输协议 (FTP) 提供对文件服务器的客户端访问。

FTP 函数用于打开、登录以及关闭连接,同时用于上传、下载、重命名、删除及获取文件服务器上的文件信息。不是所有的 FTP 函数对每个服务器都起作用或返回相同的结果。自 PHP 3 起,FTP 函数可用。

这些函数用于对 FTP 服务器进行细致的访问。如果您仅仅需要对 FTP 服务器进行读写操作,建议使用 Filesystem 函数中的 ftp:// wrapper。


安装

PHP 的 Windows 版本内置了对 FTP 扩展的支持。无需加载任何附加扩展库即可使用 FTP 函数。

然而,如果您运行的是 PHP 的 Linux 版本,在编译 PHP 的时候请添加 –enable-ftp 选项(PHP4 或以上版本)或者 –with-ftp 选项(PHP3 版本)。


PHP FTP 函数

PHP:指示支持该函数的最早的 PHP 版本。

函数 描述 PHP
ftp_alloc() 为要上传到 FTP 服务器的文件分配空间。 5
ftp_cdup() 把当前目录改变为 FTP 服务器上的父目录。 3
ftp_chdir() 改变 FTP 服务器上的当前目录。 3
ftp_chmod() 通过 FTP 设置文件上的权限。 5
ftp_close() 关闭 FTP 连接。 4
ftp_connect() 打开 FTP 连接。 3
ftp_delete() 删除 FTP 服务器上的一个文件。 3
ftp_exec() 在 FTP 服务器上执行一个程序/命令。 4
ftp_fget() 从 FTP 服务器上下载一个文件并保存到本地一个已经打开的文件中。 3
ftp_fput() 上传一个已经打开的文件,并在 FTP 服务器上把它保存为一个文件。 3
ftp_get_option() 返回 FTP 连接的各种运行时选项。 4
ftp_get() 从 FTP 服务器上下载文件。 3
ftp_login() 登录 FTP 服务器。 3
ftp_mdtm() 返回指定文件的最后修改时间。 3
ftp_mkdir() 在 FTP 服务器上创建一个新目录。 3
ftp_nb_continue() 连续获取/发送文件。(无阻塞) 4
ftp_nb_fget() 从 FTP 服务器上下载一个文件并保存到本地一个已经打开的文件中。(无阻塞) 4
ftp_nb_fput() 上传一个已经打开的文件,并在 FTP 服务器上把它保存为一个文件。(无阻塞) 4
ftp_nb_get() 从 FTP 服务器上下载文件。(无阻塞) 4
ftp_nb_put() 把文件上传到 FTP 服务器上。(无阻塞) 4
ftp_nlist() 返回 FTP 服务器上指定目录的文件列表。 3
ftp_pasv() 把被动模式设置为打开或关闭。 3
ftp_put() 把文件上传到 FTP 服务器上。 3
ftp_pwd() 返回当前目录名称。 3
ftp_quit() ftp_close() 的别名。 3
ftp_raw() 向 FTP 服务器发送一个 raw 命令。 5
ftp_rawlist() 返回指定目录中文件的详细列表。 3
ftp_rename() 重命名 FTP 服务器上的文件或目录。 3
ftp_rmdir() 删除 FTP 服务器上的一个目录。 3
ftp_set_option() 设置 FTP 连接的各种运行时选项。 4
ftp_site() 向服务器发送 SITE 命令。 3
ftp_size() 返回指定文件的大小。 3
ftp_ssl_connect() 打开一个安全的 SSL-FTP 连接。 4
ftp_systype() 返回 FTP 服务器的系统类型标识符。 3


PHP FTP 常量

PHP:指示支持该常量的最早的 PHP 版本。

常量 描述 PHP
FTP_ASCII 3
FTP_TEXT 3
FTP_BINARY 3
FTP_IMAGE 3
FTP_TIMEOUT_SEC 3
FTP_AUTOSEEK 4
FTP_AUTORESUME 为 GET 和 PUT 请求自动决定恢复和开始的位置 4
FTP_FAILED 异步传输失败 4
FTP_FINISHED 异步传输成功 4
FTP_MOREDATA 异步传输是活动状态的 4

分类
vps综合利用

PHP PDO

PHP PDO

PHP 数据对象 (PDO) 扩展为PHP访问数据库定义了一个轻量级的一致接口。

PDO 提供了一个数据访问抽象层,这意味着,不管使用哪种数据库,都可以用相同的函数(方法)来查询和获取数据。

PDO随PHP5.1发行,在PHP5.0的PECL扩展中也可以使用,无法运行于之前的PHP版本。


PDO 安装

你可以通过 PHP 的 phpinfo() 函数来查看是否安装了PDO扩展。

在 Unix 系统上安装 PDO

在Unix上或Linux上你需要添加以下扩展:

 extension=pdo.so 

Windows 用户

PDO 和所有主要的驱动作为共享扩展随 PHP 一起发布,要激活它们只需简单地编辑 php.ini 文件,并添加以下扩展:

 extension=php_pdo.dll 

除此之外还有以下对应的各种数据库扩展:

  ;extension=php_pdo_firebird.dll ;extension=php_pdo_informix.dll ;extension=php_pdo_mssql.dll ;extension=php_pdo_mysql.dll ;extension=php_pdo_oci.dll ;extension=php_pdo_oci8.dll ;extension=php_pdo_odbc.dll ;extension=php_pdo_pgsql.dll ;extension=php_pdo_sqlite.dll 

在设定好这些配置后,我们需要重启PHP 或 Web服务器。

接下来我们们来看下具体的实例,以下为使用PDO连接MySql数据库的实例:

 <?php $dbms='mysql';     //数据库类型 $host='localhost'; //数据库主机名 $dbName='test';    //使用的数据库 $user='root';      //数据库连接用户名 $pass='';          //对应的密码 $dsn="$dbms:host=$host;dbname=$dbName";   try {     $dbh = new PDO($dsn, $user, $pass); //初始化一个PDO对象     echo "连接成功<br/>";     /*你还可以进行一次搜索操作     foreach ($dbh->query('SELECT * from FOO') as $row) {         print_r($row); //你可以用 echo($GLOBAL); 来看到这些值     }     */     $dbh = null; } catch (PDOException $e) {     die ("Error!: " . $e->getMessage() . "<br/>"); } //默认这个不是长连接,如果需要数据库长连接,需要最后加一个参数:array(PDO::ATTR_PERSISTENT => true) 变成这样: $db = new PDO($dsn, $user, $pass, array(PDO::ATTR_PERSISTENT => true));  ?> 

很简单吧,接下来就让我们来具体看下PHP PDO具体说明:

分类
vps综合利用

PHP Zip File 函数

PHP Zip File 函数


PHP Zip File 简介

Zip File 函数允许您读取压缩文件。


安装

如需在服务器上运行 Zip File 函数,必须安装这些库:

在 Linux 系统上安装

PHP 5+:Zip 函数和 Zip 库默认不会启用,必须从上面的链接下载。请使用 –with-zip=DIR 配置选项来包含 Zip 支持。

在 Windows 系统上安装

PHP 5+:Zip 函数默认不会启用,必须从上面的链接下载 php_zip.dll 和 ZZIPlib 库。必须在 php.ini 中启用 php_zip.dll。

如需启用任何 PHP 扩展,PHP extension_dir 设置(在 php.ini 文件中)应该设置为该 PHP 扩展所在的目录。举例 extension_dir 的值可能是 c:/php/ext。


PHP Zip File 函数

PHP:指示支持该函数的最早的 PHP 版本。

函数 描述 PHP
zip_close() 关闭 ZIP 文件。 4
zip_entry_close() 关闭 ZIP 文件中的一个项目。 4
zip_entry_compressedsize() 返回 ZIP 文件中的一个项目的被压缩尺寸。 4
zip_entry_compressionmethod() 返回 ZIP 文件中的一个项目的压缩方法。 4
zip_entry_filesize() 返回 ZIP 文件中的一个项目的实际文件尺寸。 4
zip_entry_name() 返回 ZIP 文件中的一个项目的名称。 4
zip_entry_open() 打开 ZIP 文件中的一个项目以供读取。 4
zip_entry_read() 读取 ZIP 文件中的一个打开的项目。 4
zip_open() 打开 ZIP 文件。 4
zip_read() 读取 ZIP 文件中的下一个项目。 4


PHP Zip File 常量

无。

分类
vps综合利用

PHP 图像处理

PHP 图像处理

PHP 提供了丰富的图像处理函数,主要包括:

函数 描述
gd_info() 取得当前安装的 GD 库的信息
getimagesize() 获取图像信息
getimagesizefromstring() 获取图像信息
image_type_to_extension() 获取图片后缀
image_type_to_mime_type() 返回图像的 MIME 类型
image2wbmp() 输出WBMP图片
imageaffine() 返回经过仿射变换后的图像
imageaffinematrixconcat() 连接两个矩阵
imageaffinematrixget() 获取矩阵
imagealphablending() 设定图像的混色模式
imageantialias() 是否使用抗锯齿(antialias)功能
imagearc() 画椭圆弧
imagechar() 写出横向字符
imagecharup() 垂直地画一个字符
imagecolorallocate() 为一幅图像分配颜色
imagecolorallocatealpha() 为一幅图像分配颜色和透明度
imagecolorat() 取得某像素的颜色索引值
imagecolorclosest() 取得与指定的颜色最接近的颜色的索引值
imagecolorclosestalpha() 取得与指定的颜色加透明度最接近的颜色的索引
imagecolorclosesthwb() 取得与指定的颜色最接近的色度的黑白色的索引
imagesx() 、imagesy() 获取图像宽度与高度

GD 库

使用 PHP 图像处理函数,需要加载 GD 支持库。请确定 php.ini 加载了 GD 库:

Window 服务器上:

extension = php_gd2.dll 

Linux 和 Mac 系统上:

 extension = php_gd2.so 

使用 gd_info() 函数可以查看当前安装的 GD 库的信息:

<?php var_dump(gd_info()); ?> 

输出大致如下:

array(12) {   ["GD Version"]=>   string(26) "bundled (2.1.0 compatible)"   ["FreeType Support"]=>   bool(true)   ["FreeType Linkage"]=>   string(13) "with freetype"   ["T1Lib Support"]=>   bool(false)   ["GIF Read Support"]=>   bool(true)   ["GIF Create Support"]=>   bool(true)   ["JPEG Support"]=>   bool(true)   ["PNG Support"]=>   bool(true)   ["WBMP Support"]=>   bool(true)   ["XPM Support"]=>   bool(false)   ["XBM Support"]=>   bool(true)   ["JIS-mapped Japanese Font Support"]=>   bool(false) } 

分类
vps综合利用

Python3 解释器

Python3 解释器

Linux/Unix的系统上,一般默认的 python 版本为 2.x,我们可以将 python3.x 安装在 /usr/local/python3 目录中。

安装完成后,我们可以将路径 /usr/local/python3/bin 添加到您的 Linux/Unix 操作系统的环境变量中,这样您就可以通过 shell 终端输入下面的命令来启动 Python3 。

 $ PATH=$PATH:/usr/local/python3/bin/python3    # 设置环境变量 $ python3 --version Python 3.4.0 

在Window系统下你可以通过以下命令来设置Python的环境变量,假设你的Python安装在 C:/Python34 下:

 set path=%path%;C:/python34 

交互式编程

我们可以在命令提示符中输入”Python”命令来启动Python解释器:

 $ python3 

执行以上命令后,出现如下窗口信息:

 $ python3 Python 3.4.0 (default, Apr 11 2014, 13:05:11)  [GCC 4.8.2] on linux Type "help", "copyright", "credits" or "license" for more information. >>>  

在 python 提示符中输入以下语句,然后按回车键查看运行效果:

 print ("Hello, Python!"); 

以上命令执行结果如下:

 Hello, Python! 

当键入一个多行结构时,续行是必须的。我们可以看下如下 if 语句:

 >>> flag = True >>> if flag : ...     print("flag 条件为 True!") ...  flag 条件为 True! 

脚本式编程

将如下代码拷贝至 hello.py文件中:

 print ("Hello, Python!"); 

通过以下命令执行该脚本:

 python3 hello.py 

输出结果为:

 Hello, Python! 

在Linux/Unix系统中,你可以在脚本顶部添加以下命令让Python脚本可以像SHELL脚本一样可直接执行:

 set path=%path%;C:/python34 

0

然后修改脚本权限,使其有执行权限,命令如下:

 set path=%path%;C:/python34 

1

执行以下命令:

 set path=%path%;C:/python34 

2

输出结果为:

 set path=%path%;C:/python34 

3

分类
vps综合利用

Python3 MySQL 数据库连接

Python3 MySQL 数据库连接

本文我们为大家介绍 Python3 使用 PyMySQL 连接数据库,并实现简单的增删改查。

什么是 PyMySQL?

PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。

PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。


PyMySQL 安装

在使用 PyMySQL 之前,我们需要确保 PyMySQL 已安装。

PyMySQL 下载地址:https://github.com/PyMySQL/PyMySQL。

如果还未安装,我们可以使用以下命令安装最新版的 PyMySQL:

 $ pip install PyMySQL 

如果你的系统不支持 pip 命令,可以使用以下方式安装:

1、使用 git 命令下载安装包安装(你也可以手动下载):

 $ git clone https://github.com/PyMySQL/PyMySQL $ cd PyMySQL/ $ python3 setup.py install 

2、如果需要制定版本号,可以使用 curl 命令来安装:

 $ # X.X 为 PyMySQL 的版本号 $ curl -L https://github.com/PyMySQL/PyMySQL/tarball/pymysql-X.X | tar xz $ cd PyMySQL* $ python3 setup.py install $ # 现在你可以删除 PyMySQL* 目录 

注意:请确保您有root权限来安装上述模块。

安装的过程中可能会出现”ImportError: No module named setuptools”的错误提示,意思是你没有安装setuptools,你可以访问https://pypi.python.org/pypi/setuptools 找到各个系统的安装方法。

Linux 系统安装实例:

 $ wget https://bootstrap.pypa.io/ez_setup.py $ python3 ez_setup.py 

数据库连接

连接数据库前,请先确认以下事项:

  • 您已经创建了数据库 TESTDB.
  • 在TESTDB数据库中您已经创建了表 EMPLOYEE
  • EMPLOYEE表字段为 FIRST_NAME, LAST_NAME, AGE, SEX 和 INCOME。
  • 连接数据库TESTDB使用的用户名为 “testuser” ,密码为 “test123”,你可以可以自己设定或者直接使用root用户名及其密码,Mysql数据库用户授权请使用Grant命令。
  • 在你的机子上已经安装了 Python MySQLdb 模块。
  • 如果您对sql语句不熟悉,可以访问我们的 SQL基础教程

实例:

以下实例链接 Mysql 的 TESTDB 数据库:

实例(Python 3.0+)

#!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用 cursor() 方法创建一个游标对象 cursor cursor = db.cursor() # 使用 execute() 方法执行 SQL 查询 cursor.execute("SELECT VERSION()") # 使用 fetchone() 方法获取单条数据. data = cursor.fetchone() print ("Database version : %s " % data) # 关闭数据库连接 db.close()

执行以上脚本输出结果如下:

 Database version : 5.5.20-log 

创建数据库表

如果数据库连接存在我们可以使用execute()方法来为数据库创建表,如下所示创建表EMPLOYEE:

实例(Python 3.0+)

#!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用 cursor() 方法创建一个游标对象 cursor cursor = db.cursor() # 使用 execute() 方法执行 SQL,如果表存在则删除 cursor.execute("DROP TABLE IF EXISTS EMPLOYEE") # 使用预处理语句创建表 sql = """CREATE TABLE EMPLOYEE ( FIRST_NAME CHAR(20) NOT NULL, LAST_NAME CHAR(20), AGE INT, SEX CHAR(1), INCOME FLOAT )""" cursor.execute(sql) # 关闭数据库连接 db.close()


数据库插入操作

以下实例使用执行 SQL INSERT 语句向表 EMPLOYEE 插入记录:

实例(Python 3.0+)

#!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用cursor()方法获取操作游标 cursor = db.cursor() # SQL 插入语句 sql = """INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME) VALUES (‘Mac’, ‘Mohan’, 20, ‘M’, 2000)""" try: # 执行sql语句 cursor.execute(sql) # 提交到数据库执行 db.commit() except: # 如果发生错误则回滚 db.rollback() #
关闭数据库连接
db.close()

以上例子也可以写成如下形式:

实例(Python 3.0+)

#!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用cursor()方法获取操作游标 cursor = db.cursor() # SQL 插入语句 sql = "INSERT INTO EMPLOYEE(FIRST_NAME, / LAST_NAME, AGE, SEX, INCOME) / VALUES (‘%s’, ‘%s’, ‘%d’, ‘%c’, ‘%d’ )" % / (Mac, Mohan, 20, M, 2000) try: # 执行sql语句 cursor.execute(sql) # 执行sql语句 db.commit() except: # 发生错误时回滚 db.rollback() # 关闭数据库连接 db.close()

以下代码使用变量向SQL语句中传递参数:

 .................................. user_id = "test123" password = "password"  con.execute('insert into Login values("%s", "%s")' % /              (user_id, password)) .................................. 

数据库查询操作

Python查询Mysql使用 fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据。

  • fetchone(): 该方法获取下一个查询结果集。结果集是一个对象
  • fetchall(): 接收全部的返回结果行.
  • rowcount: 这是一个只读属性,并返回执行execute()方法后影响的行数。

实例:

查询EMPLOYEE表中salary(工资)字段大于1000的所有数据:

实例(Python 3.0+)

#!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用cursor()方法获取操作游标 cursor = db.cursor() # SQL 查询语句 sql = "SELECT * FROM EMPLOYEE / WHERE INCOME > ‘%d’" % (1000) try: # 执行SQL语句 cursor.execute(sql) # 获取所有记录列表 results = cursor.fetchall() for row in results: fname = row[0] lname = row[1] age = row[2] sex = row[3] income = row[4] # 打印结果 print ("fname=%s,lname=%s,age=%d,sex=%s,income=%d" % / (fname, lname, age, sex, income )) except: print ("Error: unable to fetch data") # 关闭数据库连接 db.close()

以上脚本执行结果如下:

 fname=Mac, lname=Mohan, age=20, sex=M, income=2000 

数据库更新操作

更新操作用于更新数据表的的数据,以下实例将 TESTDB表中的 SEX 字段全部修改为 ‘M’,AGE 字段递增1:

实例(Python 3.0+)

#!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用cursor()方法获取操作游标 cursor = db.cursor() # SQL 更新语句 sql = "UPDATE EMPLOYEE SET AGE = AGE + 1 WHERE SEX = ‘%c’" % (M) try: # 执行SQL语句 cursor.execute(sql) # 提交到数据库执行 db.commit() except: # 发生错误时回滚 db.rollback() # 关闭数据库连接 db.close()


删除操作

删除操作用于删除数据表中的数据,以下实例演示了删除数据表 EMPLOYEE 中 AGE 大于 20 的所有数据:

实例(Python 3.0+)

#!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用cursor()方法获取操作游标 cursor = db.cursor() # SQL 删除语句 sql = "DELETE FROM EMPLOYEE WHERE AGE > ‘%d’" % (20) try: # 执行SQL语句 cursor.execute(sql) # 提交修改 db.commit() except: # 发生错误时回滚 db.rollback() # 关闭连接 db.close()


执行事务

事务机制可以确保数据一致性。

事务应该具有4个属性:原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。

  • 原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。
  • 一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
  • 隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
  • 持久性(durability)。持续性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

Python DB API 2.0 的事务提供了两个方法 commit 或 rollback。

实例

实例(Python 3.0+)

# SQL删除记录语句 sql = "DELETE FROM EMPLOYEE WHERE AGE > ‘%d’" % (20) try: # 执行SQL语句 cursor.execute(sql) # 向数据库提交 db.commit() except: # 发生错误时回滚 db.rollback()

对于支持事务的数据库, 在Python数据库编程中,当游标建立之时,就自动开始了一个隐形的数据库事务。

commit()方法游标的所有更新操作,rollback()方法回滚当前游标的所有操作。每一个方法都开始了一个新的事务。


错误处理

DB API中定义了一些数据库操作的错误及异常,下表列出了这些错误和异常:

异常 描述
Warning 当有严重警告时触发,例如插入数据是被截断等等。必须是 StandardError 的子类。
Error 警告以外所有其他错误类。必须是 StandardError 的子类。
InterfaceError 当有数据库接口模块本身的错误(而不是数据库的错误)发生时触发。 必须是Error的子类。
DatabaseError 和数据库有关的错误发生时触发。 必须是Error的子类。
DataError 当有数据处理时的错误发生时触发,例如:除零错误,数据超范围等等。 必须是DatabaseError的子类。
OperationalError 指非用户控制的,而是操作数据库时发生的错误。例如:连接意外断开、 数据库名未找到、事务处理失败、内存分配错误等等操作数据库是发生的错误。 必须是DatabaseError的子类。
IntegrityError 完整性相关的错误,例如外键检查失败等。必须是DatabaseError子类。
InternalError 数据库的内部错误,例如游标(cursor)失效了、事务同步失败等等。 必须是DatabaseError子类。
ProgrammingError 程序错误,例如数据表(table)没找到或已存在、SQL语句语法错误、 参数数量错误等等。必须是DatabaseError的子类。
NotSupportedError 不支持错误,指使用了数据库不支持的函数或API等。例如在连接对象上 使用.rollback()函数,然而数据库并不支持事务或者事务已关闭。 必须是DatabaseError的子类。

分类
vps综合利用

实验在Linux下配置Mono和Jexus并且部署ASP.NET MVC5

1.开篇说明

a. 首先我在写这篇博客之前,已经在自己本地配置了mono和jexus并且成功部署了asp.net mvc项目,我也是依赖于在网上查找的各种资料来配置环境并且部署项目的,而其在网上也已有了很多这方面的文章,故而我就想我是写还是不写呢,但是想来想 去,我还是写一下吧,因为网上的文章太杂乱,不是最新版本,不是很整齐并且也可能会遇到各种各样的问题,所以我决定写一篇从无到部署项目上线的文章并且会 友情提示很多内容以及解决方案,希望也能够融入自己的思想。
b. 因为现在跨平台是一个趋势,网上学习的人员很多,我可能写的不好,希望大家见谅,下面开始从无到有的过程吧。

2.Mono和Jexus简单说明

a. Mono是由Novell公司(由Xamarin(已被微软收购并且将会开源,前途一片光明)发起,一个致力于开创.NET在Linux上使用的开源工 程。它包含了一个C#语言的编译器,一个CLR的运行时和一组类库,并且实现了ADO.NET和ASP.Net,能够使的开发人员在Linux下用C#开 发程序。)主持的项目,该项目的目标就是创建一系列符合标准的ECMA(Ecma-334和Ecma-335)的.NET工具,包括C #编译器和共同语言(CL 即 Common Language)执行平台(Platform),与微软的.Net不同:Mono项目不仅可以运行于Windows系统内,还可以运行于Linux、 FreeBSD、Unix、Mac OS X和Solaris,可以说是完完全全的跨平台。

b. Jexus即Jexus Web Server,简称JWS,是再linux平台上的一款ASP.NET WEB服务器,Jexus for linux有如下特点:

b.1 支持多种操作系统:Jexus最初的设计目标就是”跨平台的ASP.NET WEB服务器”,由于在window系统上,IIS已经是ASP.NET的优秀平台,所以当前的Jexus以支持Linux和FreeBSD等非Windows系统为主要设计目标。

b.2 高性能:“高性能”是Jexus的重要设计目标,虽然Jexus基于Mono环境运行,但Jexus并非全部由mono的.NET组件构成,对于涉及性能 的关键代码,Jexus非常巧妙的大量采用了Linux/Unix本身的优秀特性,从代码层面保证了Jexus的性能优势,同时Jexus的框架特征也为 高性能提供了基础保证。Jexus不象XSP那样,纯HTML也需要经过ASP.NET处理,更不象Apache和Nginx等服务器,需要通过插件的形 式间接地对ASP.NET进行支持,Jexus把HMTL静态文件处理模块、ASP.NET处理模块、静态文件高速缓存机制、epoll/poll数据传 输机制等进行了高度集成,从架构本身入手,最大限度地提高WEB服务器的处理能力和传输速度。

b.3 安全性:Jexus内核含有安全监控机制,绝大多数恶意访问在进入网站前就会被Jexus直接Pass掉,这是Jexus有别于其它Web服务的一大特色。

b.4 稳定性:从运行机制而言,Jexus系统中,有专门监测工作进程执行状态的管理单元,任何一个进程退出或者任何一个ASP.NET网站应用程序域退出,就 会被管理单元发现并且重启,从而保证了Jexus能够时时刻刻不间断的工作,旧程序本身而言,Jexus程序的代码力求简洁,Bug很少,同 时,Jexus的每个版本在正式发布之前,都要进过严格的压力测试,影响稳定性的因素,几乎在正式发布之前既已被全部排除。

b.5 功能强大,Jexus支持URL重写,支持多目标服务器的反向代理,支持PHP,支持GZIP压缩传输并且可以利用不同端口,不同虚拟路径,不同域名设置任意数量的网站。

b.6 安装、配置、操作即为简单,服务社区化,各种问题都能快速的处理,有良好的后续服务支撑能力。

b.7 在官网下还有一些好处请查看:http://www.linuxdot.net/bbsfile-3084

备注:部分内容来自网络,感谢张善友等社区活跃人物。

c. Mono官网:http://www.mono-project.com/

d. Jexus官网:http://www.jexus.org/

e. 工欲善其事必先利其器,那么下面我们来进行配置mono和Jexus并且部署MVC网站,本次操作需要用到的软件以及系统如下所示:虚拟机(Vmware)、虚拟机中安装的CentOS系统(64位)(IP:192.168.37.138)、Xshell、Xftp至于如何使用它们我们下面会说到。

3. 配置Mono需要的GDI+兼容API的库Libgdiplus

a. 通过上面简单的哦介绍之后,我们开始配置mono和jexus,在配置mono之前,首先来配置Libgdiplus。

b.使用XShell连接Centos,然后输入更新系统命令:yum -y update将低版本的系统升级(我的从centos6.5升级到6.8)。

c. 执行完毕之后,在安装必要的软件,命令如下:

yum -y install gcc gcc-c++ bison pkgconfig glib2-devel gettext make libpng-devel libjpeg-devel libtiff-devel libexif-devel giflib-devel libX11-devel freetype-devel fontconfig-devel  cairo-devel

备注:可能电脑已经安装了这些文件,可用rpm -qa libexif*命令查看,但是这里为了确保万无一失,直接全部执行。

d. 执行完毕之后跳转到local下面创建属于自己的文件夹kencery,在此文件夹下面创建libgdiplus文件夹,命令如下:

        d.1 (1):cd /usr/local/    (2):mkdir kencery    (3):cd kencery/   (4):mkdir libgdiplus  (5):cd libgdiplus/

e. 使用命令wget下载最新版本的libgdiplus,命令如下,下载完成之后将包解压(至于安装包里面是什么内容,请自行使用命令ls -l查看),如下图所示:

e.1 wget http://download.mono-project.com/sources/libgdiplus/libgdiplus-4.2.tar.gz

e.2 tar -zxvf libgdiplus-4.2.tar.gz

备注:可以打开http://download.mono-project.com/sources/libgdiplus/此网站查看所有的文件,选择想要下载的文件,我这里下载的是最新的libgdiplus。

f. 进入libgdiplus-4.2(cd libgdiplus-4.2)文件下,执行下面的命令进行安装

f.1 ./configure –prefix=/usr

f.2 make

f.3  make install

4.  配置Mono

a. Mono的安装在整个 过程中时间比较长,请大家耐心安装。

b. cd跳转到文件夹kencery,在此文件夹下面创建mono文件夹,命令如下:

b.1 (1):cd /usr/local/kencery  (2):mkdir mono  (3):cd mono/

c. 使用命令wget下载最新版本的mono,命令如下,下载完成之后将包解压(至于安装包里面是什么内容,请自行使用命令ls -l查看),如下图所示:

c.1 wget http://download.mono-project.com/sources/mono/mono-4.4.0.148.tar.bz2

mono源文件可能不好下载  建议在百度网盘离线下载然后下载文件并拷贝

c.2 tar -jxvf mono-4.4.0.148.tar.bz2

备注:可以打开http://download.mono-project.com/sources/mono/此网站查看所有的文件,选择想要下载的文件,我这里下载的是最新的mono。

d. 进入mono-4.4.0(cd mono-4.4.0)文件下,执行下面的命令进行安装

d.1 ./configure –prefix=/usr

d.2 make (发现会出现很多警告,不用担心,不会影响到项目部署,中间时间可能会很长)

d.3 make install(中间时间可能会很长)

e. 上述命令执行完成之后,输入mono -V如果含有mono的版本信息,则说明安装成功,版本信息如图所示:

5.  配置Jexus

a. 当mono配置完成并且测试没有问题的情况下,这时候我们就可以对Jexus进行配置了。

b. cd跳转到文件夹kencery,在此文件夹下面创建jexus文件夹,命令如下:

b.1 (1):cd /usr/local/kencery  (2):mkdir jexus (3):cd jexus/

c. 使用命令wget下载最新版本的jexus,命令如下,下载完成之后将包解压(至于安装包里面是什么内容,请自行使用命令ls -l查看),如下图所示:

c.1 wget http://www.linuxdot.net/down/jexus-5.8.1.tar.gz

c.2 tar -zxvf jexus-5.8.1.tar.gz

 备注:在官网下找到最新的jexus下载。

d. 进入jexus-5.8.1(cd jexus-5.8.1)文件下,执行下面的命令进行安装

d.1 sudo ./install

备注:在执行install脚本时,jexus默认是安装到/usr/jexus/中,如果您想安装到自定义的目录,可以在执行该脚本的时候增加一个目录参数(sudo ./install /usr/local/kencery/jexus/)

e. 因为Jexus是一个服务,故而可以控制整个服务的启动、停止、重启,命令如下,请自行测试

e.1 启动 sudo /usr/jexus/jws start

e.2 停止 sudo /usr/jexus/jws stop

e.3 重启 sudo /usr/jexus/jws restart

f. 当然也可以控制指定网站的启动,停止,重启,命令如下:请自行测试

f.1 启动 sudo /usr/jexus/jws start website(网站名称)

f.2 停止 sudo /usr/jexus/jws stop sizeName(网站名称)

f.3 重启 sudo /usr/jexus/jws restart sizeName(网站名称)

g. 使用命令:sudo /usr/jexus/jws start启动,如果jexus启动OK,则说明安装成功了。

h. 当jexus启动成功,这时候我们想在外面访问jexus,但是浏览器访问出错,使用ping 域名是可以ping通,但是浏览器访问就是失败(提示:无法访问此网站,192.168.37.138的响应时间过长),这是为什么呢?这是因为 jexus默认是80端口,而系统安装完成之后80端口是不允许外界访问的,故而访问不了,设置将80端口开放使外界可以访问。

h.1 cd /etc/sysconfig/

h.2 vim iptables 修改并且保存,如图所示:

h.3 重启服务  service iptables restart

i. 当h完成之后,重启jexus,输入如下网址访问,如图所示,则说明jexus安装完全成功,接下来我们就需要部署ASP.NET MVC项目了。

备注:快捷安装��法(一对命令将会安装成功Jexus)

1.安装:sudo curl jexus.org/release/install | sh

2.更新:sudo curl jexus.org/release/upgrade | sh

 说明:使用这种命令的安装方法将会吧Jexus安装到/usr/jexus 位置。

 

————————————-华丽的分割线—>下面将ASP.NET MVC项目部署到Jexus下——————————————————-

6.  部署ASP.NET MVC项目

a. 当mono配置完成并且测试没有问题的情况下,这时候我们就需要向其部署MVC项目,那么如何部署项目呢?这块很重要

b. 那么怎么部署一个新的网站程序呢?

b.1 首先需要建立一个”网站配置文件”,jexus安装的路径下(我本机安装在/usr/jexus)下有一个siteconf文件夹,这里面的每一个文件都 是一个网站的配置文件,每一个配置文件就代表一个网站,在(/usr/jexus/siteconf/)中,就已经有一个默认的网站配置文件,文件名 为:”default”;你可以修改这个配置文件,也可以将这个配置文件赋值并修改为一个新的站点。

b.2 在配置文件中,有关键的三项是必填项:

port:端口号定义,端口号是一个整数,一般是80,也可以是65535以下的其它整数,但是这个端口号必须没有其它服务程序占用。 root:虚拟根路径和物理根路径的定义,根路径由两部分组成,中间用空格分开,空格前表示这个网站访问时的虚拟根路径(一般都是”/”,不用修改),空 格后是存放这个网站内容的文件夹的物理路径(比如:”/var/www/default/”) hosts:域名定义,填写访问这个网站的域名,如果有多个域名,域名间用英文逗号分开,同时还可以用”泛域名”,比如:”*.mysite.com”。 网站名称:jexus把网站配置文件的名称作为网站名。

b.3 首先拷贝一份default文件,拷贝到jexus安装的路径下的siteconf下,然后修改里面的内容,命令如下:

(1):cd /usr/jexus/siteconf/       (2):cp default  mms     (3):vim mms    修改之后保存如图所示: 
   

b.3 这时候在jexus中我们将网站配置文件已经配置完成,但是还没有上传网站,这时候我们需要上传网站,上传的路径如上图所示在/var/www/mms下,如果没有文件,则创建即可。

c. Visual Studio部署网站

c.1 首先我们将下面的项目迁移到Jexus下,此项目不是Demo,是一个在实际场景中使用的项目,故而结构就不截图了,只简单将主项目截图,项目结构如图所示:

c.2 然后使用VS的发布功能,将项目发布,和一般的项目发布一模一样,这里就不做详细讲解了,请参考: http://blog.sina.com.cn/s/blog_8ce459cd0102v1kx.html,在发布的时候请注意设置选项下的配置,如图所示:(我刚开始配置始终不成功就是因为这里配置的原因)

c.3 项目发布完成之后,删除无用的文件信息,如图所示:

   

d.  将项目迁移到Jexus

d.1 首先在Linux下跳转到需要放置项目的目录下(cd /var/www/mms),打开XFtp,将网站文件上传都此目录下,如图所示:

           

d.2 其次我们需要开放8080端口,在文章上面已经说过如何开放端口80,参考开放即可,这里就不在累赘了。

d.3 使用jexus的重启功能重新启动Jexus或者启动网站(./jws start或者./jws start mms(如果这个访问还是有问题,则使用前面的命令进行启动))

e.  部署完成后访问项目

e.1  部署完成之后访问发现出现了如下图所示的错误,出现了很乱的内容,这是因为Linux下是区分大小写的,故而我们需要配置jexus,使其大小写都可以转换,那么会如何配置呢?

e.2 打开jexus的配置文件(vim jws),取消# export MONO_IOMAP=”all”这段内容的前面的#,保存,然后重新启动jexus(./jws restart)

e.3 最后我们在浏览器中访问(http://192.168.37.138:8080/),如图所示:项目已经彻底迁移到Jexus下。

备注:我对项目进行了简单的操作,没有遇到任何问题。

f.  说明:本博客部署的项目是ASP.NET MVC5项目,还可以部署MVC3、4和WebApi,欢迎大家尝试,如果遇到什么问题解决不了,欢迎联系我咨询,我们共同学习。

Jexus的发展非常迅速,以前在使用Jexus下必须安装mono,现在已经出现了不需要安装mono就可以使用的Jexus版本了(当然还是依赖于mono,只不过是Jexus内部内置了一个小的mono环境),学习地址:http://www.linuxidc.com/Linux/2016-05/130920.htm

备注:本地已做测试,按照宇内大师兄的文章去实现,没有任何问题,详细请参考上面的博客。

最后感谢张善友的文章给我的思路和实现:http://www.linuxidc.com/Linux/2015-05/117633.htm

这篇文档是本人转的,亲自尝试可以使用。注:可能会有dll报版本不正确,这个需要从packages文件夹中找到对应dll重新复制 即可。

演示  http://demo.cnvpser.com:8011/