效果: css
驗證碼仍是沒有佈局好.背景比較懷古. html
1.寫前端html
login.jsp前端
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"> <title>登陸</title> <link rel="stylesheet" href="/static/css/layui.css"> <link rel="stylesheet" href="/static/css/login.css"> </head> <body> <div class="clear box layui-main login"> <form class="layui-form layui-form-pane1" action="ulogin" method="post"> <div class="layui-form-item"> <label class="layui-form-label">用戶名:</label> <div class="layui-input-block"> <input type="text" name="user.name" lay-verify="uname" required placeholder="請輸入用戶名" autocomplete="off" class="layui-input">${UnameErrMsg?if_exists} </div> </div> <div class="layui-form-item"> <label class="layui-form-label">密碼:</label> <div class="layui-input-block"> <input type="password" name="user.pwd" lay-verify="" required placeholder="請輸入密碼" autocomplete="off" class="layui-input">${PwdErrMsg?if_exists} </div> </div> <div class="layui-form-item"> <label class="layui-form-label">驗證碼:</label> <div class="layui-input-block"> <input type="text" name="yzm" lay-verify="" required placeholder="請輸入驗證碼" autocomplete="off" class="layui-input">${yzmErrMsg?if_exists}<br> <a href="/login.html"><img alt="驗證碼" src="/yzm"></a> </div> </div> <div class="layui-form-item"> <label class="layui-form-label"></label> <button class="layui-btn layui-btn-normal btn-center" type="submit">登陸</button> </div> </form> </div> <script src="/static/js/layui.js"></script> </body> </html>
登陸界面樣式python
@CHARSET "UTF-8";
body{
background-image:url(/static/images/login-bg.png);
}
.login {
padding-top: 15%;
width: 26%;
}
.btn-center{
text-center:center;
margin:0 auto;
}
2.寫控制器
其中就是login方法與ulogin方法
controller包下IndexController類sql
package cn.pangpython.controller; import com.jfinal.aop.Before; import com.jfinal.core.Controller; import com.jfinal.ext.kit.SessionIdKit; import cn.pangpython.model.User; import cn.pangpython.utils.DateUtils; import cn.pangpython.utils.MD5; import cn.pangpython.validate.RegistValidator; import cn.pangpython.validate.UserLoginValidator; /** * @author pangPython * 主頁控制器 */ public class IndexController extends Controller { public void index(){ renderText("index"); } //渲染註冊頁面 public void regpage(){ render("regist.html"); } //處理註冊 @Before(RegistValidator.class) public void regist(){ String pwd = getPara("user.pwd"); String confirm = getPara("reg.confirm"); //驗證碼驗證 boolean result = validateCaptcha("reg.yzm"); if(!result){ setAttr("yzmErrMsg", "驗證碼錯誤!"); render("regist.html"); return; } //確認密碼驗證 if(!pwd.equals(confirm)){ setAttr("confirmErrMsg", "請正確填寫確認密碼!"); render("regist.html"); return; } String uname = getPara("user.name"); User user = getModel(User.class); String reg_time = DateUtils.dateToUnixTimestamp(DateUtils.getNowTime())+""; //使用用戶註冊日期做爲md5密碼加密的鹽值,可節省一個salt數據庫字段 pwd = MD5.GetMD5Code(pwd+reg_time); //給user實體類填充數據 user.setName(uname); user.setPwd(pwd); user.setRegTime(reg_time); //使用jfinal的保存操做 user.save(); renderText("註冊成功!"); } public void login(){ render("login.html"); } @Before(UserLoginValidator.class) public void ulogin(){ // 驗證碼結果 boolean result = validateCaptcha("yzm"); if (!result) { setAttr("yzmErrMsg", "驗證碼錯誤!"); render("login.html"); return; } String uname = getPara("user.name"); String sql = "select * from user where name = ? limit 1"; User user = User.dao.findFirst(sql, uname); if (user != null) { String pwd = MD5.GetMD5Code(getPara("user.pwd") + user.getRegTime()); if (user.getPwd().equals(pwd)) { // 生成惟一標識 String sessionId = SessionIdKit.me().generate(getRequest()); // 設置服務器端session setSessionAttr(sessionId, user); // 設置用戶端cookie setCookie("cuser", sessionId, 60000); //redirect("/user"); renderText("登陸成功!"); } else { // 密碼不正確 setAttr("UnameErrMsg", "用戶名或密碼不正確!"); render("login.html"); } } else { // 用戶名不存在 setAttr("UnameErrMsg", "用戶名不存在!"); render("login.html"); } } }
3.寫登陸驗證器
validator包下的UserLoginValidator繼承JFinal的Validator數據庫
package cn.pangpython.validate; import com.jfinal.core.Controller; import com.jfinal.validate.Validator; public class UserLoginValidator extends Validator { @Override protected void handleError(Controller controller) { controller.keepPara(); } @Override protected void validate(Controller arg0) { validateRequired("user.name", "UnameErrMsg", "請輸入用戶名!"); validateRequired("user.pwd", "PwdErrMsg", "請輸入密碼!"); validateRequired("yzm", "yzmErrMsg", "請輸入驗證碼!"); } }
注:驗證碼的校驗也能夠在驗證器中進行驗證
到此就完成了登陸功能.運行config文件,訪問服務器
http://localhost/logincookie
原文:https://blog.csdn.net/u012995856/article/details/52927053
session