找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 31735|回复: 6

[系统相关] 如何将自己的cmd命令记录到日志文件中

[复制链接]
发表于 2012-6-12 15:38:43 | 显示全部楼层 |阅读模式
本帖最后由 qzwqzw 于 2012-6-12 20:49 编辑

有感于自己cmd命令用的有点乱
怕自己也想不起来(最近记性是有点差了)
所以想找一种方法
把cmd中输入的命令自动记录到一个日志文件中
不知道大家有什么解决方案没有?
发表于 2012-6-12 16:03:52 | 显示全部楼层
这个只能靠第三方程序吧?需要常驻内存进行记录。
一个简单的模拟

  1. @echo off
  2. :loop
  3. set /p "input=%cd%>"
  4. setlocal enableDelayedExpansion
  5. >>cmd_his.log echo=!input!
  6. endlocal
  7. rem %ComSpec% /d /q /S /c "%%input%% "
  8. %input%
  9. goto loop
复制代码
发表于 2012-6-12 16:16:30 | 显示全部楼层
不知道具体是要做什么, 都是用doskey/h; 但很少用这命令。。
发表于 2012-6-12 16:34:22 | 显示全部楼层
这个不是一般的难啊。。。
 楼主| 发表于 2012-6-12 20:47:20 | 显示全部楼层
大家尽量扩展一下思路吧
我以前试过设置
HKEY_LOCAL_MACHINE\Software\Microsoft\Command Processor\AutoRun
的值为
echo [%date:~0,10% %time:~0,8%] [%CD%] [%USERNAME%@%USERDOMAIN%:%SESSIONNAME%] %cmdcmdline%>>d:\cmd.log
主要用来记录在后台偷偷调用cmd的情况
基本可以满足需求

但是这只记录使用cmd /c的调用命令行情况
对于在cmd中执行命令行它并不关心

再早之前
我曾经用DOS的ANSI.SYS转义序列
替换回车符为自定义的命令字符串
然后在命令字符串中做一些命令行扫尾的工作
比如用doskey记录命令到日志文件中
但是现在是Win7时代了
应该有更为现代化的方案了
发表于 2012-6-13 06:43:46 | 显示全部楼层
类似于Linux系统的history命令那样吗?
 楼主| 发表于 2014-11-27 11:09:50 | 显示全部楼层
最近尝试将
HKEY_LOCAL_MACHINE\Software\Microsoft\Command Processor\AutoRun
的值改为
c:\windows\system32\cmdlog.cmd

cmdlog.cmd代码如下

  1. @echo off
  2. cls
  3. if "%cmdlogroot%"=="" set cmdlogroot=%~sdpn0
  4. if not exist %cmdlogroot%\. md %cmdlogroot%
  5. set _date=%date:~0,10%
  6. set _time=%time::=%
  7. set cmdlogfile=cmd_%_date:-=%%_time:.=%.log
  8. set _date=
  9. set _time=
  10. cmd /d | tee -a -i %cmdlogroot%\%cmdlogfile%
复制代码
但是效果还是不甚理想
一是cmd控制台的IO模式被修改
cls,color等常用命令都会失效

二是只记录命令反馈结果
不记录命令本身
这点最要命
发出来给大家看看
大家有什么改进的主意?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-20 12:24 , Processed in 0.025295 second(s), 7 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表