环境:
windows 2003 server,.NET3.0,ASP.NET2.0.50727,C#步骤1.
第一个登录页面,用windows用户来登录,方法参看http://www.qqgb.com/NetProgramme/ASPNet/AspNetExample/NetProgramme_123255.html
登录成功后将WindowsIdentity对象放入session
步骤2.
之后的页面,因为要操作文件涉及用户有没有权限,在代码中模拟之前登录的windows用户,方法参看http://www.microsoft.com/china/community/program/originalarticles/techdoc/impersonation.mspx问题:
以上做法在web.config的sessionState mode="InProc"的时候没有问题。
但是在sessionState mode="StateServer"的时候,执行page_load中的WindowsIdentity wi = (WindowsIdentity)Session["loginUser"]这句的时候就出错了,报以下错误:
Invalid token for impersonation - it cannot be duplicated。(偽装に対するトークンが無効です。トークンを重複することはできません。)
用于模拟的token无效,token不能重复。
各位有遇到过吗?怎么解决啊查了好久了

解决方案 »

  1.   

    没有用过这个版本,
    sessionState mode="StateServer"需要启动一个服务Asp.net.检查一下是否有遗漏.
      

  2.   

    只是听说过
    用Struts的Token机制解决表单重复提交
      

  3.   

    TO:dick78 
    服务是先启动了的,否则会出另外的错的
    Asp.net.检查一下是否有遗漏,,,这个要怎么查??
      

  4.   

    结帖了,没有找到好的办法,只有每次要用WindowsIdentity时再去用loginUser重新取一次
    WindowsIdentity wi = new WindowsIdentity(IntPtr ptr)用这样生成wi.Token的值和生成之前的ptr的值是不一样的。没明白是为什么谢谢各位!