今日昨日及总访问量的统计(无须数据库)的方法
首先在WebRoot下创建Count的文件夹,在其中建count.txt文件,输入一个0,访问一次就将0+1的值写入文件;
编写一个读取和写入的java类文件
import java.io.*;
public class Counter extends Object
{
private String currentRecord = null;//保存文本的变量
private BufferedReader file; //BufferedReader对象,用于读取文件数据
private String path;//文件完整路径名
public Counter() {
}
//ReadFile方法用来读取文件filePath中的数据,并返回这个数据
public String ReadFile(String filePath) throws IOException
{
path = filePath;
//创建新的BufferedReader对象
file = new BufferedReader(new FileReader(path));
String returnStr =null;
try
{
//读取一行数据并保存到currentRecord变量中
currentRecord = file.readLine();
}
catch (IOException e)
{
//错误处理
System.out.println("读取数据错误.");
}
if (currentRecord == null)
{
//如果文件为空
NewFile newf=new NewFile();
newf.createFile(path);
returnStr = "没有任何记录";
}
else
{
//文件不为空
returnStr =currentRecord;
}
file.close();
//返回读取文件的数据
return returnStr;
}
//ReadFile方法用来将数据counter+1后写入到文本文件filePath中
//以实现计数增长的功能
public void WriteFile(String filePath,String counter) throws FileNotFoundException
{
path = filePath;
//将counter转换为int类型并加一
int Writestr = Integer.parseInt(counter)+1;
try {
//创建PrintWriter对象,用于写入数据到文件中
PrintWriter pw = new PrintWriter(new FileOutputStream(filePath));
//用文本格式打印整数Writestr
pw.println(Writestr);
//清除PrintWriter对象
pw.close();
} catch(IOException e) {
//错误处理
System.out.println("写入文件错误"+e.getMessage());
}
}
}
如果只需要总访问量的话,就不用往下看了,直接在页面上读取文本文件count.txt的内容就可以了.但如果还需要日访问量就继续往下看吧.
再编写一个自动创建txt文件的类,如:当在2008-07-07访问网站时,就自动创建一个2008-7-7.txt文件,并且给它写入0的字符,
import java.io.*;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
public class NewFile {
public NewFile(){
}
public void createFile(String path){
// 获取当前时间
java.util.Calendar todays = new java.util.GregorianCalendar();
String todaytimes = todays.getTime().toLocaleString();
String[] date_arr=todaytimes.split(" ");
String dc_date=date_arr[0];
try
{//如果昨天没有记录,就自动创建一个昨天信息
String[] day_ar=dc_date.split("-");
int aftdate=Integer.parseInt(day_ar[2])-1;
int yuedate=Integer.parseInt(day_ar[1]);
if(aftdate<=0){
aftdate=30;
yuedate=yuedate-1;
}
File fileafter=new File(path+"/Count/"+day_ar[0]+"-"+yuedate+"-"+aftdate+".txt");
if(!fileafter.exists()){
fileafter.createNewFile();
String fstr="0";
RandomAccessFile fm = null;
try {
fm = new RandomAccessFile(fileafter,"rw");
fm.writeBytes(fstr);
} catch (IOException e3) {
e3.printStackTrace();
} finally{
if(fm!=null){
try {
fm.close();
} catch (IOException e4) {
e4.printStackTrace();
}
}
}
}
File filename = new File(path+"/Count/"+dc_date+".txt");
if(!filename.exists()){
filename.createNewFile();
String filein="0";
RandomAccessFile mm = null;
try {
mm = new RandomAccessFile(filename,"rw");
mm.writeBytes(filein);
} catch (IOException e1) {
e1.printStackTrace();
} finally{
if(mm!=null){
try {
mm.close();
} catch (IOException e2) {
e2.printStackTrace();
}
}
}
}
}
catch(IOException e1){
e1.printStackTrace();
}
finally{
deleteFile(path);
}
}
public void deleteFile(String path){
// 获取当前时间
java.util.Calendar todays = new java.util.GregorianCalendar();
String todaytimes = todays.getTime().toLocaleString();
String[] date_arr=todaytimes.split(" ");
String dc_date=date_arr[0];
String[] day_arr=dc_date.split("-");
//删除上月所有的日期文本文件
for(int i=1;i<=31;i++)
{
int yuedate=Integer.parseInt(day_arr[1])-1;
String dc_day=day_arr[0]+"-"+yuedate+"-"+i;
File files=new File(path+"/Count/"+dc_day+".txt");
if(files.exists()){
files.delete();
}
}
}
}
最后在页面的读取
<%
//调用counter对象的ReadFile方法来读取文件lyfcount.txt中的计数
String url=request.getRealPath("/Count/count.txt");
String cont=counter.ReadFile(url);
//调用counter对象的ReadFile方法来将计数器加一后写入到文件lyfcount.txt中
counter.WriteFile(url,cont);
%>
全站总访问量:<%=cont%> <br />
<%
path = this.getServletContext().getRealPath("").replace("\\", "/");
newfile.createFile(path);
String d_url=request.getRealPath("/Count/"+dc_date+".txt");
String d_cont=counter.ReadFile(d_url);
//调用counter对象的ReadFile方法来将计数器加一后写入到文件lyfcount.txt中
counter.WriteFile(d_url,d_cont);
%>
今日总访问量:<%=d_cont%> <br />
<%
String[] day_arr=dc_date.split("-");
int aftdate=Integer.parseInt(day_arr[2])-1;
int yuedate=Integer.parseInt(day_arr[1]);
if(aftdate<=0){
aftdate=30;
yuedate=yuedate-1;
}
String dc_day=day_arr[0]+"-"+yuedate+"-"+aftdate;
String a_url=request.getRealPath("/Count/"+dc_day+".txt");
String a_cont=counter.ReadFile(a_url);
//调用counter对象的ReadFile方法来将计数器加一后写入到文件lyfcount.txt中
%>
昨日总访问量:<%=a_cont%> <br />
分享到:
相关推荐
可以统计网站的访问总人数,昨天访问,今天访问量,在线人数; 11, 增加影片专集类功能; 12,增加服务器密码认证; 13,增加影片浏览失效性验证,用户可以付款一次,免费再看几次(后台设置); 14,...
可以统计网站的访问总人数,昨天访问,今天访问量,在线人数; 11, 增加影片专集类功能; 12,增加服务器密码认证; 13,增加影片浏览失效性验证,用户可以付款一次,免费再看几次(后台设置); 14...
A、FoxBASE B、DOS C、数据库管理系统 D、数据库 7.用紧急启动盘(ESD)启动计算机后,屏幕上出现的信息是___B____。 A、Windows98桌面 B、A> C、Windows98资源管理器 D、C> 8.关于文件的含义,比较正确的说法应该是...
cmd-bat-批处理-脚本-IE主页修改.zip
Delphi 12.3控件之uniGUI-Extras_1.95.0.1600.rar
内容概要:本文主要介绍了SQL注入的概念、危害及其防范措施。SQL注入是攻击者通过恶意构造输入,使服务器执行非预期的SQL命令的一种攻击方式,常因用户输入未
使用方法:拷贝到Auto CAD的Fonts下
cmd-bat-批处理-脚本-维护版.zip
解压
内容概要:本文档为《mysql.docx》,主要汇总了MySQL的各类常用命令,分为基础命令、数据库相关命令、数据表相关命令和事务相关命令四大部分。基础命令涵盖了连接、创建、删除数据库,创建和删除表,插入、查询、更新、删除数据等基本操作;数据库相关命令则进一步细化了对数据库的管理操作,如修改编码格式、查看数据库详细信息等;数据表相关命令着重介绍了对表结构和数据的操作,包括创建、修改、删除表,添加、删除、修改列,创建和删除索引等;事务相关命令主要涉及事务的开始、提交、回滚,设置事务隔离级别,以及表的锁定与解锁操作。; 适合人群:适用于具有一定SQL基础,尤其是MySQL使用经验的数据库管理员或开发人员。; 使用场景及目标:①帮助用户快速查找并正确使用MySQL的各种命令;②提高用户对MySQL数据库的操作能力,包括但不限于数据库和表的创建、修改、删除,数据的增删改查等;③掌握MySQL事务处理机制,确保数据的一致性和完整性。; 其他说明:本文档是MySQL命令的集合,建议用户在实际操作前先熟悉各个命令的具体用法,并在测试环境中进行练习,避免误操作导致数据丢失或其他严重后果。
cmd-bat-批处理-脚本-交换两个变量的值而不使用临时变量.zip
内容概要:集成测试是确保软件质量的关键环节,它在单元测试基础上验证模块间的交互和协作。文章详细介绍了集成测试的目的、重要性、流程步骤、策略与方法以及常见问题的解决办法。集成测试不仅验证模块接口的正确性,还确保系统的整体功能和性能符合预期。文章通过一个电商系统的实际案例,展示了集成测试在发现和解决问题中的具体应用。最后,展望了集成测试未来的发展趋势,如自动化测试、云计算、大数据和人工智能技术的应用。 适合人群:软件开发人员、测试工程师、项目经理及相关技术人员。 使用场景及目标:①了解集成测试在整个软件开发生命周期中的作用和重要性;②掌握集成测试的详细流程,包括测试计划制定、环境搭建、用例设计、执行与记录、缺陷管理和回归测试、测试总结与报告;③学习集成测试的不同策略(自顶向下、自底向上、混合策略)和方法(黑盒测试、白盒测试、模拟测试),并理解其适用场景;④掌握常见问题(接口不匹配、数据传递错误、性能瓶颈)的解决办法。 其他说明:本文不仅提供了集成测试的理论知识,还结合实际案例进行详细讲解,帮助读者更好地理解和应用集成测试技术。未来集成测试将受益于自动化测试、云计算、大数据和人工智能技术的发展,测试人员应不断学习新技术,优化测试流程,提高软件质量和效率。
cmd脚本-bat批处理-快速设定分辨率.zip
内容概要:本文献为电子科技大学硕士学位论文,题目为“高阶过采样delta-sigma DAC设计”。论文首先介绍了DAC的基本概念及其多种结构,重点阐述了delta-sigma DAC的优势,包括实现24位以上量化精度、简化模拟部分设计等。接着详细探讨了delta-sigma DAC的核心组成部分——过采样和噪声整形。过采样部分采用8倍插值8倍采样保持结构,其中插值器由2倍和4倍插值器级联构成;噪声整形部分采用5阶结构,优化了零点和极点,形成前馈加局部振荡反馈的噪声整形环。论文还介绍了在Matlab中完成的数字模型和FPGA平台上实现的硬件设计,最终实现了16位数据位宽、信噪比为95.53dB的delta-sigma DAC。 适合人群:具备一定电子工程和数字信号处理基础,特别是对DAC设计感兴趣的研究生或研究人员。 使用场景及目标:①适用于研究高精度数模转换技术的学术机构;②为设计高阶过采样delta-sigma DAC提供理论和技术支持;③探索delta-sigma技术在音频和其他高精度应用领域的潜力。 阅读建议:此资源不仅涉及复杂的理论分析,还包括详细的硬件实现步骤,建议读者在理解基本概念的基础上逐步深入,结合Matlab仿真和FPGA实现进行实践,以加深对delta-sigma DAC设计的理解。
cmd-bat-批处理-脚本-弹出对话框.zip
提供一个ARIMA模型的MATLAB代码示例,该代码能够根据用户自身的具体需求灵活调整参数,从而达到预期的分析效果。
cmd-bat-批处理-脚本-倒记时(全屏).zip
ssm+vue图书管理系统全套源码+毕业论文+数据库sql,全套毕设,非常具有参考意义
cmd-bat-批处理-脚本-更改电源管理方式.zip
cmd-bat-批处理-脚本-禁止用XP的图片视频预览功能.zip