MYSQL基础笔记(五)- 练习作业:站点统计练习
作业:站点统计
1、将用户的访问信息记录到文件中,独占一行,记录IP地址
<?php
//站点统计
header('Content-type:text/html;charset=utf-8'); //获取用户信息
$ip = $_SERVER['REMOTE_ADDR']; //写入文件(追加)
file_put_contents('record.text',$ip."\r\n",FILE_APPEND);
2、所有信息都是通过文件中记录的内容来计算的,读取整个文件,一行代表访问一次,使用file函数读取。
//读取数据 ,以行为单位
$info = file('record.text');
3、总的访问次数等于总行数,就是读取的数组的总记录数。
//求出网站的总访问量
$visits = count($info);
4、求出当前用的访问次数,当前用户的IP在数组中出现的次数
//求出当前用户(IP)出现的次数
$ip_visits = 0;
foreach($info as $each_ip)
{ //比较
if($each_ip == $ip)
$ip_visits++;
}
5、总共有多少个用户访问过,遍历当前所有的访问用户信息,另外使用一个数组保存。如果当前IP在数组中存在,那么不加入,否则加入。最后统计新数组即可。
foreach($info as $each_ip)
{
//统计当前数组中拥有的的独立IP数
if(!in_array($each_ip,$unique_ips))
$unique_ips[] = $each_ip; //比较:从文件中读出的是一行,用trim去掉换行符空格
if(trim($each_ip) == $ip)
$ip_visits++; //统计$unique_ips中的元素个数:就是独立ip数,总用户
$users = count($unique_ips);
}
6、求出当前用户是第几位访问访问者,只要判断当前IP在独立用户数组中出现的位置即可。
下面是整个作业的代码:
<?php
//站点统计
header('Content-type:text/html;charset=utf-8');
//获取用户信息
$ip = $_SERVER['REMOTE_ADDR'];
//写入文件(追加)
file_put_contents('record.text',$ip."\r\n",FILE_APPEND);
//读取数据 ,以行为单位
$info = file('record.text');
//求出网站的总访问量
$visits = count($info);
//求出当前用户(IP)出现的次数
$ip_visits = 0;
$unique_ips = array();
foreach($info as $each_ip)
{
//统计当前数组中拥有的的独立IP数
if(!in_array($each_ip,$unique_ips))
{ //讲当前新的用户加入到独立的ip数组中
$unique_ips[] = $each_ip;
//判断当前新加的IP($each_ip)是否是当前用户的IP
if($ip == trim($each_ip)) $user_visit = count($unique_ips); } //比较:从文件中读出的是一行,用trim去掉换行符空格
if(trim($each_ip) == $ip)
$ip_visits++; //统计$unique_ips中的元素个数:就是独立ip数,总用户
$users = count($unique_ips);
}
//需求_输出
echo "欢迎访问,你是第{$user_visit}个用户,当前网站一共有{$users}位用户,
当前网页一共被访问了{$visits}次,你当前是第{$ip_visits}位访问";
?>
本作业所涉及的几个PHP函数总结:
1、$_SERVER['REMOTE_ADDR']
$_SERVER 是一个包含了诸如头信息(header)、路径(path)、以及脚本位置(script locations)等等信息的数组。这个数组中的项目由 Web 服务器创建。
'REMOTE_ADDR' 浏览当前页面的用户的 IP 地址。
2、 file_put_contents— 将一个字符串写入文件
1 int file_put_contents ( string $filename , mixed $data [, int $flags = 0 [, resource $context ]] )
和依次调用 fopen(),fwrite() 以及 fclose() 功能一样。
参数
filename-
要被写入数据的文件名。
data-
要写入的数据。类型可以是 string,array 或者是 stream 资源(如上面所说的那样)。
如果
data指定为 stream 资源,这里 stream 中所保存的缓存数据将被写入到指定文件中,这种用法就相似于使用 stream_copy_to_stream() 函数。参数
data可以是数组(但不能为多维数组),这就相当于file_put_contents($filename, join('', $array))。 flags-
flags的值可以是 以下 flag 使用 OR (|) 运算符进行的组合。context一个 context 资源。
MYSQL基础笔记(五)- 练习作业:站点统计练习的更多相关文章
- MYSQL基础笔记(六)- 数据类型一
数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...
- MYSQL基础笔记(四)-数据基本操作
数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...
- MySQL基础(五)——视图
MySQL基础(五)--视图
- MYSQL基础笔记(三)-表操作基础
数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...
- MYSQL基础笔记(二)-SQL基本操作
SQL基本操作 基本操作:CRUD,增删改查 将SQL的基本操作根据操作对象进行分类: 1.库操作 2.表操作 3.数据操作 库操作: 对数据库的增删改查 新增数据库: 基本语法: Create da ...
- MYSQL基础笔记(一)
关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...
- C#基础第五天-作业答案-用DataTable制作名片集
.DataTable 实现 DataTable PersonCard = new DataTable(); //创建一个DataTable DataTable PersonCardCopy = new ...
- C#基础第五天-作业-用DataTable制作名片集
1.用DataTable集合去实现名片集.(增加,修改,删除,查询,查询全部)需求:根据人名去(删除/查询).指定列:姓名,年龄,性别,爱好,电话. 本系列教程: C#基础总结之八面向对象知识点总结- ...
- C语言基础第五次作业
题目7-2 统计一行文本的单词个数 1.实验代码 #include <stdio.h> int main() { char a; ,countword=; ){ scanf("% ...
随机推荐
- 【移动开发】安卓Lab2(01)
本次Lab需要用到Google Map的API,分享学习一下Google Map的知识 需求: 界面: 1. 主界面(map界面): 提供了指定的学校校园地图图片,不能用Google的API生成图片 ...
- leetcode@ [316] Remove Duplicate Letters (Stack & Greedy)
https://leetcode.com/problems/remove-duplicate-letters/ Given a string which contains only lowercase ...
- 有趣的Node爬虫,数据导出成Excel
最近一直没更新了诶,因为学习Backbone好头痛,别问我为什么不继续AngularJs~因为2.0要出来了啊,妈蛋!好,言归正传,最近帮我的好基友扒数据,他说要一些股票债券的数据.我一听,那不就是要 ...
- awk的二维数组
awk是不支持二维数组的,它的底层是一维数组,将两个key拼接为一维数组的key. 如下是其初始化和遍历 awk 'BEGIN{ for(i=0;i< 3; ++i) for(j = 0; j ...
- [iOS微博项目 - 1.1] - 设置导航栏主题(统一样式)
A.导航栏两侧文字按钮 1.需求: 所有导航栏两侧的文字式按钮统一样式 普通样式:橙色 高亮样式:红色 不可用样式:亮灰 阴影:不使用 字体大小:15 github: https://github ...
- Umbraco官方技术文档 中文翻译
Umbraco 官方技术文档中文翻译 http://blog.csdn.net/u014183619/article/details/51919973 http://www.cnblogs.com/m ...
- CodeForces 589A Email Aliases (匹配,水题)
题意:给定于所有的邮箱,都是由login@domain这样的形式构成,而且字符都是不区分大小写的. 我们有一种特殊类型的邮箱——@bmail.com, 这种邮箱除了不区分大小写外—— 1,'@'之前的 ...
- myeclipse内存配置
配置文件路径:D:\work\myeclipse\MyEclipse for Spring 10\myeclipseforspring.ini 替换以下内容即可 -vmargs-Xmx768m-XX: ...
- java functional syntax overview
Defining a Functional Interface @FunctionalInterface public interface TailCall<T> { TailCall&l ...
- (转)WordPress的主查询函数-query_posts()
今天说说WordPress 的主查询函数 -query_posts(),因为我正在制作的主题里面多次用到了这个函数 . query_posts()查询函数决定了哪些文章出现在WordPress 主 循 ...