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

[日期时间] 为什么NT AUTHORITY\SYSTEM权限下的任务计划不能正常运行?

[复制链接]
 楼主| 发表于 2014-10-21 11:13:57 | 显示全部楼层
回复  sinun


看起来像是修改注册表失败,或者是修改注册表成功了但是没有生效。你把 reg add 那行改成 ...
Batcher 发表于 2014-10-14 14:09


下面是问题重现,请帮忙看看问题在哪里,谢谢!

(1) 日期格式为M/d/yyyy,直接运行C:\DelData.bat,运行正常,DelData.log内容如下。(10/07/2014文件被删除,其它保留)
  1. 修改注册表之前

  2. ! REG.EXE VERSION 3.0

  3. HKEY_CURRENT_USER\Control Panel\International
  4.     sShortDate        REG_SZ        yyyy-M-d


  5. The operation completed successfully
  6. 修改注册表之后

  7. ! REG.EXE VERSION 3.0

  8. HKEY_CURRENT_USER\Control Panel\International
  9.     sShortDate        REG_SZ        yyyy-M-d

  10. "2014-10-16 08:05 PM" leq "2014-10-08"
  11. "2014-10-17 09:39 PM" leq "2014-10-08"
  12. "2014-10-18 06:26 AM" leq "2014-10-08"
  13. "2014-10-07 12:15 PM" leq "2014-10-08"
  14. "2014-10-09 09:31 PM" leq "2014-10-08"
  15. "2014-10-10 11:39 PM" leq "2014-10-08"
  16. "2014-10-11 11:33 PM" leq "2014-10-08"
  17. "2014-10-12 07:16 PM" leq "2014-10-08"
  18. "2014-10-13 10:17 PM" leq "2014-10-08"
  19. "2014-10-14 11:46 PM" leq "2014-10-08"
  20. "2014-10-16 10:07 PM" leq "2014-10-08"
  21. "2014-10-17 10:38 PM" leq "2014-10-08"
  22. "2014-10-18 05:43 AM" leq "2014-10-08"
  23. "2014-10-16 11:59 PM" leq "2014-10-08"
  24. "2014-10-17 11:59 PM" leq "2014-10-08"
  25. "2014-10-18 06:19 AM" leq "2014-10-08"
复制代码
(2) 日期格式更改为M/d/yyyy,第一次运行任务计划DelData,运行异常,DelData.log内容如下。(所有文件被删除)
  1. 修改注册表之前

  2. ! REG.EXE VERSION 3.0

  3. HKEY_CURRENT_USER\Control Panel\International
  4.     sShortDate        REG_SZ        M/d/yyyy


  5. The operation completed successfully
  6. 修改注册表之后

  7. ! REG.EXE VERSION 3.0

  8. HKEY_CURRENT_USER\Control Panel\International
  9.     sShortDate        REG_SZ        yyyy-M-d

  10. "10/16/2014 08:05 PM" leq "2014-10-08"
  11. "10/17/2014 09:39 PM" leq "2014-10-08"
  12. "10/18/2014 06:26 AM" leq "2014-10-08"
  13. "10/07/2014 12:15 PM" leq "2014-10-08"
  14. "10/09/2014 09:31 PM" leq "2014-10-08"
  15. "10/10/2014 11:39 PM" leq "2014-10-08"
  16. "10/11/2014 11:33 PM" leq "2014-10-08"
  17. "10/12/2014 07:16 PM" leq "2014-10-08"
  18. "10/13/2014 10:17 PM" leq "2014-10-08"
  19. "10/14/2014 11:46 PM" leq "2014-10-08"
  20. "10/16/2014 10:07 PM" leq "2014-10-08"
  21. "10/17/2014 10:38 PM" leq "2014-10-08"
  22. "10/18/2014 05:43 AM" leq "2014-10-08"
  23. "10/16/2014 11:59 PM" leq "2014-10-08"
  24. "10/17/2014 11:59 PM" leq "2014-10-08"
  25. "10/18/2014 06:19 AM" leq "2014-10-08"
复制代码
(3) 日期格式更改为M/d/yyyy,但第二次运行任务计划DelData,运行正常,DelData.log内容同(1)
日期格式已更改为M/d/yyyy了,但任务计划返回的值仍是yyyy-M-d
发表于 2014-10-21 11:27:29 | 显示全部楼层
回复 16# sinun


