12-显示登录信息

显示登录信息

根据用户的登录状态,显示不同的内容(注册,登录/首页,头像等)
每个静态页面中都有这个信息,都要做同样的处理,但很麻烦,耦合度太高,利用Spring的拦截器解决这个问题:
能够拦截浏览器访问过来的请求,或多个请求,然后,在开始或结束的部分插入代码,从而解决共用的业务实现。

属于表现层的逻辑,放在concroller中:

  • 拦截器示例
    • 定义拦截器,实现Handlerlnterceptor
      编写AlphaInterceptor
package com.nowcoder.community.controller.interceptor;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//让Spring容器去管理
@Component
public class AlphaInterceptor implements HandlerInterceptor {

    private static final Logger logger = LoggerFactory.getLogger(AlphaInterceptor.class);

    // 在Controller之前执行
    //HttpServletRequest request, HttpServletResponse response可处理自己的请求
    //Object handler是拦截的目标
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        logger.debug("preHandle: " + handler.toString());
        return true;
    }

    // 在Controller之后执行
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        logger.debug("postHandle: " + handler.toString());
    }

    // 在TemplateEngine之后执行
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        logger.debug("afterCompletion: " + handler.toString());
    }
}

}

这里注意,在没有实现完所有方法以前,@Overrite会报错,其他出错情况可参考: https://blog.csdn.net/lenfranky/article/details/95878017?spm=1001.2101.3001.6661.1&utm_medium=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1-95878017-blog-111601453.pc_relevant_default&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1-95878017-blog-111601453.pc_relevant_default&utm_relevant_index=1

  • 配置拦截器,为它指定拦截、排除的路径
    在config里面创建配置类:
package com.nowcoder.community.config;

import com.nowcoder.community.controller.interceptor.AlphaInterceptor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
//要求实现一个接口,而不是简单实现一个配置类
    @Autowired//将拦截器配置并注入进来
    private AlphaInterceptor alphaInterceptor;

//    @Autowired
//    private LoginTicketInterceptor loginTicketInterceptor;
//
//    @Autowired
//    private LoginRequiredInterceptor loginRequiredInterceptor;

    @Override//添加拦截器,注册
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(alphaInterceptor)
                .excludePathPatterns("/**/*.css", "/**/*.js", "/**/*.png", "/**/*.jpg", "/**/*.jpeg")//(静态资源访问释放)
                .addPathPatterns("/register", "/login");//(拦截注册和登录的功能)设置拦截器的拦截路径,如果不设置,所有文件都会被拦截
        // "/**"所有目录下的css文件:localhost:8080/community/css(**),域名和项目名不需要设置

}

如果想要查看效果,看断点即可
在这里插入图片描述

  • 拦截器应用
    浏览器存cookie, 发送给服务器,得到凭证ticket,关联用户,得到当前用户是谁,(查询login_ticket表)得到用户id,得到用户,运用在模板上显示,(放在model里),最终模板向浏览器响应,携带html;
    在这里插入图片描述
    这套流程用拦截器处理
    先编写获取cookie的工具类
    在这里插入图片描述
    写工具类
package com.nowcoder.community.util;

import com.nowcoder.community.entity.User;
import org.springframework.stereotype.Component;

/**
 * 持有用户信息,用于代替session对象.
 * 浏览器访问服务器是多对一的多线程的情况,不能简单存入一个变量bean,要考虑线程的隔离
 * 起到一个容器作用
 */
@Component
public class HostHolder {

    private ThreadLocal<User> users = new ThreadLocal<>();
    //ThreadLocal实现线程隔离

    public void setUser(User user) {
        users.set(user);
    }

    public User getUser() {
        return users.get();
    }

    public void clear() {//用完需要清理,不然会造成堆积
        users.remove();
    }

}

在这里插入图片描述
登陆拦截器
LoginTicketInterceptor

  • 在请求开始时查询登录用户

  • 在本次请求中持有用户数据

  • 在模板视图上显示用户数据

  • 在请求结束时清理用户数据

package com.nowcoder.community.controller.interceptor;

import com.nowcoder.community.entity.LoginTicket;
import com.nowcoder.community.entity.User;
import com.nowcoder.community.service.UserService;
import com.nowcoder.community.util.CookieUtil;
import com.nowcoder.community.util.HostHolder;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.Date;

@Component
public class LoginTicketInterceptor implements HandlerInterceptor {

    @Autowired
    private UserService userService;

    @Autowired
    private HostHolder hostHolder;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 从cookie中获取凭证,一开始就找到当前用户,以便后续使用(在登录状态下才能获取)
        String ticket = CookieUtil.getValue(request, "ticket");

