持续更新:从零开始的php学习生活
其实也不是真的从零开始,在此之前我还是一边研究博学(博客美化)一边学的CSS、HTML、JavaScript的,相关内容可以戳这里。
看本文之前你最好稍微熟悉一下HTML、JavaScript什么的。
从一个小白做起,目标是搭一个网站!(flag在此。
2017.9.28
(其实是一周前开始搞的,现在才开始写
学习php,首先我们要有本地的php环境。
作为一个偷懒选手我是直接用XAMPP,这个的下载安装教程网上有很多,我当时是在这里看的。
记得开IIS,还要改改端口什么的(我把Apache的端口改成了82,下面代码会出现)。
然后请开始在网上(随便)找个php教程看看。各种语法好像其实和JavaScript,c++什么的差不多。
(其实以上两步你随便什么顺序都可以)
开工吧。
先熟悉一下SQL的使用。
我遇到的第一个问题是php教程跟我说的mysql_connect好像用不了。。。哦,折腾了很久以后发现我的版本比较高,应该用mysqli_connect。
先把注册系统搞进来。
下面这个是注册界面:
<!DOCTYPE HTML> <html> <body> <form action="recive.php" method="post"> 姓名:<input type="text" name="username"><br> 密码:<input type="password" name="password"><br> 邮箱:<input type="text" name="email"><br> <input type="submit"> </form> </body> </html>
然后是接收:
<?php
define('DB_HOST', 'localhost');
define('DB_USER', 'root');
define('DB_PASSWORD', '');
define('DB_NAME','enceladus') ;
$conn=mysqli_connect(DB_HOST,DB_USER,DB_PASSWORD,DB_NAME);
mysqli_query($conn,"set names 'utf8'");
if(mysqli_connect_errno()){
echo mysqli_connect_error();
}
$user_name=mysqli_real_escape_string($conn,trim($_POST['username']));
$user_email=mysqli_real_escape_string($conn,trim($_POST['email']));
$user_password=mysqli_real_escape_string($conn,trim($_POST['password']));
$user_email=$_POST['email'];
$query = "SELECT * FROM Users WHERE email='$user_email' ";
$data = mysqli_query($conn,$query);
if (mysqli_num_rows($data)!=0){
echo "<h2>Email exist!</h2>";
}else{
$sql = "INSERT INTO Users(username,password,email) VALUES ('"
.$user_name."','".$user_password."','".$user_email."')";
if ($conn->query($sql) === TRUE) {
echo "Register Successfully!<br>";
}else{
echo "Error: " . $sql . "<br>" . $conn->error;
}
}
mysqli_close($conn);
?>
还在开发过程中所以暂时没管密码加密什么的(其实是出了问题偷懒不搞
然后做login的时候不知道出了什么岔子,session.save_path一直是一个奇怪的地址(跟php.ini的不同),于是只能强行在页面前加个session_save_path('D:\swm_sxt\XAMPP\tmp');,先这样了,以后再处理。
然后搞着搞着。login做好了:
<?php
session_save_path('D:\swm_sxt\XAMPP\tmp');
session_start();
define('DB_HOST', 'localhost');
define('DB_USER', 'root');
define('DB_PASSWORD', '');
define('DB_NAME','enceladus') ;
if(!isset($_SESSION['user_id'])){
if(isset($_POST['submit'])){
$conn=mysqli_connect(DB_HOST,DB_USER,DB_PASSWORD,DB_NAME);
$user_email=mysqli_real_escape_string($conn,trim($_POST['useremail']));
$user_password=mysqli_real_escape_string($conn,trim($_POST['password']));
if(!empty($user_email)&&!empty($user_password)){
$query="SELECT user_id, username FROM Users WHERE email='$user_email' AND password='$user_password'";
$data=mysqli_query($conn,$query);
echo $user_password;
if(mysqli_num_rows($data)==1){
$row=mysqli_fetch_array($data);
$_SESSION['user_id']=$row['user_id'];
$_SESSION['username']=$row['username'];
$home_url='index.php';
header('Location:'.$home_url);
}else{
echo 'Sorry, you must enter a valid username and password to log in.';
}
}else{
echo 'Sorry, you must enter a valid username and password to log in.';
}
}
}else{
$home_url='index.php';
header('Location:'.$home_url);
}
?>
<html>
<head>
<title>Log In</title>
</head>
<body>
<?php
if(!isset($_SESSION['user_id'])){
?>
<form method = "post" action="<?php echo $_SERVER['PHP_SELF'];?>">
<fieldset>
<legend>Log In</legend>
<label for="useremail">Useremail:</label>
<input type="text" id="useremail" name="useremail"
value="<?php if(!empty($user_useremail)) echo $user_useremail; ?>" />
<br/>
<label for="password">Password:</label>
<input type="password" id="password" name="password"/>
</fieldset>
<input type="submit" value="Log In" name="submit"/>
</form>
<?php
}
?>
</body>
</html>
暂时就搞到这里了。赶紧去上晚自习了。
2017.11.30
好久没更了过来更下(虽然好像没人看
之前搞了一个多月的botzone,进度拖慢了不少,终究还是有条不紊地进行中。现在已经完成了题库啦,公告啦,排行榜啦之类基本的东西。嘛,丑得不行。

各方面没遇到什么技术问题,反正就是搬砖嘛……值得一提的是我采用了Semantic的ui框架,初学者强行搞ui还是有一定难度的,拿个现成的比较好。
但是现在就很纠结了,到底要像其他网站一样搞个顶部菜单呢还是把博客园的手制菜单移过来呢……
(这是hover时的效果。
干活干活
持续更新:从零开始的php学习生活的更多相关文章
- 【持续更新】D3 的学习资料
经常有朋友问哪里有关于 D3 的比较好的学习资料,现整理成此文.以后找到更多更好的,会不断更新本文. 我是在2013年开始接触 D3 的,当时就觉得这个工具很好玩.至今,学习资料整理了不少.如果有朋友 ...
- 值得学习的C/C++开源项目 持续更新
值得学习的C语言开源项目 持续更新 文章目录 值得学习的C语言开源项目 持续更新 - 1. Webbench - 2. Tinyhttpd - 3. cJSON - 4. CMockery - 5. ...
- 关于ASP.NET MVC开发设计中出现的问题与解决方案汇总 【持续更新】
最近一直用ASP.NET MVC 4.0 +LINQ TO SQL来开发设计公司内部多个业务系统网站,在这其中发现了一些问题,也花了不少时间来查找相关资料或请教高人,最终都还算解决了,现在我将这些问题 ...
- (持续更新) C# 面试技术点、常见SQL技术点 和 解决高并发的相关技术
这篇博客 持续更新. 方便小伙伴们学习与面试前的复习
- ASP.NET MVC 5 系列 学习笔记 目录 (持续更新...)
前言: 记得当初培训的时候,学习的还是ASP.NET,现在回想一下,图片水印.统计人数.过滤器....HttpHandler是多么的经典! 不过后来接触到了MVC,便立马爱上了它.Model-View ...
- 【 js 基础 】【 源码学习 】源码设计 (持续更新)
学习源码,除了学习对一些方法的更加聪明的代码实现,同时也要学习源码的设计,把握整体的架构.(推荐对源码有一定熟悉了之后,再看这篇文章) 目录结构:第一部分:zepto 设计分析第二部分:undersc ...
- java 学习必备的软件,持续更新中
小编会持续更新在学习Java过程中需要的软件以及各种文件: 话不多说,看行动! 一:JDK (1)JDK1.8(*64): 链接:https://pan.baidu.com/s/1vM0jNXn2CT ...
- 状压dp(状态压缩&&dp结合)学习笔记(持续更新)
嗯,作为一只蒟蒻,今天再次学习了状压dp(学习借鉴的博客) 但是,依旧懵逼·································· 这篇学习笔记是我个人对于状压dp的理解,如果有什么不对的 ...
- python3.4学习笔记(六) 常用快捷键使用技巧,持续更新
python3.4学习笔记(六) 常用快捷键使用技巧,持续更新 安装IDLE后鼠标右键点击*.py 文件,可以看到Edit with IDLE 选择这个可以直接打开编辑器.IDLE默认不能显示行号,使 ...
随机推荐
- DotNetCore跨平台~System.DrawingCore部署Linux需要注意的
回到目录 你在windows上使用图像组件没有任务问题,但部署到linux之后,将注意以下几点: 安装nuget包ZKWeb.System.Drawing 项目里还是引用System.DrawingC ...
- rwx读写执行对文件和目录的意义
文件 目录 r 查看 列出目录内容 w 修改 在目录内新建删除文件 x 执行 可以进入目录 对文件的删除权限是对文件所有目录的写权限 对目录-wx的权限,有写和执行权限,既可以在目录内创建删除文件,可 ...
- Mysql 锁基础
本文同时发表在https://github.com/zhangyachen/zhangyachen.github.io/issues/53 lock与latch 在数据库中,lock与latch都可以 ...
- ES6 let和const命令(4)
const声明的常量只在当前代码块有效.如果想设置跨模块的常量,可以采用下面的写法. //constants.js模块 export const A = 1; export const B = 3; ...
- lesson - 15 Linux系统日常管理4
内容概要:1. rsync 命令格式rsync [OPTION]... SRC DESTrsync [OPTION]... SRC [USER@]HOST:DESTrsync [OPTION].. ...
- Python第二十天 shutil 模块 zipfile tarfile 模块
Python第二十天 shutil 模块 zipfile tarfile 模块 os文件的操作还应该包含移动 复制 打包 压缩 解压等操作,这些os模块都没有提供 shutil 模块shut ...
- Effective Java 第三版——14.考虑实现Comparable接口
Tips <Effective Java, Third Edition>一书英文版已经出版,这本书的第二版想必很多人都读过,号称Java四大名著之一,不过第二版2009年出版,到现在已经将 ...
- SQL 多列合并一列
select rtrim(姓)+ rtrim(名) as 姓名 from tb
- ffempg支持文件解码
在做一个数据通道 要求有两个 1.支持打开实时流,解码得到图片 2.支持打开视频文件,得到解码图片 第一个要求前任已经实现 bool FfmpegStreamChr::Open(const char ...
- Zabbix 单位换算
直接举一例子,然后再举一反三: 如图: 单位B 则基数为1024(倍数) 我性能参数为KB单位,我们则把单位转换成和我们计数器 保持一致的单位即可,一致后,zabbix 后面会自己准换成自己想要的显示 ...