我想问本身,为何要学习PHP
,什么是PHP
,学习以后,我能作什么,将来的发展,那么如何学习一门编程语言,如何给出学习建议。javascript
php
是一种超文本预处理器的学习语言,它是一种被普遍应用的开放源代码的多用途的脚本语言,它可嵌入到HTML
中,尤为是适合web
开发。php
PHP
是一种在服务器端执行的嵌入HTML
文档的脚本语言。语言的风格相似于C
语言,如今被不少的网站编程人员普遍的运用。使用PHP
能够开发各类交互式的动态网页。css
那么如何理解动态网页呢?接下来讲一说:html
动态网站和静态网站的区别?
还有如LAMP
这些词表明什么意思呢?在PHP中经常使用到的:前端
LAMP是什么呢,须要了解一下?
L:LINUX
A:Apache
M:mysql
P:PHP
扩展性说说以下词汇,须要咱们逐步去了解。java
LAMP
: Linux+Apache+MySQL+PHP
mysql
LNMP
: Linux+Nginx+MySQL+PHP
jquery
LNMPA
: Linux+Nginx+MySQL+PHP+Apache
git
WAMP
: Window+Apache+MySQL+PHP
github
集成环境: wampserver, xampp, phpstudy
Apache
是世界上使用排名前列的web
服务器软件,它能够运行在几乎全部普遍使用的计算机平台上,因为其跨平台和安全性被普遍使用,是最流行的web
服务器端软件之一。它快速,可靠而且可经过简单的api
扩充。
那么让咱们走进PHP
世界,了解其语法结构吧!
PHP
文档结构:1.文档扩展名.php
; 2.注意,文件名不要使用中文,也不要包含特殊字符
PHP
标记风格:
下面看看代码示例:
<?php 代码段;?>
下面看看代码示例:
<?代码段;?>
注意:须要配置PHP
配置文件php.ini
中short_open_tag=On
,重启Apache
服务器便可
ASP
风格:下面看看代码示例:
<% 代码段; %>
注意:须要配置PHP
配置文件php.ini
中asp_tags=On
,重启Apache
服务器便可
PHP
语法风格示例:
<?php echo 'this is dada show dada'; <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>55555--<?php echo 'hello world';?></title> <style media="screen"> h1{ color:<?php echo '5555';?>; } </style> <script type="text/javascript"> alert('hello world'); </script> </head> <body> <h1>this is dadada show time<?php echo 'dada';?></h1> </body> </html> <?php // 标准风格的写法 // echo 输出一个或者多个字符串 /* echo 'this is a dada'; echo '<br/>'; echo 'hello world'; */ echo 'this is dada show time';
学习php
须要工具,这里能够说说常使用的phpstorm
phpstorm
的安装和使用phpstorm
是JetBrains
公司开发的一款商业的PHP
集成开发工具,能够随时帮助用户对其进行编码,运行单元测试或者提供可视化debug
功能。
进入phpstorm
官网,点击“downLoad”
按钮,进入下载页面。
最后,双击桌面图标便可。
php
文件命名注意事项:
变量的注意事项:
数据类型:
特殊符号:
单引号和双引号的区别
和
这两个转义符花括号的意义
${变量名}变量名
;{$变量名变量名}
;经过函数形式实现临时转换
intval(变量)
转成整型strval(变量)
转成字符串型boolval(变量)
转成布尔类型永久转换
settype
(变量,设置的类型)设置变量类型gettype
(变量)获得变量的类型变量函数库检测变量类型
is_int
(变量) > 检测整型is_string
(变量) > 检测字符串类型is_array
(变量) > 检测数组类型is_resource
(变量) > 检测资源类型is_object
(变量) > 检测对象类型is_null
(变量) > 检测null类型is_numeric
(变量) > 检测数值型系统常量
PHP_VERSION
:获得php
版本PHP_OS
:获得服务器的操做系统M_PI
:PI
的值$
符号检测常量是否被定义
defined
函数var_dump
(defined
变量)魔术常量
__LIEN__
获得行号__FILE__
获得文件的完整路径和文件名__FUNCTION__
函数名称__CLASS__
类__METHOD__
方法__DIR__
返回文件所在路径以点的形式来链接咱们的变量
让咱们来看看下面示例代码:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <script src="jquery-2.2.3.js" type="text/javascript"></script> </head> <body> <?php header("content-type:text/html;charset=utf-8"); $str = ''; $rand = mt_rand(1000, 9999); $str.='<span hljs-number" >0, 255).', '.mt_rand(0, 255).','.mt_rand(0, 255).') ">'.mt_rand(0, 9).'<span>'; $str.='<span hljs-number" >0, 255).', '.mt_rand(0, 255).','.mt_rand(0, 255).') ">'.mt_rand(0, 9).'<span>'; $str.='<span hljs-number" >0, 255).', '.mt_rand(0, 255).','.mt_rand(0, 255).') ">'.mt_rand(0, 9).'<span>'; $str.='<span hljs-number" >0, 255).', '.mt_rand(0, 255).','.mt_rand(0, 255).') ">'.mt_rand(0, 9).'<span>'; ?> <label for="check">请输入验证码:</label> <div id="hiddent_val" style="display: none;"><?php echo $str ?></div> <input type="text" name="check" id="check_val"/><?php echo $str; ?> <br/> <input type="button" onclick="javascript:check();" value="提交"/> <script> function check(){ var v1=$("#hiddent_val").text(); v1 = v1*1; var v2=$("#check_val").val(); v2 = v2*1; if(v1==v2){ alert('true'); }else{ alert('false'); } } </script> </body> </html>
日期函数格式代码:
data($format[,$time=time()]) time(): Y:年,m:月, d:日, h:小时, i:分钟, s:秒 w:星期一到星期天 0表示星期天 设置时区:函数形式 date_default_timezone_get() date_default_timezone_set($timezone);
预约义变量:系统内已定义的变量,以下有:
$_POST:http
-post
变量,接收表单以post
方式发送的数据$_GET:HTTP
-get
变量,接收以?
形式传参的数据$_FILES:HTTP
文件上传变量$_SERVER
:服务器和执行环境变量$_ENV
:环境变量$_SESSION
:会话变量$_COOKIE
:HTTP Cookies$_REQUEST:$_GET+$_POST+$COOKIE
$php_errormsg
前一个错误信息$GLOBALS
超全局变量,在所有做用域中始终可用的内置变量让咱们看看Switch...case
的示例代码以下:
<?php $a = 2; switch ($a){ case 1: echo 'a<br/>'; break; case 2: echo 'b<br/>'; break; case 3: echo 'c<br/>'; break; default: echo '默认的执行'; }
让咱们看看for
的示例代码以下:
<?php //1到100的数进行相加 5050, //1+2+3+4 $sum =0; for($i=0;$i<101;$i++){ $sum = $sum+$i; } echo $sum; echo '<hr/>'; //1到100可以被2整除的数, for($i=1;$i<101;$i++){ if($i%2==0){ echo '这是可以被2整除的数:'.$i.'<br/>'; } }
学习小案例以下-乘法表代码:
<?php /* 1*1=1; * 1*2=2 2*2=4 * */ for($i=1;$i<=9;$i++){ for($j=1;$j<=$i;$j++){ echo $j.'*'.$i.'='.($i*$j)."t"; } echo '<br/>'; }
特殊流程控制-示例:
<?php //break跳出整个for循环 for($i=1;$i<10;$i++){ if($i==3){ break; } echo '这里是$i的值:'.$i.'<br/>'; } echo '<hr/>'; //continue跳出当前循环 for($i=1;$i<10;$i++){ if($i==3){ continue; } echo '这里是$i的值:'.$i.'<br/>'; } echo '<hr/>'; echo '这里是开始部分'; goto jump; echo '这里是jump下面的代码'; jump: echo '这里是jump里面的代码'; echo '<hr/>'; echo '这里是结束部分';
什么是PHP数组呢?数组是什么呢?- 数组:数据的集合,在php
中数组其实是一个有序映射。
经过array()
形式声明:
array()
空数组array(值1,值2...)
下标连续的索引数组,数组的下标从0开始array(key=>value,key=>value...)
能够声明索引数组和关联经过:print_r
打印数组
数组或者混合数组:
true
转换为1,false
转换为0null
转换为空字符串动态建立数组:
$
数组名称[]
:下标连续的索引数组$
数组名称[数字]
:指定数组索引$
数组名称[字符串]
:关联数组快速建立数组-示例格式:
range($min, $max[$step=1]); 快速建立索引数组 compact($varname,...);快速建立关联数组
学习小示例:
<?php // $arr = array(); // var_dump($arr); //索引数组 下标是从数字开始的 $arr = array( 1, 5.5, false, 'dada' ); print_r($arr); echo '<hr/>'; //array(key=>value,key=>value...) $arr1 = array( 5=>'dada', 6=>12, 9=>false, 4=>4.4 ); print_r($arr1); echo '<hr/>'; //关联数组,下标是字符串 //username 能够称呼为咱们的键名, //咱们的键名所对应的值就是键值 $arr2 = array( 'username'=>'dada', 'password'=>123456, 'age'=>27 ); print_r($arr2); echo '<hr/>'; //索引+关联混合使用 $arr3 = array( 1,2,3,4,5, 'username'=>'dadaqianduan', 'addr'=>'haha' ); print_r($arr3); echo '<hr/>'; $arr3['username'] = 'dada'; print_r($arr3);
current($arr)
,获得数组当前指针所在位置元素的键值key($arr)
,获得数组当前指针所在位置元素的键名next($arr)
,将数组指针向下移动一位,而且获得数组指针所在位置元素的键值prev($arr)
,将数组指针向上移动一位,而且返回当前指针所在位置元素的键值end($arr)
,将数组指针移动到数组的末尾,而且返回当前元素的键值reset($arr)
,将数组指针移动到数组的开始,而且返回当前元素的键值经过foreach遍历数组
foreach(数组名称 as $key=>$val){}
经过list和each遍历数组
list($var[,$var...])
:把数组中的值赋给一些变量each($arr)
返回数组中当前的键/值对并将数组指针向前下移动一位如何建立用户列表页面,示例代码格式以下:
<tr style="text-align:center;"> </tr> <?php foreach($userInfo as $val){ ?> <tr style="text-align:center;"> <td><?php echo $val['id'];?></td> <td><img src="img/<?php echo $val['id'];?>" alt=""/></td> </tr> <?php }?>
如何添加留言页面,示例代码格式以下:
<body> <h2>添加留言页面</h2> <form action="doAction.php?act=add" method="get"> <table border="1" width="80%" cellpadding="0" cellspacing="0" bgcolor="blue"> <tr> <td>留言者</td> <td><input type="text" name="username" id="" placholder="请输入您的呢称"/></td> </tr> </table> </form> </body>
提交反映-doAction.php
<?php $username = $_GET['username']; $title = $_GET['title']; $content = $_GET['content']; $arr[] = array( 'username' => $username, 'title' => $title, 'content' => $content ); print_r($arr);
收集留言信息:
$filename = 'text.txt'; $data = 1; file_put_contents($filename, $data);
<input type="hidden" name="act" value="add"/> ?php $username = isset($_GET['username']) ? $_GET['username'] : ''; $time = date('Y-m-d h:i:s'); $act = isset($_GET['act']) ? $_GET['act']:''; // 是不是添加页面 // 判断 if(file_exists($filename) && filesize($filename)>0){ $str = file_get_contents($filename); $arr = unserialize($str); } if($act == 'add'){ ... $arr = serialize($arr); file_put_contents($filename, $arr); }
if($act == 'add') { $arr[] = array( 'username' => $username, 'title' => $title, 'content' => $content, 'time' => $time ); $arr = serialize($arr); if(file_put_contents($filename, $arr)){ echo'添加留言成功'; }else{ echo '添加留言失败'; }; }
总结9点经常使用函数,下面来看看它们各有什么含义以及做用:
strlen($string)
获得字符串长度strpos($string,$search[,$offset])
:在指定字符串中查找目标字符串第一次出现的位置stripos($string,$search[,$offset])
:忽略大小写的去查找strrpos($string,$search[,$offset])
:在指定字符串中查找目标字符串最后一次出现的位置strripos($string,$search[,$offset])
:忽略大小写的去查找最后一次出现的位置strstr|strchr($string,$search[,$before_needle])
:查找字符串的首次出现,返回的是字符串strrchr($string,$search)
:查找指定字符在字符串中的最后一次出现stristr($string,$search[,$before_needle])
:忽略大小写的去查找str_replace($search,$replace,$string)
:在指定字符串中去查找另一个字符串,找到以后将其替换成指定字符串str_ireplace($search,$replace,$string)
:忽略大小写的去查找并替换strtolower($string)
:返回小写以后的字符串strtoupper($string)
: 返回大写以后的字符串ucwords($string)
:单词的首字母大写ucfirst($string)
:字符串的单词的首字母大写lcfirst($string)
:字符串的单词的首字母小写ord($char)
:获得指定字符的ASCIIchr($ascii)
:根据ASCII获得指定的字符substr($string,$start[,$length])
:截取字符串substr_replace($string,$replace,$start[,$length]):
替换字符串的子串md5($string)
: 计算字符串的md5的散列值,返回32
位长度的字符串sha1($string)
: 计算字符串的sha1的散列值,返回40
位长度的字符串trim($string[,$charlist])
:默认过滤字符串两端的空格,也能够过滤指定字符串ltrim($string[,$charlist])
:过滤字符串左端rtrim | chop($string[,$charlist])
:过滤字符串右端strip_tags($string[,$allowTag])
:过滤字符串中的html标记addslashes($string)
:使用反斜线引用字符串中的特殊字符htmlentities($string[,$flag=ENT_COMPAT])
:将全部字符转换成HTML实体htmlspecialchars($string[,$flag=ENT_COMPAT]
:将字符串中的特殊字符转换成HTML实体nl2br($string)
:将字符串中的n
用<br/>
替换explode($delimiter,$string)
将指定字符串拆分红数组implode | join($delimiter,$array)
以指定分隔符将数组中的键值链接成字符串str_split($string[,$split_length=1])
将字符串转换成数组strrev($string)
反转字符串str_shuffle($string)
随机打乱字符串str_repeat($string)
重复字符串str_getcsv(...)
解析csv字符串为一个数组parse_str($str[,$arr])
将字符串解析成多个变量接下来以表格的形式展现以下内容
数学函数库表格以下:
函数
说明
abs($number)
求绝对值
ceil($number)
进一取整
floor($number)
舍掉小数部分
round($number,$percision)
四舍五入
pow($base,$exp)
幂运算
sqrt($number)
平方根
max($val1,$val2,..)
求最大值
min($val1,$val2...)
求最小值
mt_rand($min,$max)
产生随机数
日期时间函数库表格以下:
函数
说明
date_default_timezone_get()
获得默认时区
date_default_timezone_set($timezone)
设置默认时区
date($format[,$time])
获得服务器的日期时间
time()
获得当前的时间戳
mktime()
取得一个日期的unix时间戳
getdate($timestamp)
取得日期时间信息
gettimeofday($return_float)
取得当前时间
microtime([$get_as_float])
返回当前unix时间戳和微妙数
strtotime($time[,$now=time()])
将任何英文文本的日期时间描述解析为unix
时间戳
建立数组操做
函数
描述
range($min, $max[,$step=1])
快速建立下标连续的索引数组
compact($varname,$varname...)
快速建立关联数组
array_fill($start_index,$num,$value)
用给定的值填充数组
array_fill_keys($keys,$value)
使用指定的键和值填充数组
array_combine($keys,$values)
建立一个数组,用一个数组的值做为其键名,另一个值做为其键值
键值相关操做表格以下:
函数
描述
count()
计算数组中的单元数目或对象中的属性个数
array_keys($array)
取得数组的键名做为下标连续的索引数组返回
array_values($array)
取得数组的键值做为下标连续的索引数组返回
array_filp($array)
交换数组中的键名和赋值
in_array()
检测数组中是否存在某个值
array_search()
在数组中搜索给定的值,若是成功则返回相应的键名
arry_key_exists()
检查给定的键名或索引是否存在于数组中
array_reverse()
数组倒置
shuffle()
打乱数组的元素
array_rand()
随机取出数组的键名
array_unique()
移除数组中重复的值
array_sum()
统计数组中元素值的总和
数组指针函数表格以下:
函数
描述
key($array)
获得当前指针所在位置元素的键名
current($array)
pos($array)
获得当前指针所在位置元素的键值
next($array)
将数组指针向下移动一位,而且返回当前指针所在位置元素的键值
prev($array)
将数组指针向上移动一位,而且返回当前指针所在位置元素的键值
end($array)
将数组指针移动到数组的末尾,而且返回当前指针所在位置元素的键值
reset($array)
将数组指针移动到数组的开始,而且返回当前指针所在位置元素的键值
each($array)
返回数组中当前的键值对,并将数组指针向下移动一位
list($var,...)
将数组中元素的值赋给对应的变量
array_unshift($array,$value...)
在数组开头插入一个元素或者多个元素
array_shift($array)
弹出数组的第一个元素
array_push($array,$value...)
在数组末尾压入一个元素或者多个元素
array_pop($array)
弹出数组的最后一个元素
数组的拆分与合并表格以下:
函数
描述
array_slice($array,$offset)
截取数组
array_merge()
合并数组
如何声明函数呢?来看看以下代码:
function 函数名称([参数...]){ 函数体; return 返回值; }
注意事项:
接下来咱们看看带入的函数参数:
参数分为形参和实参:
形参,定义函数时声明的参数(必选参数:调用函数的时候必选要传参;可选参数:调用函数的时候若是不传参数,使用默认值;)
实参,调用函数时实际传入的参数
接下来了解变量的做用域,以下思惟导图:
接下来讲说函数的传值和传引用区别:
回调函数是什么呢?
在开发过程当中,有时候但愿针对一个对象或者一个值执行多个不相干的操做,那么运用回调将是最好的方式。
<?php function text1(){ echo '我是达达'; } function text2($username){ echo '我是哪吒'; } // 回调函数:函数体内的名称是咱们要传入的参数(); function callBack($call,$str){ $call($str); } // 回调函数的使用就是传入的参数是你想要回调的函数名称 callBack('text2','dadaqianduan');
什么是递归函数,即函数体本身调用本身自己
写法示例:
function text($i) { echo $i; $i--; if($i>=0){ text($i); } } text(2);
匿名函数示例:
$str = function() { echo 'dadaqianduan'; }; $str(); $str1 = function($username) { echo 'dada'; echo $username; }; $str1('哪吒');
php的文件包含:include
,include_once
,require
,require_once
,就是将一个文件的内容包含进另一个文件。
require
引用文件出错的时候 是一个报错一个警告include
引用文件出错的时候 是两个警告require
会生成致命错误并中止脚本include
只会生成警告,而且脚本会继续因此这里建议你使用include
哦!
include
或require
语句会获取指定文件中存在的全部文本,代码,标记,并复制到使用include
语句文件中。
语法格式以下:
include 'filename'; 或 require 'filename';
php include示例:
让咱们来建立要给名为'dada.php'的标准的页脚文件,代码以下:
<?php echo '<p> 达达 哪吒</p>'; ?>
而后须要在另外一个页面中引用这个页脚文件以下:
<html> <body> <p>魔王哪吒</p> <?php include 'footer.php'; ?> </body> </html>
require_once/include_once
,与require/include
做用相同,不一样在于执行到时会先检查目标内容是否是在以前已经导入过,若是导入过了,那么便不会再次重复引入其一样的内容。
首先了解面向对象是什么呢?
它是一种思想,是一种开发方式,并非实际的代码。
谈到面向对象,就要说到面向对象与面向过程的区别:
面向的几种方式:
OOA(Object Oriented Analysis)面向对象分析 OOD(Object Oriented Design)面向对象设计 OOP(Object Oriented Programming)面向对象编程
说到面向对象就离不开类和对象的关系:类是具体事务的抽象,对象是这个类的具体实例。
怎么样定义一个类,类的定义:(相似class关键字来定义的)
class Person{ } <?php // 定义一我的类 class Person{ // 类里面是有属性和方法存在的 // public 访问修饰符 public $userName = 'dada'; public $age = 12; } // 经过new 关键字来建立咱们的对象 $p = new Person(); echo $p->userName.'<hr/>'; echo $p->age.'<hr/>';
属性讲了,说说方法吧,以下示例:
<?php class Person{ public $userName; public $age; // 类里面的行为称为方法 public function eat() { echo '我要吃饭'; } } $p = new Person(); $p->eat();
来讲一下对象的内存分析,在PHP中,内存被划分为四个:
访问修饰符有哪些呢?以下展现:
public
公共的,默认protected
受保护的private
私有的代码示例以下
<?php class Da{ public $userName = 'dada'; protected $age = 12; public function eat() { echo '我要吃饭'; } } $da = new Da(); echo $da->userName echo $da->age // 报错
修改以下:
<?php class Da{ public $userName = 'dada'; protected $age = 12; public function eat() { echo '我要吃饭'; //$this echo $this->age; } } $da = new Da(); echo $da->userName echo $da->eat()
首先什么是构造函数呢?构造函数是经过new
对象的时候会被调用的。
其次析构函数是什么?析构函数首先不能带有参数,析构函数会在对象的全部引用被删除或者显示的消失以前被调用。
<?php class Person { public $userName; public $age; // php5.5以前的写法 // public function Person() { // echo '我是构造函数'; // } // 经过一个魔术常量来写构造函数 public function _construct($userName,$age) { // $this表示的是当前对象 $this->userName = $userName; $this->age = $age; } // 析构函数 public function _destruct(){ echo '析构函数' } } $p1 = new Person('dada',12); echo $p1->userName $p1 = null; // 析构函数被调用
了解set和get
方法:set
对外界提供设置成员属性的方法,而get
对外界提供访问成员属性的方法。
因此魔术常量:_set
和_get
。
以下示例:
<?php class Person{ private $userName; private $age; public function setAge($age){ // $this->age = 12; // $this-age == private $age; $this->age = $age; } public function getAge(){ return $this->age; } public function _set($key,$value){ $this->userName = $value; } public function _get($key){ return $this->userName; } $p = new Person(); // echo $p->userName; $p->setAge(16); echo $p->getAge();
_isset
当外部调用isset()
函数检测不可访问的属性或者不存在的属性时自动调用。_unset
当在类外部调用unset
销毁不可访问属性时自动调用。以下示例表示:
<?php class Person{ private $userName; private $age; public $abc; public function _construct($userName,$age){ $this->userName=$userName; $this->age=$age; } public function _isset($name){ echo '当外部调用isset()函数检测不可访问的属性或者不存在的属性时自动调用'; return isset($name); // boolean } public function _unset($name){ echo '当在类外部调用unset销毁不可访问属性时调用'; } } $p = new Person('dada',12); var_dump(isset($p->userName)); // echo '<hr/>' unset($p->abc);
下面来讲说面向对象的继承,封装,多态中的继承特色:
那么继承的意义在于哪里,用继承能够减小重复代码,经过extends
关键字来继承。
代码示例以下:
<?php class Person{ public $userName; public $age; public function eat(){ echo 'dadaqianduan'; } } class Student extends Person{ } $stu = new Student(); echo $stu->eat();
parent
关键字继承中使用parent
,代码以下:
<?php class Person { public $userName='parent'; public $age = 100; protected function eat() { echo `老爸要吃饭`; } } class Student extends Person { public $userName = 'children`; public $age = 12; // 重写 须要访问的修饰符必须和父类的平级或者大于父类,方法名字相同 public function eat() { parent::eat().'<hr/>'; echo 'children'; } } $stu = new Student(); echo $stu->eat();
使用final关键字注意事项:
final
关键字不能修饰属性final
修饰过的class
和方法不能被继承或者重写static
用于表示静态的意思:
static
所修饰的属性和方法都是静态的属性和方法下面代码示例以下:
class Person { public static $i = 1; public static function eat(){ echo '要吃饭'; } } echo Person::$i; Person::eat();
self
在类内部经过self
来访问静态的属性和方法:
下面代码示例以下:
class Student { public static $i = 1; public static function eat(){ echo self::$i; } } Student::eat();
下面示例静态绑定的用法以下:
<?php class A{ public static function text1(){ echo 'text1'; } public static function text2(){ echo 'text2'; self::text1(); } } class B extends A { public static function text1(){ echo 'B-A'; } } B::text2();
const,为常量修饰符,常量的特色,不能被修改,惟一的标识符,注意以下:常量要大写,不能经过对象来访问,不须要加$
符号。
示例链接数据库:
<?php header("content-type:text/html;charset=urf-8"); // 创建链接而且返回链接对象 $link = mysqli_connect('localhost','root','root') or die('链接失败'); // 设置字符集 mysqli_set_charset($link,'utf8'); // 打开指定数据库 mysqli_select_db($link, 'dadaqianduan'); // 执行sql语句 $query = "insert user values(1,'dada','12345')“; $res = mysqli_query($link, $query); if($res){ echo '插入数据成功'; }else{ echo '插入数据失败'; }
因此mysqli
操做数据库的步骤有:
mysql
sql
查询若是每次使用都要重写链接数据库,那么咱们能够进行封装:
封装数组:config.php
<?php $config = array( 'host'=>'localhost', 'user'=>'root', 'password'=>'root', 'charset'=>'utf8', 'dbName'=>'dadaqianduan' ); define('DB_HOST','localhost'); define('DB_USER','root'); define('DB_PWD','root'); define('DB_CHARSET','utf8'); define('DB_DBNAME','dadaqianduan');
链接
<?php /** * 链接 * @param string $host * @param string $user * @param string $password * @param string $charset * @param string $database * @return object 链接标识符 */ function connect1($host,$user,$password,$charset,$database){ $link = mysqli_connect($host,$user,$password) or die('数据库链接失败'); mysqli_set_charset($link,$charset); mysqli_select_db($link,$database) or die('指定数据库打开失败'); return $link; }
链接 须要传递数组
/** * 链接 须要传递数组 * @param array $config * @return object */ function connect2($config){ $link=mysqli_connect($config['host'],$config['user'],$config['password']); mysqli_set_charset($link,$config['charset']); mysqli_select_db($link,$config['dbName'] or die('指定数据库打开失败'); return $link; }
用常量的形式创建链接
/** * 用常量的形式创建链接 * @return unknown */ function connect3(){ $link = mysqli_connect(DB_HOST,DB_USER,DB_PWD) or die('数据库链接失败'); mysqli_set_charset($link,DB_CHARSET); mysqli_select_db($link,DB_DBNAME) or die('指定数据库打开失败'); return $link; }
插入操做
/* array( 'username'=>'dada', 'password'=>'dada', 'age'=>'123456', 'regTime'=>'12345' ); INSERT user(username,password,age,regTime) VALUES('dada','dada','12','123123123'); */ /** * 插入操做 * @param object $link * @param array $data * @param string $table * @return boolean */ // 插入的封装 function insert($link,$data,$table){ $keys=join(',',array_key($data)); $vals = "'".join("','", array_values($data))."'"; $query = "insert{$table}({$keys})values({$vals})"; $res = mysqli_query($link,$query); if($res){ return mysqli_insert_id($link); }else{ return false; } }
更新操做
/* array( 'username'=>'dada', 'password'=>'dada', 'age'=>'12', 'regTime'=>'123123123' ); UPDATE user SET username='dada',password='dada',age='12',regTime='123123123' WHERE id=1 */ /** * 更新操做 * @param object $link * @param array $data * @param string $table * @param string $where * @return boolean */ function update($link, $data, $table, $where = null) { foreach ( $data as $key => $val ) { $set .= "{$key}='{$val}',"; } $set = trim ( $set, ',' ); $where = $where == null ? '' : ' WHERE ' . $where; $query = "UPDATE {$table} SET {$set} {$where}"; $res = mysqli_query ( $link, $query ); if ($res) { return mysqli_affected_rows ( $link ); } else { return false; } }
删除操做
//DELETE FROM user WHERE id= /** * 删除操做 * @param object $link * @param string $table * @param string $where * @return boolean */ function delete($link, $table, $where = null) { $where = $where ? ' WHERE ' . $where : ''; $query = "DELETE FROM {$table} {$where}"; $res = mysqli_query ( $link, $query ); if ($res) { return mysqli_affected_rows ( $link ); } else { return false; } }
查询全部记录
/** * 查询全部记录 * @param object $link * @param string $query * @param string $result_type * @return array|boolean */ function fetchAll($link, $query, $result_type = MYSQLI_ASSOC) { $result = mysqli_query ( $link, $query ); if ($result && mysqli_num_rows ( $result ) > 0) { while ( $row = mysqli_fetch_array ( $result, $result_type ) ) { $rows [] = $row; } return $rows; } else { return false; } }
获得表中的记录数
/** * 获得表中的记录数 * @param object $link * @param string $table * @return number|boolean */ function getTotalRows($link, $table) { $query = "SELECT COUNT(*) AS totalRows FROM {$table}"; $result = mysqli_query ( $link, $query ); if ($result && mysqli_num_rows ( $result ) == 1) { $row = mysqli_fetch_assoc ( $result ); return $row ['totalRows']; } else { return false; } }
获得结果集的记录条数
/** * 获得结果集的记录条数 * @param object $link * @param string $query * @return boolean */ function getResultRows($link, $query) { $result = mysqli_query ( $link, $query ); if ($result) { return mysqli_num_rows ( $result ); } else { return false; } }
获取信息的封装:
/** * @param object $link */ function getServerInfo($link) { return mysqli_get_server_info ( $link ); } /** * @param object $link */ function getClientInfo($link) { return mysqli_get_client_info ( $link ); } /** * @param object $link */ function getHostInfo($link){ return mysqli_get_host_info($link); } /** * @param object $link */ function getProtoInfo($link) { return mysqli_get_proto_info ( $link ); }
下面展现介绍,思惟导图以下:
Redis 是一个开源(BSD
许可)的,内存中的数据结构存储系统,它能够用做数据库、缓存和消息中间件。 它支持多种类型的数据结构,如 字符串(strings
), 散列(hashes
), 列表(list
), 集合(sets
), 有序集合(sorted sets
) 与范围查询, bitmaps
, hyperloglogs
和 地理空间(geospatial
) 索引半径查询。 Redis
内置了 复制(replication
),LUA脚本(Lua scripting
), LRU驱动事件(LRU eviction
),事务(transactions
) 和不一样级别的 磁盘持久化(persistence
), 并经过 Redis哨兵(Sentinel
)和自动 分区(Cluster
)提供高可用性(high availability
)。
优势:
IO
操做Redis
安装
Window
下安装
下载地址:https://github.com/tporadowski/redis/releases
。
Redis
支持 32 位和 64 位。这个须要根据你系统平台的实际状况选择,这里咱们下载 Redis-x64-xxx.zip
压缩包到 C 盘,解压后,将文件夹从新命名为 redis
。
打开文件夹,内容以下:
打开一个 cmd
窗口 使用 cd
命令切换目录到xxx:redis
运行:
redis-server.exe redis.windows.conf
另启一个 cmd
窗口,原来的不要关闭,否则就没法访问服务端了。
设置一下是否生效:
Composer
是 PHP
用来管理依赖(dependency
)关系的工具。你能够在本身的项目中声明所依赖的外部工具库(libraries
),Composer
会帮你安装这些依赖的库文件。
https://getcomposer.org/
点击Getting Started
点击下载:
https://developer.aliyun.com/composer?spm=a2c4e.11153940.0.0.40eb6995J6zupg
检查:
Windows
快速配置NodeJS
配置淘宝镜像源的命令行:
npm config set registry http://registry.npm.taobao.org
Windows
快速配置Bower
在Windows
下使用phpStudy
安装
fastadmin.net/go/tencent
https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html
下载
https://www.bt.cn/?invite_code=MV9veWhubmU=
点击当即安装https://www.bt.cn/bbs/thread-19376-1-1.html
yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh
Internal Server Error The server encountered an internal error or misconfiguration and was unable to complete your request. Please contact the server administrator at admin@php.cn to inform them of the time this error occurred, and the actions you performed just before this error. More information about this error may be available in the server error log.
修改.htaccess
为如下内容
<IfModule mod_rewrite.c> RewriteEngine On RewriteBase / RewriteRule ^index.php$ - [L] RewriteCond %{ENV:REDIRECT_STATUS} ^$ RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule . /index.php [L] </IfModule>
Node.js
(可选,用于安装Bower和LESS,同时打包压缩也须要使用到)Composer
(可选,用于管理第三方扩展包)Bower
(可选,用于管理前端资源)Less
(可选,用于编辑less文件,若是你须要增改css样式,最好安装上)好了各位,以上就是这篇文章的所有内容,能看到这里的人都是人才。我后面会不断更新技术相关的文章,若是以为文章对你有用,欢迎给个“赞”,也欢迎分享,感谢你们 !!