一、PHP多维数组
多维数组是包含一个或多个数组的数组。
在多维数组中,主数组中的每一个元素也可以是一个数组,子数组中的每一个元素也可以是一个数组。
<?php
$sites = array
(
"runoob"=>array
(
"菜鸟教程",
"http://www.runoob.com"
),
"google"=>array
(
"Google 搜索",
"http://www.google.com"
),
"taobao"=>array
(
"淘宝",
"http://www.taobao.com"
)
);
?>
二、PHP日期
三、PHP包含
在服务器执行 PHP 文件之前在该文件中插入一个文件的内容,使用 include
和 require
语句。
require
一般放在 PHP 文件的最前面,程序在执行前就会先导入要引用的文件;
include
一般放在程序的流程控制中,当程序执行时碰到才会引用,简化程序的执行流程。
include
和 require
除了处理错误的方式不同之外,在其他方面都是相同的:
require
生成一个致命错误(E_COMPILE_ERROR
),在错误发生后脚本会停止执行。
include
生成一个警告(E_WARNING
),在错误发生后脚本会继续执行。
语法:
include 'filename'; or require 'filename';
require()
和include()
语句是语言结构,不是真正的函数,和echo()
一样也可以不加圆括号而直接加参数。
include_once()
和 require_once()
语句也是在脚本执行期间包括运行指定文件。此行为和 include()
语句及 require()
类似,使用方法也一样。唯一区别是如果该文件中的代码已经被包括了,则不会再次包括。这两个语句应该用于在脚本执行期间,同一个文件有可能被包括超过一次的情况下,确保它只被包括一次,以避免函数重定义以及变量重新赋值等问题。
例子:
require("config.inc.php");
require_once("config.inc.php");
include("config.inc.php");
include_once("config.inc.php");
总结:
incluce
在用到时加载
require
在一开始就加载
_once
后缀表示已加载的不加载
四、PHP文件
五、PHP 电子邮件
PHP 运行邮件函数需要一个已安装且正在运行的邮件系统(如:sendmail、postfix、qmail等),PHP从脚本直接发送电子邮件。
1.mail()函数
PHP mail()
函数用于从脚本中发送电子邮件。
语法:mail(to,subject,message,headers,parameters)
参数:
to
: 必需。规定 email 接收者。
subject
:必需。规定 email 的主题。注释:该参数不能包含任何新行字符。
message
:必需。定义要发送的消息。应使用 LF (\n)
来分隔各行。每行应该限制在 70 个字符内。
headers
:可选。规定附加的标题,比如 From、Cc 和 Bcc。应当使用 CRLF (\r\n
) 分隔附加的标题。
parameters
:可选。对邮件发送程序规定额外的参数。
例子:
<?php
$to = "someone@example.com"; // 邮件接收者
$subject = "参数邮件"; // 邮件标题
$message = "Hello! 这是邮件的内容。"; // 邮件正文
$from = "someonelse@example.com"; // 邮件发送者
$headers = "From:" . $from; // 头部信息设置
mail($to,$subject,$message,$headers);
echo "邮件已发送";
?>
2.PHP 简易Mail表单
反馈表单:向指定的 e-mail 地址发送了一条文本消息。
当填写完表单点击提交按钮后,页面重新载入,可以看到邮件输入被重置,同时显示邮件发送成功的消息。
<?php
if (isset($_REQUEST['email'])) { // 如果接收到邮箱参数则发送邮件
// 发送邮件
$email = $_REQUEST['email'] ;
$subject = $_REQUEST['subject'] ;
$message = $_REQUEST['message'] ;
mail("someone@example.com", $subject,
$message, "From:" . $email);
echo "邮件发送成功";
} else { // 如果没有邮箱参数则显示表单
echo "<form method='post' action='mailform.php'>
Email: <input name='email' type='text'><br>
Subject: <input name='subject' type='text'><br>
Message:<br>
<textarea name='message' rows='15' cols='40'>
</textarea><br>
<input type='submit'>
</form>";
}
?>
3.PHP 安全Email
防止 e-mail 注入的最好方法是对输入进行验证。
<?php
function spamcheck($field)
{
// filter_var() 过滤 e-mail
// 使用 FILTER_SANITIZE_EMAIL过滤器从字符串中删除电子邮件的非法字符
$field=filter_var($field, FILTER_SANITIZE_EMAIL);
//filter_var() 过滤 e-mail
// 使用 FILTER_VALIDATE_EMAIL 过滤器验证电子邮件地址的值
if(filter_var($field, FILTER_VALIDATE_EMAIL))
{
return TRUE;
}
else
{
return FALSE;
}
}
if (isset($_REQUEST['email']))
{
// 如果接收到邮箱参数则发送邮件
// 判断邮箱是否合法
$mailcheck = spamcheck($_REQUEST['email']);
if ($mailcheck==FALSE)
{
echo "非法输入";
}
else
{
// 发送邮件
$email = $_REQUEST['email'] ;
$subject = $_REQUEST['subject'] ;
$message = $_REQUEST['message'] ;
mail("someone@example.com", "Subject: $subject",
$message, "From: $email" );
echo "Thank you for using our mail form";
}
}
else
{
// 如果没有邮箱参数则显示表单
echo "<form method='post' action='mailform.php'>
Email: <input name='email' type='text'><br>
Subject: <input name='subject' type='text'><br>
Message:<br>
<textarea name='message' rows='15' cols='40'>
</textarea><br>
<input type='submit'>
</form>";
}
?>