PHP语言
一、认识前后端
前端:用户可见的界面,数据展示在页面上给用户看到
后端:分为服务器端和数据库
服务器端:把前端要展示的数据存储到数据库中,前端需要时把数据库的数据再传递给前端(服务器端:我们学习php语言,php语言运行在apache服务器上) 数据库:一个存储数据的仓库(mysql),可以让后端进行数据的增删改查(mysql)
展示方面: ??????前端之间看到,布局,图文,交互和特效。 ??????后端没办法直接看到,数据存取,业务逻辑
使用技术: ??????前端HTML5、Css3、JavaScript、Ajax,vue,react ??????后端Java、php、python、算法、数据库、服务器
工作职责: ??????前端web前端开发,移动端和小程序 ??????后端业务逻辑实现,功能接口实现
二、前后端交互
我们是一个前端开发工程师 还有一个工作叫做后端开发工程师(Java、php、nodejs) 我们一个网站的组织架构基本上有下面的步骤完成
用户 => 前端 => 后端 => 数据库
比如: 我们浏览一个新闻网站
1)用户输入网址
2)前端人员就要把对应的页面给到用户,在页面打开的过程中,想后端人员索要新闻信息
3) 后端人员接收到前端人员索要新闻信息以后,就去数据库中找到对应的新闻信息数据给前端人员
4) 前端人员接收到后端人员给的新闻信息以后,使用我们的办法吧新闻信息数据渲染在页面上
5) 页面就打开了,用户就可以看到一个新闻网站了
再比如:
用户登陆一个网站
1) 当用户书写完表单内容以后,点击提交按钮的时候
2) 前端人员拿到用户填写的内容,把数据整合好传送给后端人员
3) 后端人员接收到数据以后,去数据库中进行比对,看看有没有对应的数据
4) 然后告诉前端人员,你给我的用户名和密码是否正确
5) 前端吧信息反馈给客户看到
- 如果正确就是跳转页面
- 如果不正确提示用户名或者密码有问题
三、服务器的简单理解
1、为什么要用服务器:
我们不可能把所有的网页数据全部保存在电脑上,第一不安全,第二太大。 所以我们把前端需要的数据放在网路的另一端,需要的时候通过网络来进行请求。
2、什么是服务器
它就是一个电脑,当他跑起来一些程序的时候,就是一个服务器。
我们的电脑也能变成一个服务器,只要跑一些特殊的程序就可以,只不过它没有专业的服务器运算,
存储的能力强
常见的服务器软件:
目前常用的服务器就是Apache和Tomcat
我们要学习的服务器就是apache,它是php的运行环境
服务器语言端除了PHP还有,JSP(java),ASP,python,nodeJS,go等等。
PHP:personal home page;
3、服务器是通过什么被访问
什么是ip地址:
为计算机网络相互连接进行通信而设计的协议。具有唯一性
什么是域名:
域名:每一台计算机都有一个唯一ip地址,特别难记,所以出现了今天的(域名)。像www.baidu.com
端口号:简单理解为当你使用ip地址访问到电脑以后,帮你确定访问的是哪一个服务器软件
https://www.baidu.com:443
协议 域名 端口号
http协议的默认端口号是80
https协议的默认端口号是443
端口:服务器端也有文件夹(0-255)
文件夹内部有子文件夹,(0-255)
0~ 605535 多个端口
四、PHP介绍
??????php是一门后端语言,是一门服务端的语言,运行在服务器端 ??????php是PHP的后缀,我们能看懂代码即可 ??????主要目标是允许web开发人员快速编写动态网页 一句话概括:PHP是一种创建动态交互性站点的强有力的服务器端脚本语言。
为什么要学习一个后端语言呢?
??????目前市场上的需求,要求前端人员掌握一个后端语言 ??????方便和后端开发人员进行交互 ??????补充:服务器端除了PHP还有JAVA,JSP,python,nodejs,go等语言。
PHP优点: ??????跨平台,同时支持多种数据库(mysql(关系型数据库),MongoDB(非关系型数据库)) ??????安全性和效率好 ??????使用成本低 ??????相比其他后端语言,简单易学 缺点: ??????安装比较复杂,配置比较多,太灵活
PHPStudy(PHP运行环境一键安装包)PHPstudy是搭建服务器的工具,我需要把我写的php代码放在phpstudy工具的WWW目录下,‘www’就是服务器的目录,即放置项目代码的目录。 自己的计算机访问自己的服务器,可以在地址栏里输入locahost或者127.0.0.1
五、php基本语法
1、注意点
??????PHP脚本可放置于文档中的任何位置。PHP脚本以<?php开头,以?>结尾:
<?php
?>
??????PHP文件的默认文件扩展名是".php" ??????PHP语句以分号结尾; ??????PHP代码块的关闭标签也会自动表明分号(因此在 PHP 代码块的最后一行不必使用分号)
2、PHP中的注释
PHP代码中的注释不会被作为程序来读取和执行。它唯一的作用是供代码编辑者阅读。 PHP支持三种注释:
<?php
# 这也是单行注释
?>
3、PHP变量
变量是存储信息的容器:
<?php
$x=5;
$y=6;
$z=$x+$y;
echo $z;
?>
**注释:**请把变量视为存储数据的容器。
变量规则: ??????变量以$符号开头,其后是变量的名称 ??????变量名称必须以字母或下划线开头 ??????变量名称不能以数字开头 ??????变量名称只能包含字母数字字符和下划线(A-z、0-9以及_) ??????变量名称对大小写敏感( $y与 $Y 是两个不同的变量)
4、PHP输出
??????echo 和 print 之间的差异 ??????echo 能够输出一个以上的字符串 ??????print 只能输出一个字符串,并始终返回1 ??????echo 比 print 稍快,因为它不返回任何值
<?php
echo "<h2>PHP is fun!</h2>";
echo "Hello world!<br>";
echo "I'm about to learn PHP!<br>";
?>
展示如何用 echo 命令来显示字符串和变量:
<?php
$txt1="Learn PHP";
$txt2="W3School.com.cn";
$cars=array("Volvo","BMW","SAAB");
echo $txt1;
echo "<br>";
echo "Study PHP at $txt2";
echo "My car is a {$cars[0]}";
?>
5、PHP的数据类型
三大类:
在这里插入代码片
1.基本数据类型1.1 整型1.2 小数1.3 布尔类型1.4 字符串 2. 复合数据类型2.1 数组类型2.2 对象类型 3. 特殊数据类型3.1 null
6、PHP字符串
var_dump() 会返回变量的数据类型和值 字符串可以是引号内的任何文本。您可以使用单引号或双引号:
<?php
$x = "Hello world!";
echo $x;
echo "<br>";
$x = 'Hello world!';
echo $x;
?>
7、PHP整数
整数是没有小数的数字。int
<?php
$x = 5985;
var_dump($x);
echo "<br>";
$x = -345;
var_dump($x);
echo "<br>";
?>
8、PHP浮点数
浮点数是有小数点或指数形式的数字。float
<?php
$x = 10.365;
var_dump($x);
echo "<br>";
?>
9、PHP逻辑
逻辑是 true 或 false。
$x=true;
$y=false;
var_dump($x);
10、PHP数组
数组在一个变量中存储多个值。
$arr = array('hello','hi','world')
for($i =0;i<count($arr);$i++){
echo $arr[$i].'<br>';
}
<?php
$cars=array("Volvo","BMW","SAAB");
var_dump($cars);
?>
11、PHP与前端交互(重点)
PHP接收前端的数据
$_GET[‘参数名’]
$_GET['username']获取usersname
$_GET['password']获取password
$_POST[‘参数名’]
$_REQUEST['参数名']
请求参数有中文的解决方案:
header('Content-type:text/html;charset=utf-8');
<?php
header('Content-type:text/html;charset=utf-8');
$nick = $_GET['name'];
?>
六、数据库
1、数据库的概念
概念:数据库是按照数据结构来组织,存储和管理数据的仓库。一个数据库是由多张数据表组成的。
库:仓库 表:一个仓库被分为了很多的部分,很像类(Student) 字段:很像类的属性(id name sex password)
每个字段的数据类型: int —> 整数类型 float —> 浮点数 char —> 定长字符串 varchar —> 变长字符串 blob —> 二进制类型 date —> 日期类型
2、常见的数据库
关系型数据库 oracle、mysql、SQLServer、DB2、sybase
非关系型数据库 Redis、HBAse、CouchDb、MongoDB
3、MySQL的使用
使用工具:phpstudy,点击MySQL管理器,选择MySQL-front,进入SQL编辑器
创建数据库:鼠标右键(可视化面板)代码:create database数据库名 打开一个库: use mydb 创建表:
create table students(
id int not null primary key AUTO_INCREMENT,
name varchar(8) not null,
sex char(4) not nul,
age tinyint not null
)
primary key:表示唯一的主键
id int not null primary key AUTO_INCREMENT,
增加一条记录
insert into student(username,userpass) values('张三丰','123');
删除
delete from student where username='张三丰
查询
select * from student where username='张' and usersex='男'
查询出来的是一个表格的形式
改
update student set usersex='女' where username='张三丰'
例子:
新增insert [into] 表名[{列名1,列名2,…}] values (值1,值2)
例如:
insert into students(name,sex,age) values('孙丽华','女',21)
查询select 列名称 from 表名称[查询条件]
select name,age,from students;
select* from students;
select* from students where age>12
select* from students where name like '%王%'; 模糊查询
select* from students where id<5 and age>20
删除
delete from 表名称 where 删除条件;
delete from students;删除表中的所有数据
delete from students where id=2;删除表中id为2的数据
delete from students where age<20;删除表中年龄小于20
修改update 表名称 set 列名称=新值 where 更新条件
update students set age = age+1
update students set name='张伟鹏',age=19 where tel='13067999999'
4、PHP连接MySQL
1、连接数据库:mysqli_connect();
语法:mysqli_conncet(servername,username,password,dbname); 参数: ● servername:规定要连接的服务器的名称:默认是’localhost:3306’ ● username:规定登录所使用的用户名,默认值是拥有服务器进程的用户 ● password:规定登录所用的密码,默认是’’ ● dbname:表示式数据库名 返回值:返回一个代表到 MySQL 服务器的连接的对象。 示例:
$con = mysqli_connect('localhost','root','root','mydb')
if(!$con){
echo('连接失败')
}else{
echo('连接成功')
}
2、增加内容:
给students表中插入数据
$sql = 'insert into student(username,password) values("1988","洪七公")'
mysqli_query($conn,$sql)返回插入成功还是失败. 成功返回true。失败返回false
if(mysqli_query($conn,$sql)){
echo '新记录插入成功'
}else{
echo 'error'.$sql.'<br>'.mysqli_error($conn)
}
mysqli_num_rows()表示影响行的个数
$rowCount = mysqli_num_rows($result);
if ($rowCount==0) {
echo '登录失败,用户名或者密码错误';
}else{
echo '<script>location.href="http://www.baidu.com"</script>';
}
3、查询
$sqlstr ='select*from student';
$result = mysqli_query($conn,$sqlstr);
查询行:$query_num = mysqli_num_rows($result)
查询列:$query_cols = mysqli_num_fields($result)
$query_row = mysqli_fetch-array($result);拿出结果集中的某一行,返回的是拿到的行
函数返回结果集中行的数量:mysqli_num_rows(result);
函数返回结果集中字段(列)的数量:mysqli_num_fields(result)
函数从结果集中取得一行作为关联数组:mysql_fetch_array(result)
5、前后端交互
1、接收前端发来的数据 2、逻辑处理 3、响应数据
注册
header('content-type:text/html;charset=utf-8');
$name = $_POST['username'];
$pass = $_POST['password'];
$con = mysqli_connect('localhost','root','root','my2102');
if ($con) {
$sql = 'insert into book(username,userpass) values("'.$name.'","'.$pass.'")';
$result = mysqli_query($con,$sql);
}else{
echo '连接失败';
}
if ($result) {
echo '注册成功';
}else{
echo '注册失败';
}
mysqli_close($con);
登录
header('content-type:text/html;charset=utf-8');
$username = $_POST['username'];
$password = $_POST['password'];
$conn = mysqli_connect('localhost','root','root','my2102');
if ($conn) {
echo '连接成功';
$sql = 'select * from book where username="'.$username.'" and userpass="'.$password.'"';
执行查询语句,返回的是一个表格,需要通过mysqli_num_rows($result)来查看影响了多少行
$result = mysqli_query($conn,$sql);
}else{
echo '连接失败';
}
mysqli_close($conn);
$rowCount = mysqli_num_rows($result);
if ($rowCount) {
echo '<script>location.href="http://www.baidu.com"</script>';
}else{
echo '用户或者密码错误';
}
|