热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php增添删改界面,0070PHP编程前端网站增加新闻信息显示功能

原标题:0070PHP编程前端网站增加新闻信息显示功能上节课完成了整个后台网站的功能开发,可以新建编辑删除查询新闻信息数据。这节课来到前端网站ÿ

原标题:0070 PHP编程前端网站增加新闻信息显示功能

上节课完成了整个后台网站的功能开发,可以新建编辑删除查询新闻信息数据。

这节课来到前端网站,增加新闻信息一览显示页面和详细页面。

编写新闻一览网页

一览页面可以参照后台的一览查询页面,但是不需要查询条件了,而且翻页的方式要修改一下,确保每次传递的数据只有当前页的数据。

f_news_list.php代码如下:

272cc72b7903c7119679efc8efd77576.png

89d5e7129f5f7ff907e5d31876742899.png

f_news_list_do.php代码如下:

95a44717b341c193fd91cd101eeaf3dd.png

news.css代码修改如下:

20db3ed9b1e67bde708424fd4234cb19.png

先登录到后台网页,增加记录数总共5条:

022386b9616e565012e12f032176091c.png

然后通过浏览器直接访问网页url地址:

8928381594dc0c0a2c5525f009bf09e2.png

可以看到当前页显示了2个新闻,并且出现了页数,点击第2页:

61d0fc274ffa3dfa1ac04773dd66ee6e.png

可以看到正确的数据显示出来了。

编写新闻详细显示网页

详细页面就是除了要显示主表信息,同时通过循环显示详细表的信息。

f_news_detail.php代码如下:

ae00890717deeefbeba64c72c8e03e3b.png

1b7104c39353576adb3e1b9f30e94bb1.png

f_news_detail_do.php代码如下:

eaf8e1fef96fe8a1ce5ba3dc9153438a.png

news.css代码修改如下:

13726cc3d2c5e248d5608fe5e2de4f8c.png

通过浏览器访问新闻一览页面:

eb59a508cb00d628648e7f026f29c3da.png

然后点击第一个新闻,进入详细页面:

fedf704f15520a66ef8b48595f4aab4b.png

可以看到,按照设置的数据,正常显示了内容和图片等信息。

去后台管理功能页面,将此新闻的详细增加到2个图和2段文字:

689ec641ed564ef0d78df7f763367d0b.png

然后回到前台新闻详细页面,刷新:

ce424979b4f3ec89f193615eec5b0102.png

可以看到显出出2个图片和对应的文字内容了。

整体测试

将之前的翻页的参数调整一下,修改为10条记录翻页:

news_list_do.php修改如下:

5bb23aa65b49da606d49342a1a82041a.png

f_news_list_do.php修改如下:

57dd487781707726e1aa044989552485.png

然后在之前编写的index.html当中增加一个链接,可以链接到新闻一览显示页面。

index.html修改如下:

74d24b627c4727cdbf3385f4476e6d07.png

刷新index.html网页:

00c603865c996fb6910f2cd53afa44f2.png

点击“新闻信息一览”按钮:

29c6808cffc6a7698a3e8d0b73340774.png

然后通过后台管理页面,增加更多的数据,然后通过前端页面去浏览看看是否功能正常。

云服务器创建数据库和表结构

首先,要到云服务器的数据库系统中创建数据库student以及对应的表studentscore、content和contentdetail。

创建之前,需要先准备好创建数据库和表的SQL语句。

可以从之前的数据库客户端软件当中导出。

打开数据库客户端软件,并打开连接和数据库:

a77c79339f596a070e2ebabf98c6f79d.png

然后在数据库student上面右键,选择菜单“转储SQL文件”:

1b84fd0d952acf01d3a56edca4456518.png

然后点击“保存”按钮:

b7cba9163a043dacdf0ed9654d981909.png

可以看到生成完成。点击关闭按钮。

然后去文件管理器当中找到这个student.sql文件,用文本编辑器打开:

4b6e39498124d3ff5cde95c01f2d8228.png

可以看到是关于创建表结构的SQL语句,以及新增数据的SQL语句。删除掉注释语句和新增数据的SQL语句,最后保留如下:

529ed7409a1982d24c38517052e02bd3.png

然后将此文件student.sql通过scp命令或者winscp软件上传到云服务器的home目录下:

6654335a3c180b49d6ae41dbb5fea955.png

然后,通过ssh命令或者putty程序远程登录到云服务器,并进入/home目录,通过ls命令查看是否存在student.sql软件:

979184ccc0d484feadadb335fe709052.png

确保存在此文件,然后运行以下命令,进入mysql客户端软件程序,进行创建数据库的操作和创建数据表的操作

#mysql -uroot -p回车

输入数据库密码

mysql>show databases;回车

显示当前有几个数据库

mysql>create database student default character set utf8 collate utf8_general_ci;回车

创建一个数据库名字是student,字符集是utf8

mysql>show databases;回车

显示当前有几个数据库,应该多了一个student数据库

mysql>use student;回车

进入student数据库

mysql>show tables;回车

查看当前数据库有几个表

mysql>source /home/student.sql; 回车

执行sql文件

mysql>show tables;回车

查看当前数据库有几个表,应该看到多了3个表studentscore、content和contentdetail

mysql>select * from content;回车

查询content表中的数据,应该没有记录

mysql>quit回车

退出mysql客户端程序,回到linux系统环境

以上步骤就是创建一个数据库student以及创建3个表的过程。

步骤截图如下:

58c380fb053c55cf82906866637385a3.png

5ee114f6e1042f430c55dee26b368e80.png

