按行输出log日志文件里的日志,

如果用不同的bufferedreader的readline方法去读取一个日志文件里的一行的话,经常会出现,实际读出来的并不是真是的行,而是会把行阶段,用下面的方式,可以把一个文件里的行日志,按行输出:

	@GET
	@Path("viewlog")
	@Produces("text/plain;charset=UTF-8")
	public String viewLog(@QueryParam("s") Integer s,@QueryParam("k") String k) {
		String logpath = ConfigHelp.getProperty("logpath");
		StringBuffer sb = new StringBuffer();
		try {
			RandomAccessFile rf = null;
			rf = new RandomAccessFile(logpath, "r");
			long len = rf.length();
			long start = rf.getFilePointer();
			long nextend = start + len - 1;
			String line;
			rf.seek(nextend);
			int c = -1;
			int size = 0;
			while (nextend > start && size < ((null == s) ? 30 : s)) {
				c = rf.read();
				if (c == '\n' || c == '\r') {
					line = rf.readLine();
					if (line != null) {
						String str = new String(line.getBytes("ISO-8859-1"), "utf-8");
						if(StringUtils.isEmpty(k) || (StringUtils.isNotEmpty(k) && str.contains(k))){
							sb.append(str).append("\r\n").append("\r\n");
							size++;
						}
					}
					nextend--;
				}
				nextend--;
				rf.seek(nextend);
				if (nextend == 0) {// 当文件指针退至文件开始处,输出第一行
					String str = new String(rf.readLine().getBytes("ISO-8859-1"), "utf-8");
					if(StringUtils.isEmpty(k) || (StringUtils.isNotEmpty(k) && str.contains(k))){
						sb.append(str);
						size++;
					}
				}
			}
			rf.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
		return sb.toString();
	}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值