记录用户上次登录时间

sky11007 2008-10-09 04:31:55
我想做一个就是上次访问者的登录时间和ip 我用了firsttime,lasttime ,firstip,lastip四个字段,我是让他在用户登录时候把这四个字段写入到数据库代码是
command1.CommandType = CommandType.StoredProcedure;
conn1.Open();
SqlParameter date = command1.Parameters.Add("@firsttime", SqlDbType.DateTime);
date.Value = Convert.ToString(DateTime.Now);
SqlParameter date1=command1 .Parameters .Add ("@lasttime",SqlDbType.DateTime );
date1.Value = date .Value ;
SqlParameter firstip = command1.Parameters.Add("@firstip", SqlDbType.NVarChar, 50);

firstip.Value = Convert.ToString(Request.UserHostAddress);
SqlParameter lastip=command1 .Parameters .Add ("@lastip",SqlDbType.NVarChar ,50);
lastip.Value = firstip.Value;
command1.ExecuteNonQuery();
conn1.Close();
用的是存储过程 但是写入数据库的时间firsttime和lasttime是一个样的,是同一时间,不知道怎样才能读出上次登录时间,
问题很简单,初学者,请详细讲解,谢谢
...全文
889 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhifeng2012 2010-07-14
  • 打赏
  • 举报
回复
ding!ding!ding!
js1722 2008-10-16
  • 打赏
  • 举报
回复
先取改用户的最后一次登陆时间嘛. 如果不存在的话,那他就是第一次登录了.select max(lasttime ) from table where id = '用户ID'
lovehongyun 2008-10-10
  • 打赏
  • 举报
回复
你把两个时间全搞成DateTime.Now那肯定两个时间都是相同的,而且是当前时间
lovehongyun 2008-10-10
  • 打赏
  • 举报
回复
你要取出上次登录的时间才行.

而不是把所有的时间都用当前时间
wihtsky 2008-10-10
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 bingbingw 的回复:]
firsttime 只在第一次时才是DateTime.Now。再插入time和ip时判断一下,以后每次再插入的firstime应该是上次的lasttime。除非你要保留firsttime这个时间。
[/Quote]
bingbingw 2008-10-10
  • 打赏
  • 举报
回复
firsttime 只在第一次时才是DateTime.Now。再插入time和ip时判断一下,以后每次再插入的firstime应该是上次的lasttime。除非你要保留firsttime这个时间。
coco_ke 2008-10-10
  • 打赏
  • 举报
回复
FirstTime和LastTime每次登陆时都更新时间,而且更新的都是当前时间,如果在这之后再读取FirstTime和LastTime,读出来的还是当前时间
sky11007 2008-10-09
  • 打赏
  • 举报
回复
谢谢 请大家多多指教
sky11007 2008-10-09
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 Aden 的回复:]
firsttime 只是第一次记录才写,你这里每次都写有问题.加个判断该用户是否已登录
[/Quote]
能不能在说的详细点啊,我的整体代码是这样的
SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["project_DataConnectionString"].ConnectionString);
SqlCommand command = new SqlCommand("selectuser", conn);
command .CommandType =CommandType .StoredProcedure ;
conn.Open();
SqlParameter username = command.Parameters.Add("@name", SqlDbType.NVarChar, 50);
username.Value = TextBox1.Text;
SqlParameter pass = command.Parameters.Add("@pwd", SqlDbType.NVarChar, 50);
pass.Value = TextBox2.Text;
SqlDataReader dr = command.ExecuteReader();
if (dr.Read() == true)
{
Session["username"] = name;
SqlConnection conn1 = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["project_DataConnectionString"].ConnectionString);
SqlCommand command1 = new SqlCommand("insertlogin01",conn1 );
command1.CommandType = CommandType.StoredProcedure;
conn1.Open();
SqlParameter date = command1.Parameters.Add("@firsttime", SqlDbType.DateTime);
date.Value = Convert.ToString(DateTime.Now);
SqlParameter date1=command1 .Parameters .Add ("@lasttime",SqlDbType.DateTime );
date1.Value = date .Value ;
SqlParameter firstip = command1.Parameters.Add("@firstip", SqlDbType.NVarChar, 50);

firstip.Value = Convert.ToString(Request.UserHostAddress);

SqlParameter lastip=command1 .Parameters .Add ("@lastip",SqlDbType.NVarChar ,50);
lastip.Value = firstip.Value;
command1.ExecuteNonQuery();
conn1.Close();
Server.Transfer("kyfb.aspx");

}
else
{
Session["username"] = "";
this.Response.Write("<script>window.alert('用户名或密码错误')</script>");

}
dr.Close();


conn.Close();
Aden 2008-10-09
  • 打赏
  • 举报
回复
firsttime 只是第一次记录才写,你这里每次都写有问题.加个判断该用户是否已登录
yangpeiyu 2008-10-09
  • 打赏
  • 举报
回复
你上次的时间是必需先从你库里的firsttime这个字段的值..以此类推.

是先从库取出值然后分别赋给对应的.然后当前是永远是DateTime.Now
Re: 《用户管理及用户信息查询命令》 ---------------------------------------内容提要: 01/19)命令useradd   :创建用户02/19)命令usermod :修改用户信息03/19)命令userdel    :删除用户04/19)命令groupadd:创建新组05/19)命令groupdel :删除用户组06/19)命令passwd    :修改用户密码07/19)命令chage      :修改用户密码有效期08/19)命令chpasswd:批量更新用户密码09/19)命令su            :切换用户10/19)命令visudo     :编辑sudoers文件11/19)命令sudo        :以另一个用户身份执行命令12/19)命令id             :显示用户用户组的信息13/19)命令w             :显示已登录用户信息14/19)命令who          : 显示已登录用户信息15/19)命令users       :显示已登录用户16/19)命令whoami    : 显示当前登录用户名17/19)命令last          :显示用户登录列表18/19)命令lastb         : 显示用户登录失败的记录19/19)命令lastlog      : 显示所有用户的最近登录记录  本人在教学和实战过程中发现,即便是有一定运维经验的人,可能已经能够搭建一定复杂度的Linux架构,但是在来来回回的具体操作中,还是体现出CLI(命令界面)功底不够扎实,甚至操作的非常‘拙’、处处露‘怯’。 对一个士兵来说,枪就是他的武器,对于一个程序员来说,各种library(工具库)就是他的武器;而对于Linux运维人员来说,无疑命令行工具CLI(命令界面)就是他们的武器;高手和小白之间的差距往往就体现在对于这些“武器”的掌握和熟练程度上。有时候一个参数就能够解决的事情,小白们可能要写一个复杂的Shell脚本才能搞定,这就是对CLI(命令界面)没有理解参悟透彻导致。 研磨每一个命令就是擦拭手中的作战武器,平时不保养不理解,等到作战的时候,一定不能够将手中的武器发挥到最好,所以我们要平心、静气和专注,甘坐冷板凳一段时间,才能练就一身非凡的内功! 本教程从实战出发,结合当下流行或最新的Linux(v6/7/8 版本)同时演示,将命令行结合到解决企业实战问题中来,体现出教学注重实战的务实精神,希望从事或未来从事运维的同学,能够认真仔细的学完Linux核心命令的整套课程。 本课程系列将逐步推出,看看我教学的进度和您学习的步伐,孰占鳌头! 注:关于教学环境搭建,可以参考本人其它课程系列,本教学中就不再赘述! 《参透 VMware 桌面级虚拟化》 《在虚拟机中安装模版机(包括应用软件等)》 《SecureCRT 连接 GNS3/Linux 的安全精密工具》 

110,534

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