把每一个用户的登陆信息都写到各自cookie中,然后通过读cookie来判断!
解决方案 »
- hibernate 配置没有错误,建表语句,不能执行
- struts2
- 关于request.getParameter(),(急求)
- 我想要图片轮显的效果
- 利用数据库连接在jsp页面中创建数据库表,字段列数、字段名、类型都由用户确定
- 大家来讨论看看。目前这2种数据库哪个更好些?来者有分!
- 使用jspsmartupload遇到了问题!!!请高手指点啊
- 请问我要在servlet中调用javabean怎样做呢?servlet在classes/servlet下login.class
- 被这个问题折磨的快死了,到底该怎么办呢?求助!
- JSP的事件触发?我头大了,请各位多多帮忙!谢谢!
- tomcat下如何建立自己的虚拟目录
- 关于jsp调用servlet的问题
我也比较关系这个问题。
我得想法是用户第一次登录的时候生成一个编码(GUID),然后存到服务器(数据库或session),用户每次提交请求的时候都带着这个编码,进行验证,如果相同,表示是同一个客户端登录的。如果另外一个人登录就重新生成一个不一样的编码,验证编码不一致,就将前一个人在服务器的端编码更新,这样第一个人访问页面的时候,带着原来的编码,验证编码不一致,提示已经有人用他的帐号登录了,不能访问服务器了,必须重新登录。这样的机制是保证后登陆的人是合法。
这只是我得想法,可能实际操作中会有更多的问题需要考虑,比如服务器怎样保存这么多得用户数据,并且需要频繁的访问。
不知道是否可行
就是登陆之后他再点登陆就显示他登陆过了.不用再登陆了
我说的对吧.
我觉得用session就可以了啊.
登陆的时候判断session是不是为空.
如果是空的话就没有登陆.
如果不为空就登陆过了.
关键字 Session 时时监控例子
/**这是管理user信息的类文件名为onLineUser.java*/import javax.servlet.http.*;
import javax.servlet.*;
import java.util.*; public class onLineUser implements HttpSessionBindingListener {
public onLineUser(){
} private Vector users=new Vector();
public int getCount(){
users.trimToSize();
return users.capacity();
}
public boolean existUser(String userName){
users.trimToSize();
boolean existUser=false;
for (int i=0;i<users.capacity();i++ )
{
if (userName.equals((String)users.get(i)))
{
existUser=true;
break;
}
}
return existUser;
} public boolean deleteUser(String userName) {
users.trimToSize();
if(existUser(userName)){
int currUserIndex=-1;
for(int i=0;i<users.capacity();i++){
if(userName.equals((String)users.get(i))){
currUserIndex=i;
break;
}
}
if (currUserIndex!=-1){
users.remove(currUserIndex);
users.trimToSize();
return true;
}
}
return false;
} public Vector getOnLineUser()
{
return users;
}
public void valueBound(HttpSessionBindingEvent e) {
users.trimToSize();
if(!existUser(e.getName())){
users.add(e.getName());
System.out.print(e.getName()+"\t 登入到系统\t"+(new Date()));
System.out.println(" 在线用户数为:"+getCount());
}else
System.out.println(e.getName()+"已经存在");
} public void valueUnbound(HttpSessionBindingEvent e) {
users.trimToSize();
String userName=e.getName();
deleteUser(userName);
System.out.print(userName+"\t 退出系统\t"+(new Date()));
System.out.println(" 在线用户数为:"+getCount());
}
} /////////////////////////////////////////////////////////////////////////////
<%
/**这是显示在线用户的jsp文件文件名为onLineUser.jsp*/
%>
<%@ page contentType="text/html;charset=gb2312" %>
<%@ page import="onLineUser,java.util.*" %>
<jsp:useBean id="onlineuser" class="onLineUser" scope="application"/>
<html>
<head>
<title>搞定JSP在线人数</title>
</head>
<body>
<center>
<p><h1>登陆成功,欢迎您访问!</h1></p>
</center>
<% session = request.getSession(false); %>
<%
String username=request.getParameter("username");
if (onlineuser.existUser(username)){
out.println("用户<font color=red>"+username+"</font>已经登陆!");
}else{
session.setMaxInactiveInterval(50); file://Sesion有效时长,以秒为单位
session.setAttribute(username,onlineuser);
out.println("欢迎新用户:<font color=red>"+username+"</font>登陆到系统!");
}
out.println("<br>当前在线用户人数:<font color=red>"+onlineuser.getCount()+"</font><br>");
Vector vt=onlineuser.getOnLineUser();
Enumeration e = vt.elements();
out.println("在线用户列表");
out.println("<table border=1>");
out.println("<tr><td>用户名</td></tr>");
while(e.hasMoreElements()){
out.println("<tr><td>");
out.println((String)e.nextElement()+"<br>");
out.println("</td></tr>");
}
out.println("</table>");
%>
<center>
<p>elapsed制作</p>
<p> </p>
<%
out.println("<p><a href='logout.jsp?username="+username+"'>退出系统</a></p>");
%>
</center>
</body>
</html> ////////////////////////////////////////////////////////////////////////////////////
<%
/**这是用户退出的jsp文件文件名为logout.jsp*/
%>
<%@ page contentType="text/html;charset=gb2312" %>
<%@ page import="onLineUser,java.util.*" %>
<jsp:useBean id="onlineuser" class="onLineUser" scope="application"/>
<html>
<head>
<title>搞定JSP在线人数</title>
</head>
<body>
<center>
<p><h1>登陆成功,欢迎您访问!</h1></p>
</center>
<%
String username=request.getParameter("username");
if(onlineuser.deleteUser(username))
out.println(username+"已经退出系统!");
else
out.println(username+"没有登陆到系统!");
%>
<center>
<p>elapsed制作</p>
<p> </p>
<p><a href="logout.jsp">退出系统</a></p>
</center>
</body>
</html>
*先建立一个表来记录"用户名seriesNo"与 "sessionID"
*当用户登录时,我们插入或更新一条记录,记录下最后的sessionID,seriesNo等。当用户提交请求时,我们将当前页面的sessionID,seriesNo与数据库中的比较,如果匹配,则提交,否则拒绝该请求。
这种处理方法,正如 tele(tele) 所说的那样。这只能是做到限制一个帐号在一时间内只能一个人使用,但做不到"在登陆验证用户密码的同时,判断这个帐号是否已经在使用中,如果这个正在使用,则提示用户不能再登录。"
看了你们的做法~~~觉得挺可行的~起码做到限制一个帐号在一时间内只能一个人使用挺好的~~~~
但是有个问题~~只有在第二个下相同的账号登陆后~~~第一个账号再有操作~~会提示从登陆~
那么~~~要是几个人同一时段进行操作~~~是不是没个人都不会很连贯~~总会被打断~~~是这样吗?实际中是不是很少~我多虑了~搂主~说的~~登录的时候判断该用户是否已经登录~我用的是sessoin~~监控离线~~但是时间控制的不精确~~尤其是关IE的时候~~~~但是确实可以做到~~~关注中~~~