如果完成以上步骤,下一次再进入数据库,查询数据的话,就只需要以下步骤即可。

#mysql -uroot -p

mysql>use student;

mysql>select * from content; 或者其它SQL语句

mysql>quit

代码更新部署到云服务器

将需要更新的文件整理一下,然后上传到云服务器。

更新文件列表如下:

check_auth.php

common.php

entity.php

f_news_detail_do.php

f_news_detail.php

f_news_list_do.php

f_news_list.php

index.html

login_do.php

login.php

news_detail_do.php

news_detail.php

news_index.php

news_list_do.php

news_list.php

news.css

news.js

top.php

上传之前,需要注意如果云服务器的MySQL设置的root用户的密码和本地服务器的MySQL设置的密码如果不一样的话,需要修改:

entity.php修改如下:

2dc452f6d83db4d609cd5c7fd4f9ebac.png

然后到云服务器的Web目录下增加upload目录,例如ubuntu服务器创建/usr/share/nginx/html/upload目录。

并将改目录的权限修改为755:

#cd /usr/share/nginx/html

#mkdir upload

#sudo chmod 777 -R upload

步骤截图如下:

1323bc3207774c159f1ab4d93239be48.png

上传完成之后目录文件如下:

dec561722ca8334f1bfbf2ec4e012f13.png

通过域名访问云服务器并测试

然后通过域名访问网站:

262766be6da0e8d4a387bf84433f211a.png

可以看到多了一按钮,点击“新闻信息一览”按钮:

cf3ea77bdf3b7d515d300369564b6d61.png

发现页面没有打开新的窗口并显示新闻信息一览页面,反而是变成了下载php文件,这是因为之前云服务器没有做php的相关配置。

通过ssh或者putty登录到云服务器,执行如下命令:

#sudo apt-get install -y php5 php5-mysql php5-fpm

#sudo vi /etc/nginx/site-enabled/default

修改成以下这样:

cb01d8025030f613952f4316b4138222.png

然后输入:wq,保存退出。

完成编辑配置文件之后,运行命令重启php5-fpm和nginx:

sudo service php5-fpm restart

sudo service nginx restart

然后重新刷新首页,点击“新闻信息一览”按钮:

43a89406313af3853987c2351dd4488c.png

可以看到进入了新闻信息一览查看页面,但是由于数据库没有新增数据,所以是空的页面。

通过直接输入url地址进入后台管理功能页面,进行新闻信息的管理:

af6fe0b6cdc4f2ce2764a5f4dce5b117.png

输入用户名和密码,点击登录,发现提示错误“登录超时或没有权限,请重新登录!”,经过检查,发现login_do.php有一个问题,在第一行缺少一句session_start();函数调用。由于之前的运行环境是phpStudy,这个和ubuntu的php配置是不一样的。所以必须要增加这一句。

login_do.php修改如下:

a63df4502ae3407a61f3a4ea63b3540c.png

修改之后,重新上传此文件到云服务器,然后重新登录,这次可以进入后台主页面:

7bb774148b218821d8fef1325b87b54e.png

然后点击菜单进入新闻信息管理页面:

00b4b32ebcbd265001f6e4e027d0d9ae.png

然后可以进行数据维护操作。插入2条数据:

8641de3b806f3a3a3e65acb805ed136a.png

回到前端新闻信息一览查看页面,刷新页面:

23a38d45a793a75afd7a325a2e6de7e4.png

点击某个新闻,进入详细页面:

7c374ce3a19f1b20f8a40f29c1c5ae5d.png

可以看到正常信息的显示。

第4章小结

第4章主要介绍了PHP语言,并结合HTML、CSS和Java编写动态数据网站,同时学习了SQL语言的基本知识,并学会使用MySQL数据库进行数据查询和更新操作。

然后通过2个实例,学生分数信息管理和新闻信息发布管理,来练习如果将所有的知识融会贯通,实现最基础的网站页面功能。

下一章,将通过一个更接近实用的例子:图书馆管理系统,来复习和巩固前面学习的知识:HTML+CSS+Java+PHP+MySQL实现经典网站。返回搜狐,查看更多

责任编辑:



推荐阅读
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 基于事件驱动的并发编程及其消息通信机制的同步与异步、阻塞与非阻塞、IO模型的分类
    本文介绍了基于事件驱动的并发编程中的消息通信机制,包括同步和异步的概念及其区别,阻塞和非阻塞的状态,以及IO模型的分类。同步阻塞IO、同步非阻塞IO、异步阻塞IO和异步非阻塞IO等不同的IO模型被详细解释。这些概念和模型对于理解并发编程中的消息通信和IO操作具有重要意义。 ... [详细]
  • Oracle10g备份导入的方法及注意事项
    本文介绍了使用Oracle10g进行备份导入的方法及相关注意事项,同时还介绍了2019年独角兽企业重金招聘Python工程师的标准。内容包括导出exp命令、删用户、创建数据库、授权等操作,以及导入imp命令的使用。详细介绍了导入时的参数设置,如full、ignore、buffer、commit、feedback等。转载来源于https://my.oschina.net/u/1767754/blog/377593。 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • Oracle seg,V$TEMPSEG_USAGE与Oracle排序的关系及使用方法
    本文介绍了Oracle seg,V$TEMPSEG_USAGE与Oracle排序之间的关系,V$TEMPSEG_USAGE是V_$SORT_USAGE的同义词,通过查询dba_objects和dba_synonyms视图可以了解到它们的详细信息。同时,还探讨了V$TEMPSEG_USAGE的使用方法。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
author-avatar
yuanyuan
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有