        if (ticket != null) {
            // 查询凭证
            LoginTicket loginTicket = userService.findLoginTicket(ticket);
            // 检查凭证是否有效,因为凭证有状态及过期时间
            if (loginTicket != null && loginTicket.getStatus() == 0 && loginTicket.getExpired().after(new Date())) {//超时时间晚于当前时间
                // 根据凭证查询用户
                User user = userService.findUserById(loginTicket.getUserId());
                // 在本次请求中持有用户
                //浏览器访问服务器是多对一的多线程的情况,不能简单存入一个变量bean,要考虑线程的隔离
                //处理请求的过程中,线程是一直都在的
                hostHolder.setUser(user);
            }
        }

        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        User user = hostHolder.getUser();
        if (user != null && modelAndView != null) {
            modelAndView.addObject("loginUser", user);//模板调用之前,将html传入modeland view
        }
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        hostHolder.clear();//返回模板后
    }
}

配置类中的设置

package com.nowcoder.community.config;

import com.nowcoder.community.controller.interceptor.AlphaInterceptor;
import com.nowcoder.community.controller.interceptor.LoginTicketInterceptor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
//要求实现一个接口,而不是简单实现一个配置类
    @Autowired//将拦截器配置并注入进来
    private AlphaInterceptor alphaInterceptor;

    @Autowired
    private LoginTicketInterceptor loginTicketInterceptor;
//
//    @Autowired
//    private LoginRequiredInterceptor loginRequiredInterceptor;

    @Override//添加拦截器,注册
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(alphaInterceptor)
                .excludePathPatterns("/**/*.css", "/**/*.js", "/**/*.png", "/**/*.jpg", "/**/*.jpeg")//(静态资源访问释放)
                .addPathPatterns("/register", "/login");//(拦截注册和登录的功能)设置拦截器的拦截路径,如果不设置,所有文件都会被拦截
        // "/**"所有目录下的css文件:localhost:8080/community/css(**),域名和项目名不需要设置

        registry.addInterceptor(loginTicketInterceptor)
                .excludePathPatterns("/**/*.css", "/**/*.js", "/**/*.png", "/**/*.jpg", "/**/*.jpeg");

//        registry.addInterceptor(loginRequiredInterceptor)
//                .excludePathPatterns("/**/*.css", "/**/*.js", "/**/*.png", "/**/*.jpg", "/**/*.jpeg");
    }

}

改写index.html对应的部分

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML、CSS和JavaScript可以配合使用实现登录注册功能。其中,HTML负责页面结构和内容,CSS负责页面样式,JavaScript负责页面交互和逻辑。一般情况下,登录注册需要与后端进行交互,以便验证用户输入的信息是否正确。 在HTML中,可以使用form标签来创建表单,通过input标签创建输入框等元素,使用户可以输入信息。在CSS中,可以对表单进行样式设置,美化表单的外观。在JavaScript中,可以通过获取表单元素的值,进行信息的校验和提交等操作。 为了显示文件后缀名,可以使用JavaScript来获取上传文件的文件名,并从中提取出文件后缀名。具体实现方法可以参考以下代码: ```html <!DOCTYPE html> <html> <head> <title>Login/Register</title> <style> /* CSS 样式 */ input[type="text"], input[type="password"] { width: 100%; padding: 12px 20px; margin: 8px 0; display: inline-block; border: 1px solid #ccc; box-sizing: border-box; } input[type="submit"] { background-color: #4CAF50; color: white; padding: 14px 20px; margin: 8px 0; border: none; cursor: pointer; } input[type="submit"]:hover { background-color: #45a049; } </style> </head> <body> <h1>Login/Register</h1> <form action="#" method="post"> <label for="username">Username:</label><br> <input type="text" id="username" name="username" required><br> <label for="password">Password:</label><br> <input type="password" id="password" name="password" required><br> <label for="avatar">Avatar:</label><br> <input type="file" id="avatar" name="avatar" onchange="showFileName()"><br> <input type="submit" value="Submit"> </form> <script> // JavaScript 代码 function showFileName() { var fileInput = document.getElementById("avatar"); var fileName = fileInput.value.split("\\").pop(); // 获取文件名并去除路径 var fileExt = fileName.split(".").pop(); // 获取文件后缀名 alert("File name: " + fileName + ", File extension: " + fileExt); } </script> </body> </html> ``` 以上代码实现了一个简单的登录注册页面,并提供了一个上传头像的功能。在上传头像时,通过JavaScript获取文件名并从中提取出文件后缀名,并通过alert函数显示出来。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值