<!--    html登录代码    -->
        <div class="box">
<div class="title">登录</div>
<div class="input">
<label for="name">用户名</label>
<input type="text" name="name" id="name">
<span class="spin"></span>
</div>
<div class="input">
<label for="pass">密码</label>
<input type="password" name="pass" id="pass">
<span class="spin"></span>
</div>
<div class="button login">
<button>
<span>登录</span>
<i class="fa fa-check"></i>
</button>
</div>
<a href="javascript:" class="pass-forgot">忘记密码?</a>
</div>
<!-- javasript 登录代码 -->
$(".button").click(function(e) {
$("button", this).addClass('active');
if ($(".button").hasClass("login")){
$.ajax({
url:"/cch/dologin",
type:"POST",
data:{
name:$("#name").serialize(),
pass:$("#pass").serialize(),
},
success:function (result) {
if(result.code==100){
window.location.href="/cch/main";
}else {
alert(result.extendInfo.login_error);
}
}
})
}
})
//JsonMsg工具类
public class JsonMsg {
private int code;
private String msg;
private Map<String,Object> extendInfo = new HashMap<String, Object>(); public int getCode() {
return code;
} public void setCode(int code) {
this.code = code;
} public String getMsg() {
return msg;
} public void setMsg(String msg) {
this.msg = msg;
} public Map<String, Object> getExtendInfo() {
return extendInfo;
} public void setExtendInfo(Map<String, Object> extendInfo) {
this.extendInfo = extendInfo;
} public static JsonMsg success(){
JsonMsg res = new JsonMsg();
res.setCode(100);
res.setMsg("操作成功");
return res;
} public static JsonMsg fail(){
JsonMsg res = new JsonMsg();
res.setCode(200);
res.setMsg("操作失败");
return res;
} public JsonMsg addInfo(String key,Object object){
this.extendInfo.put(key,object);
return this;
}
}
/**
* controller
* 判断用户名和密码是否正确
*/
  @RequestMapping(value = "/cch/dologin",method = RequestMethod.POST)
@ResponseBody
public JsonMsg dologin(HttpServletRequest request){
String username = request.getParameter("name");
String password = request.getParameter("pass");
System.out.println(username+" "+password);
if (!"name=admin".equals(username) || !"pass=123".equals(password)){
return JsonMsg.fail().addInfo("login_error","用户名或密码错误");
}
request.getSession().setAttribute("islogin","true");//如果正确,则在seesion里添加判断属性,可供拦截器判断是否登录过
return JsonMsg.success();
}
//自定义拦截器
//如果未登录则跳回登录页
public class SysInterceptor extends HandlerInterceptorAdapter {
/**
* 进入拦截器后首先进入的方法
* 返回false则不再继续执行
* 返回true则继续执行
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("我是拦截器:我进来了");
HttpSession session = request.getSession();
String islogin = (String)session.getAttribute("islogin");
if(islogin==null){
System.out.println("用户没有登录");
response.sendRedirect("/cch/login");
return false;
}
System.out.println("用户已登录");
return true;
} @Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } @Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { }
}
//把拦截器添加到springboot中

@Configuration
public class SessionConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
//拦截有 "/cch" 前缀的路径,除了 "/cch/login","/cch/dologin"
registry.addInterceptor(new SysInterceptor()).excludePathPatterns("/cch/login","/cch/dologin").addPathPatterns("/cch/**");
}
}

最新文章

  1. 【IDEA】intellij idea 插件推荐
  2. Manually enable Appear Offline in Lync 2013 Preview via Registry
  3. ZeroMQ实例-使用ZeroMQ进行windows与linux之间的通信
  4. FOJ2022车站 线段树区间合并
  5. 原 iOS面试题收集
  6. 使用PHP开发一个简单的后台接口(响应移动端的get请求和post请求)
  7. C#在与java对接时候的UrlEncode的坑
  8. BZOJ:1185: [HNOI2007]最小矩形覆盖
  9. Git运用基础之如何删除Github上不想要的项目
  10. wcf生成客户端代理类步骤及语句
  11. 百度地图API密钥
  12. pip 更改国内镜像
  13. jvm学习三:自定义ClassLoader
  14. 如何将OpenCV中的Mat类绑定为OpenGL中的纹理
  15. mysql定时执行某任务
  16. 【RF库XML测试】测试的XML文件说明
  17. 2_C语言中的数据类型 (二)进制
  18. 牛客红包OI赛 B 小可爱序列
  19. vs2013配置opencv3.2.0
  20. 微软Azure、谷歌GAE、亚马逊AWS比較

热门文章

  1. CSS单位计算总结
  2. SpiningUP 强化学习 中文文档
  3. 1..Net平台的背景
  4. OpenMP Programming
  5. VWware Workstation 安装CentOS系统
  6. jQuery万能放大镜插件(普通矩形放大镜)
  7. 深入解析Underscore.js源码架构
  8. ATOMac - 基于Python的Mac应用Ui自动化库
  9. 如何配置 GitHub 为个人的手机图床
  10. angular http 节流