Web开发从零单排之二:在自制电子请帖中添加留言板功能,SAE+PHP+MySql

时间:2022-08-26 20:37:42

在上一篇博客中介绍怎样在SAE平台搭建一个html5的电子请帖网站,收到很多反馈,也有很多人送上婚礼的祝福,十分感谢!

web开发从零学起,记录自己学习过程,各种前端大神们可以绕道不要围观啦

大婚将至,各种事情很多,今天终于驱动自己把上次遗留的内容补充完

奉上在电子请帖中添加留言板的功能简介,采用php脚本语言和mysql数据库,同样在新浪的SAE平台下,可以节省很多部署和维护工作

在SAE的个人项目管理界面,从MySql页面点击"管理MySql",进入SAE提供的mysql数据库管理界面,

有一点数据库知识的话,在可视化界面进行表的添加,字段规划,同样是在线维护,十分简单和方便

新建一张“tb_Message”的表,用来保存留言记录,字段包含姓名,内容,留言时间,是否允许查看等

然后在“代码管理”中使用SAE Editor在电子请帖的主页中,添加留言板的界面

<article class="container box style3">
<header>
<h1>祝福</h1>
<p>您可以通过下面给我们留言</p>
</header>
<form method="post" action="add.php">
<div class="row half">
<div class="6u"><input type="text" class="text" name="name" placeholder="Name" /></div>
</div>
<div class="row half">
<div class="12u">
<textarea name="message" placeholder="Message"></textarea>
</div>
</div>
<div class="row">
<div class="12u">
<ul class="actions">
<li><input name="MySubmit" type="submit" value="捎句话" /></li>
</ul>
</div>
</div>
</form>
</article>

这里通过一个表单<form>来提交留言文字,服务端add.php脚本用来处理带留言的“请求”

add.php的源代码如下,其中一部分为获取请求的客户端IP地址,用来记录留言者IP

