做一个web登录界面,login.jsp里面进行登录,loginservlet进行登录处理,然后转回login.jsp进行显示
我在session里面添加一个boolean型的loginok参数,用来标识是否登录成功。然后在login.jsp里面判断loginok参数,来判断显示登陆框还是显示用户...
我在session里面添加一个boolean型的loginok参数,用来标识是否登录成功。然后在login.jsp里面判断loginok参数,来判断显示登陆框还是显示用户信息。但是在servlet里面:
boolean loginok = req.getParameter(loginok);
这句话会报错。 是否有高手帮忙解答一下一般网站登录是怎么做的。
有没有人能附上jsp和servlet的源码,非常感谢啊,用Boolean型参数去判断我觉得不是很好啊。一般网站的登录是怎么做的呢,就是登录之后返回主页,原先登录的区域显示成已登录的用户信息。 非常感谢! 展开
boolean loginok = req.getParameter(loginok);
这句话会报错。 是否有高手帮忙解答一下一般网站登录是怎么做的。
有没有人能附上jsp和servlet的源码,非常感谢啊,用Boolean型参数去判断我觉得不是很好啊。一般网站的登录是怎么做的呢,就是登录之后返回主页,原先登录的区域显示成已登录的用户信息。 非常感谢! 展开
4个回答
展开全部
首先,你jsp跳转到Servlet是用哪种方法传值的,是form表单提交,还是用连接(&loginok=true)这样的提交。无论怎样提交。boolean loginok = req.getParameter(loginok);也不对啊。req是什么类型的啊?你的loginok是放在session里面的。所以先创建session对象,然后在用session的内置方法获取loginok的值。HttpSession session = request.getSession();然后在boolean loginok = session.getAttribute("loginok");
下面是我自己登陆用的Servlet希望可以帮到你:
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String userName = "";
String userPwd = "";
String flag = "";
flag = request.getParameter("flag");
if (flag == null) {
flag = "";
}
if (flag.equals("back")) {
HttpSession session = request.getSession();
session.invalidate();
flag = "";
response.sendRedirect("/MicroBlog/initServlet");
} else {
boolean bool = false;
action login = new action();
try {
RequestDispatcher rd = null;
request.setCharacterEncoding("UTF-8"); // 中文转码
response.setCharacterEncoding("UTF-8");
userName = request.getParameter("name"); // 获得用户登录名
userPwd = request.getParameter("pwd"); // 获得用户密码
bool = login.getLogin(userName, userPwd);
HttpSession session = request.getSession();
if (bool) { // 登陆成功
UserForm userForm = login.getUser();
ArrayList<String> guanList = login.getGuan(userForm.getId());
ArrayList<ExForm> expList = login.getExp();
session.setAttribute("exp", expList);
session.setAttribute("user", userForm);
session.setAttribute("guan", guanList);
rd = request.getRequestDispatcher("user.jsp");
} else {
rd = request.getRequestDispatcher("error.jsp");
}
rd.forward(request, response);
} catch (Exception e) {
e.printStackTrace();
}
}
}
下面是我自己登陆用的Servlet希望可以帮到你:
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String userName = "";
String userPwd = "";
String flag = "";
flag = request.getParameter("flag");
if (flag == null) {
flag = "";
}
if (flag.equals("back")) {
HttpSession session = request.getSession();
session.invalidate();
flag = "";
response.sendRedirect("/MicroBlog/initServlet");
} else {
boolean bool = false;
action login = new action();
try {
RequestDispatcher rd = null;
request.setCharacterEncoding("UTF-8"); // 中文转码
response.setCharacterEncoding("UTF-8");
userName = request.getParameter("name"); // 获得用户登录名
userPwd = request.getParameter("pwd"); // 获得用户密码
bool = login.getLogin(userName, userPwd);
HttpSession session = request.getSession();
if (bool) { // 登陆成功
UserForm userForm = login.getUser();
ArrayList<String> guanList = login.getGuan(userForm.getId());
ArrayList<ExForm> expList = login.getExp();
session.setAttribute("exp", expList);
session.setAttribute("user", userForm);
session.setAttribute("guan", guanList);
rd = request.getRequestDispatcher("user.jsp");
} else {
rd = request.getRequestDispatcher("error.jsp");
}
rd.forward(request, response);
} catch (Exception e) {
e.printStackTrace();
}
}
}
追问
万分感谢!
由于学java不久,有些不太理解的地方。
有几点小疑问:
1.flag字符串是做标志位吗?back信息是退出的意思?
1.action login = new action(); 是定义Login这个动作是吧, bool = login.getLogin(userName, userPwd);这句怎么实现判断用户是否登录正确呢?
小号暂时没有对的加分了 以后上有分的号问。
展开全部
HttpSession session = request.getSession(true);
String acount = request.getParameter("acount") == null ? "" : request.getParameter("acount");
String pwd = request.getParameter("pwd") == null ? "" : request.getParameter("pwd");
String loginSQL=登录sql;
User obj= (User) lDao.LoginByName(loginSQL);
if(obj!=null){
if (kang.getPwd().equals(encryPtPwd(pwd.toLowerCase()))) {
session.setAttribute("acount", kang.getAcount());
}
}
然后在页面 判断 if(request.getAttribute("acount")!=null){
显示用户名
}
else{
用户名密码错误
}
encryPtPwd这个是加密的
String acount = request.getParameter("acount") == null ? "" : request.getParameter("acount");
String pwd = request.getParameter("pwd") == null ? "" : request.getParameter("pwd");
String loginSQL=登录sql;
User obj= (User) lDao.LoginByName(loginSQL);
if(obj!=null){
if (kang.getPwd().equals(encryPtPwd(pwd.toLowerCase()))) {
session.setAttribute("acount", kang.getAcount());
}
}
然后在页面 判断 if(request.getAttribute("acount")!=null){
显示用户名
}
else{
用户名密码错误
}
encryPtPwd这个是加密的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用req.getSession().getAttribute("loginok");
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
报的什么错,是不是因为你的括号中的字符串没有加引号啊.....
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询