持续更新:从零开始的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默认不能显示行号,使 ...
随机推荐
- Parallels Desktop 12 for Mac 破解版
Parallels Desktop for Mac 是功能最强大灵活度最高的虚拟化方案,无需重启即可在同一台电脑上随时访问Windows和Mac两个系统上的众多应用程序.从仅限于PC的游戏到生产力软件 ...
- IOS学习2——Xcode快捷键大全
转载自:图文解释XCode常用快捷键的使用 刚开始用Xcode是不是发现以前熟悉的开发环境的快捷键都不能用了?怎么快捷运行,停止,编辑等等.都不一样了.快速的掌握这些快捷键,能提供开发的效率. 其实快 ...
- ABP前端使用阿里云angular2 UI框架NG-ZORRO分享
一.前言 前段时间写博客分享和介绍了阿里云的UI框架NG-ZORRO(博客请查看:http://www.cnblogs.com/donaldtdz/p/7892960.html),结合近段时间对.Ne ...
- touchstart和touchend事件
touchstart和touchend事件 移动互联网是未来的发展趋势,现在国内很多互联网大佬都在争取移动这一块大饼,如微信及支付宝是目前比较成功的例子,当然还有各种APP和web运用. 由于公司的需 ...
- DNS查询的工作原理
二.DNS查询的工作原理 1.DNS查询过程按两部分进行 1.名称查询从客户端计算机开始, 并传送给本机的DNS客户服务程序进行解析 2.如果不能再本机解析查询, 可根据设定的查询DN ...
- Linux_服务器_07_ 将用户设置为管理员
二.参考资料 1.CentOS普通用户获得管理员权限 2.linux下添加用户并赋予root权限
- 根据图片的路径(绝对路径/相对路径都可以),生成base64的
根据图片的路径(绝对路径/相对路径都可以),生成base64的 <!DOCTYPE html> <html> <head> <meta charset=&qu ...
- Spark 核心概念 RDD 详解
RDD全称叫做弹性分布式数据集(Resilient Distributed Datasets),它是一种分布式的内存抽象,表示一个只读的记录分区的集合,它只能通过其他RDD转换而创建,为此,RDD支持 ...
- 例子:js超级玛丽小游戏
韩顺平_轻松搞定网页设计(html+css+javascript)_第34讲_js超级玛丽小游戏_学习笔记_源代码图解_PPT文档整理 采用面向对象思想设计超级马里奥游戏人物(示意图) 怎么用通过按键 ...
- ADO.NET查询和操作数据库
stringbuilder 类 stringbuilder类:用来定义可变字符串 stringbulider Append(string value) 在结尾追加 stringbuilder in ...