<?php
include("conn.php"); if($_POST['MySubmit']){ if (getenv("HTTP_CLIENT_IP"))
$ip = getenv("HTTP_CLIENT_IP");
else if(getenv("HTTP_X_FORWARDED_FOR"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
else if(getenv("REMOTE_ADDR"))
$ip = getenv("REMOTE_ADDR");
else $ip = "Unknow"; $sql="insert into tb_Message (No,Name,MessageTime,Content,MessageIP,Memo,IsShow) ".
"values ('','$_POST[name]',now(),'$_POST[message]','$ip','','1')";
mysql_query($sql);
echo "留言成功!";
}else{
echo "error!";
}
?>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">

数据库连接coon.php代码如下,连接字符串为SAE下MySql数据库使用的固定写法,app_lovewithlmj为数据库名

<?php
$conn= @ mysql_connect(SAE_MYSQL_HOST_M.':'.SAE_MYSQL_PORT,SAE_MYSQL_USER,SAE_MYSQL_PASS) or die ("连接出错");
mysql_select_db("app_lovewithlmj",$conn);
mysql_query("set names 'utf-8'"); ?>

记得指定utf-8编码,否则中文会出现乱码情况

这样在电子请帖页面留言后通过按钮发送请求,得到“留言成功”的回复即留言成功

如果要在电子请帖中添加查看留言功能,

<article class="container box style3">
<header>
<h1>您还可以</h1>
</header>
<form method="post" action="list.php">
<div class="row">
<div class="12u">
<ul class="actions">
<li><input type="submit" value="看看大家说什么" /></li>
</ul>
</div>
</div>
</form>
</article>

发送查看留言请求后,服务端“list.php”来处理此请求,由于时间原因,对于展示留言的页面没有用html语言进行装饰,直接显示的php查询数据库后的表单

<?php
include ("conn.php");
?>
<table width=500 border="0" align="center" cellpadding="5" cellspacing="1" bgcolor="#cccccc">
<?php
$sql = "SELECT * FROM tb_Message where IsShow='1' ORDER BY MessageTime DESC";
$query=mysql_query($sql); while($row=mysql_fetch_array($query)){ ?>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<tr bgcolor="#eeeeee">
<td>留言时间: <?php echo $row[MessageTime];?></td> </tr>
<tr bgcolor="#eeeeee">
<td> <?php echo $row[Name];?> : <?php echo $row[Content];?> </td> </tr>
<?php
}
?>
</table>

这样一个带留言板功能的html5电子相册就基本完成了,抛砖引玉,在初学web开发的道路上,大家一起交流更好的建议和想法

Web开发从零单排之二:在自制电子请帖中添加留言板功能,SAE+PHP+MySql的更多相关文章

  1. Web开发从零单排之一:在新浪云平台SAE上开发一个html5电子喜帖

    需求描述: 本人大婚将至,女朋友说“现在都流行在微信上发电子请帖了,你不是技(cheng)术(xu)宅(yuan)嘛,不会连这个都搞不定吧” 本人嘴上说这等小事何足挂齿,但心里还是七上八下的,虽然自认 ...

  2. Unity3D游戏开发从零单排&lpar;四&rpar; - 制作一个iOS游戏

    提要 此篇是一个国外教程的翻译,尽管有点老,可是适合新手入门. 自己去写代码.debug,布置场景,能够收获到非常多.游戏邦上已经有前面两部分的译文,这里翻译的是游戏的最后一个部分. 欢迎回来 在第一 ...

  3. java web开发环境配置系列(二)安装tomcat

    在今天,读书有时是件“麻烦”事.它需要你付出时间,付出精力,还要付出一份心境.--仅以<java web开发环境配置系列>来祭奠那逝去的…… 1.下载tomcat压缩包,进入官网http: ...

  4. 第134天:移动web开发的一些总结(二)

    1.响应式布局 开发一个页面,在所有的设备上都能够完美展示. 媒体查询:@media screen and (max-width:100px) { } 媒体类型:screen(屏幕) print(打印 ...

  5. Linux从零单排(二):setuptools、pip、anaconda2的环境配置

    为了更方便的使用Python的类库,需要进行相应的配置 (一)setuptools的配置 1.setuptools的下载 命令行输入wget https://pypi.python.org/packa ...

  6. Unity3D游戏开发从零单排&lpar;五&rpar; - 导入CS模型到Unity3D

    游戏动画基础 Animation组件 Animation组件是对于老的动画系统来说的. 老的动画形同相应的动画就是clip,每一个运动都是一段单独的动画,使用Play()或CrossFade(),直接 ...

  7. Unity3D游戏开发从零单排&lpar;三&rpar; - 极速创建狂拽酷炫的游戏地形

    提要 在Unity工作流程内,地形是一个必不可少的重要元素.不论是游戏或虚拟现实都会使用到各种类型的地形效果,在这个教学中我们须要了解到地形的制作基本概念与,当中对于Unity的地形操作部分须要大量的 ...

  8. Unity3D游戏开发从零单排&lpar;六&rpar; - 人物运动及攻击连击

    提要 今天要实现的是一个简单人物控制器. 包括用w,a,s,d来控制人物上下左右跑动,鼠标左击发出连招,都是基于老的lagacy的动画.尽管unity3d自带有charactorcontroller, ...

  9. Django web框架开发基础-django实现留言板功能

    1.创建项目 cmd  django-admin startpoject cloudms 2.创建APP cmd django-admin startapp msgapp 3.修改settings,T ...

随机推荐

  1. 聊聊excel生成图片的几种方式

    目录     I:需求.  II:实现思路.     III:实现方式.     IV:优缺点分析.     V:结论.     VI:wps安装与配置. 正文 1.需求:把excel生成等比的图片. ...

  2. textView的提醒文字

    如果我们想提交一些备注信息,会想到用textFiled和textView两种控件去实现 1.提醒文字是textFiled的特有属性,但是textFiled显示文本只有一行,不能实现我们输入较多文字的情 ...

  3. AD RMS 配置指南 附结合SharePoint使用

    本文的 RMS配置 是独立安装的配置手册,如果要和SharePoint结合使用可以作为参考指南. SharePoint安装可参考 点击链接 同样可提供给Office使用,当然Exchange也可以使用 ...

  4. dos 下删除文件、文件夹

    删除文件 /p 删除每一个文件之前提示确认/f 强制删除只读文件 /s 从当前目录及所有子目录删除指定文件/q 安静模式.删除全局通配符时,不要求确认/a 根据属性选择要删除的文件 指定下列文件属性中 ...

  5. noip2010-t2

    题目大意:小明过生日的时候,爸爸送给他一副乌龟棋当作礼物.乌龟棋的棋盘是一行 N个格子,每个格子上一个分数(非负整数).棋盘第 1 格是唯一 的起点,第 N格是终点,游戏要求玩家控制一个乌龟棋子从起点 ...

  6. C&plus;&plus;11—lambda函数

    [1]lambda表达式语法定义 lambda表达式的语法定义如下: [capture] (parameters) mutable ->return-type {statement}; (1) ...

  7. 【Android - 框架】之Retrofit的使用

    Retrofit是Square公司发布的一个可以应用在Android和Java中的Http客户端访问框架,其底层应用的是OkHttp. 在这个帖子中,我们以下面这个Http请求为例: https:// ...

  8. UISement属性

    .segmentedControlStyle 设置segment的显示样式. typedef NS_ENUM(NSInteger, UISegmentedControlStyle) { UISegme ...

  9. Jmeter入门(压力测试)

    Jmeter介绍 Jmeter是一款使用Java开发的,开源免费的,测试工具, 主要用来做功能测试和性能测试(压力测试/负载测试). 而且用Jmeter 来测试 Restful API, 非常好用. ...

  10. mina基础知识整理

    一.      简介: Apache Mina Server 是一个网络通信应用框架,Mina 可以帮助我们快速开发高性能.高扩展性的网络通信应用,Mina 提供了事件驱动.异步(Mina 的异步 I ...