你手工修改注册表,把日期格式设置成 yyyy-M-d
把任务计划里面的脚本改成这样:
  1. @echo off
  2. schtasks /create /tn DelData /tr "C:\DelData.bat" /sc daily /st 18:00:00 /ru system

  3. set SrcDir=C:\Data
  4. set DaysAgo=10
  5. >"%temp%\DstDate.vbs" echo LastDate=date()-%DaysAgo%
  6. >>"%temp%\DstDate.vbs" echo FmtDate=right(year(LastDate),4) ^& right("0" ^& month(LastDate),2) ^& right("0" ^& day(LastDate),2)
  7. >>"%temp%\DstDate.vbs" echo wscript.echo FmtDate
  8. for /f %%a in ('cscript /nologo "%temp%\DstDate.vbs"') do (
  9.     set "DstDate=%%a"
  10. )
  11. set DstDate=%DstDate:~0,4%-%DstDate:~4,2%-%DstDate:~6,2%
  12. for /r "%SrcDir%" %%a in (*.*) do (
  13.     echo "%%~ta" leq "%DstDate%">>C:\DelData.log
  14.     if "%%~ta" leq "%DstDate%" (
  15.         if exist "%%a" (
  16.             del /f /q "%%a"
  17.         )
  18.     )
  19. )
复制代码
发表于 2014-10-21 13:00:02 | 显示全部楼层
HKEY_USERS\S-1-5-18对应的是system账户的SID,试试修改 HKEY_USERS\S-1-5-18\Control Panel\International的sShortDate值看行不行。

评分

参与人数 1技术 +1 收起 理由
sinun + 1 感谢老师的回复!

查看全部评分

 楼主| 发表于 2014-10-25 10:47:37 | 显示全部楼层
回复  sinun


你手工修改注册表,把日期格式设置成 yyyy-M-d
把任务计划里面的脚本改成这样:
Batcher 发表于 2014-10-21 11:27


按老师的要求手工修改了注册表,运行C:\DelData.bat,自动生成DstDate.vbs,可正常删除10天之前的文件
DelData.log内容如下:
  1. "2010-11-20 09:06" leq "2014-10-15"
  2. "2014-10-21 10:21" leq "2014-10-15"
  3. "2014-10-25 10:23" leq "2014-10-15"
  4. "2014-10-25 10:04" leq "2014-10-15"
复制代码
运行任务计划DelData,不会生成DstDate.vbs,但也可删除10天之前的文件,10天之内的保留。DelData.log内容与上面相同。不生成DstDate.vbs,怎么计算的日期呢?
 楼主| 发表于 2014-10-25 10:57:21 | 显示全部楼层
HKEY_USERS\S-1-5-18对应的是system账户的SID,试试修改 HKEY_USERS\S-1-5-18\Control Panel\International ...
apang 发表于 2014-10-21 13:00


修改了注册表后,运行C:\DelData.bat,可生成DstDate.vbs,

运行任务计划DelData,不会生成DstDate.vbs,但也可以正常删除文件,请教老师这是为什么?
发表于 2014-10-25 14:45:03 | 显示全部楼层
回复 19# sinun


打开命令行窗口
cd /d "%temp%"
dir /b /a *.vbs
 楼主| 发表于 2014-10-26 22:12:23 | 显示全部楼层
回复 21# Batcher


运行任务计划,%temp%下没有生成DstDate.vbs,而是生成在C:\WINDOWS\temp目录下。

请老师帮忙解答一下,NT AUTHORITY\SYSTEM权限下的任务计划都是有哪些特殊的属性? 谢谢!!!
发表于 2014-10-26 23:36:15 | 显示全部楼层
以前碰到过schtasks创建的计划任务(system账户权限),用 xcopy 复制远程机器上的文件到本地失败,但改成具有管理员权限的账户可以复制,不知道为什么。
 楼主| 发表于 2014-10-27 05:25:25 | 显示全部楼层
回复 23# apang

是啊,对reg add也有限制,不知道system权限的计划任务到底有多少限制呢。
 楼主| 发表于 2014-12-12 22:08:04 | 显示全部楼层
回复 13# Batcher

请大神帮帮忙,看下面这个问题该怎么解决,多谢!!!

请教批处理命令findstr的异常问题
http://bbs.bathome.net/thread-33296-1-1.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

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

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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