到目前为止,你已经了解了足够多的php了。该写个小程序练手了。
用户注册系统
写一个index.php页面,有用户名和密码表单,post提交到check.php,输出用户名和"用户名+密码"的md5值
本地建立一个mysql数据库,名叫segmentfault,建立一个表user,字段username password将上题check.php接收到的内容存入
我们先完成html部分:
<!doctype html>
<html>
<head>
<title>注册</title>
</head>
<body>
<h1>注册</h1>
<form action="check.php" enctype="application/x-www-form+xml" method="post">
<p>
<label for="name">邮箱</label>
<input name="name" required type="email" placeholder="请填写有效邮箱"></input>
</p>
<p>
<label for="passphrase">密码</label>
<input name="passphrase" required type="passphrase"></input>
</p>
<p>
<input type="submit" value="提交"></input>
</form>
</body>
</html>
注意,html5对表单的支持比以往版本的html好很多,可以直接指明各种type。比如制定了type="email",会检验用户提交的邮件地址是否合法。
然后是check.php。
<!doctype>
<html>
<head>
<title> 注册成功!</title>
</head>
<body>
<h1> 哇咔咔,你已经注册成功啦!</h1>
<p>呃……不过注册成功了好像也没什么用,因为本网站除了注册以外好像没有其他功能。</p>
<p>那么,作为补偿,我会告诉你,你的“邮箱+密码”的md5值。</p>
<p>你的邮箱是:
下面是php部分,直接嵌入html,这是php的优势:
<?php
$username = htmlspecialchars($_post["name"]);
echo $username;
?>
</p>
<p>你的“邮箱+密码”的md5值是:
<?php
$passphrase = htmlspecialchars($_post["passphrase"]);
$md5sum = md5($username . $passphrase);
echo $md5sum;
注意我们用了htmlspecialchars,避免用户填入奇怪的东西。
然后是数据库操作,我们使用mysqli,(mysql已经废弃了,现在推荐用 mysqli,当然你也可以用 pdo。)
首先我们指明数据库的一些信息:
$db_server = "localhost";
$db_user = "db_user";
$db_pass = "password";
$db_name = "segmentfault";
连接到数据库,并且确保连接正常:
$conn = new mysqli($db_server, $db_user, $db_pass, $db_name);
if (mysqli_connect_errno()) {
trigger_error("database connection failed: " . mysqli_connect_error(), e_user_error);
}
使用sql语句创建表
添加记录
手写sql不太爽,实际应用中,框架会为你提供各种方便。
关闭数据库:
mysqli_close($conn);
?>
</p>
</body>
</html>
好了,我们已经成功地写好了一个小应用,也顺带学习了如何访问 mysql 数据库。今天就到这里了。
评论列表:
发布于 4天前回复该评论
发布于 4天前回复该评论
发布于 3天前回复该评论
发布于 3天前回复该评论
发布于 3天前回复该评论
发布于 3天前回复该评论
发布于 2天前回复该评论
发布于 2天前回复该评论