ssm实战------用户模块

Posted lemonades

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ssm实战------用户模块相关的知识,希望对你有一定的参考价值。

功能:

 

用户登录

用户名验证

用户注册

忘记密码: 获取问题

提交问题答案:

重置密码

获取用户信息

更新用户信息

退出登录:删除session

 

门户接口(11个):

          1登录;2注册;3检验用户名是否有效;4获取登录用户的信息;5忘记密码;6提交问题答案;7忘记密码的重设置密码;8登录状态重置密码;

          9登录状态更新用户信息;10获取当前登录用户的详情信息,并强制登录;11退出登录

 

1 SQL查询不要使用 “  select *  ”,需要哪个字段查那个

2 返回用户对象时,记得将用户密码设置为空

 

学习目标:

 

横向越权、纵向越权安全漏洞

MD5明文加密及增加salt值:一个MD5加密小工具的使用

        //MD5加密
        user.setPassword(MD5Util.MD5EncodeUtf8(user.getPassword()));

 

     工具类:

package com.eshop.util;

import org.springframework.util.StringUtils;

import java.security.MessageDigest;

/**
 * Created by geely
 */
public class MD5Util 

    private static String byteArrayToHexString(byte b[]) 
        StringBuffer resultSb = new StringBuffer();
        for (int i = 0; i < b.length; i++) 
            resultSb.append(byteToHexString(b[i]));
        

        return resultSb.toString();
    

    private static String byteToHexString(byte b) 
        int n = b;
        if (n < 0) 
            n += 256;
        
        int d1 = n / 16;
        int d2 = n % 16;
        return hexDigits[d1] + hexDigits[d2];
    

    /**
     * 返回大写MD5
     *
     * @param origin
     * @param charsetname
     * @return
     */
    private static String MD5Encode(String origin, String charsetname) 
        String resultString = null;
        try 
            resultString = new String(origin);
            MessageDigest md = MessageDigest.getInstance("MD5");
            if (charsetname == null || "".equals(charsetname)) 
                resultString = byteArrayToHexString(md.digest(resultString.getBytes()));
             else 
                resultString = byteArrayToHexString(md.digest(resultString.getBytes(charsetname)));
            
         catch (Exception exception) 
        
        return resultString.toUpperCase();
    

    public static String MD5EncodeUtf8(String origin) 
        //origin = origin + PropertiesUtil.getProperty("password.salt", "");
        return MD5Encode(origin, "utf-8");
    


    private static final String hexDigits[] = "0", "1", "2", "3", "4", "5",
            "6", "7", "8", "9", "a", "b", "c", "d", "e", "f";


 

 

guava缓存的使用:

    UUID生成随机字符串:

            //使用UUID生成一个随机字符串,当做token储存起来
            String forgetToken= UUID.randomUUID().toString();
            //创建token类保存token
            TokenCache.setKey("token"+username,forgetToken);
            return ServerResponce.createBySuccess(forgetToken);

 

     token类:

package com.eshop.common;

import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader;
import com.google.common.cache.LoadingCache;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.concurrent.TimeUnit;

public class TokenCache 
    //声明日志
    private static Logger logger=LoggerFactory.getLogger(TokenCache.class);

    //.initialCapacity(1000):设置初始化的容量; maximumSize(1000):当超过3000时,会使用LRU算法对缓存进行清理
    //expireAfterAccess(12, TimeUnit.HOURS):缓存的有效期是12个小时
    private static LoadingCache<String,String> localCache= CacheBuilder.newBuilder().initialCapacity(1000).maximumSize(3000).expireAfterAccess(12, TimeUnit.HOURS)
            .build(new CacheLoader<String, String>() 
                //默认的加载实现,当调用get方法时,找不到对应的token,就会加载这个方法
                @Override
                public String load(String s) throws Exception 
                    //为了不必要的空指针异常,返回一个字符串的 “null”
                    return "null";
                
            );

    public static void setKey(String key,String value)
        /*保存key*/
        localCache.put(key,value);
    
    public static String getKey(String key)
        String value=null;
        try 
            value = localCache.get(key);
            if(value.equals("null"))
                return null;
            
            return value;
        catch (Exception e)
            logger.error("localCache get error",e);
        
        return null;
    

 

 

可复用服务响应对象的设计:一个消息响应对象

session的使用

 

以上是关于ssm实战------用户模块的主要内容,如果未能解决你的问题,请参考以下文章

ssm实战-----支付模块开发,订单模块

SpringMVC学习记录----SSM 框架实战 用户信息增删改查

Java SSM 项目实战 day05 用户操作

Java SSM 项目实战 day05 用户操作

Java SSM 项目实战 day07用户角色关联操作,添加角色,以及添加权限

毕业设计-基于SSM框架大学教务管理平台项目开发实战教程(附源码)