RBAC项目记录

新建项目

新建maven开始项目的时候,会报错,因为没有webxml.
项目右击-properties,projectfac--,先取消 dynamic。。。,apply然后重新点上


image.png

然后下面



点击设置路径
image.png

一、乱码问题

  1. post乱码
  • 1.1. 直接转换(麻烦,每个都要转换)
1. String loginacct = user.getLoginacct();
       // 将乱码字符串按照错误的编码方式转换为原始的字节码序列
       // byte[] bs = loginacct.getBytes("ISO8859-1");

       // 将原始的字节码序列按照正确的编码转换为正确的文字即可。
       // loginacct = new String(bs, "UTF-8");
  • 1.2. 添加过滤器(一劳永逸)
<!-- 解决乱码问题 -->
     <filter>
        <filter-name>encoding</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
        </init-param>
        <init-param>
            <param-name>forceEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
    </filter>
    
    <filter-mapping>
        <filter-name>encoding</filter-name>
        <servlet-name>springmvc</servlet-name>
    </filter-mapping>
  1. get 乱码
    tomcat服务器 server。xml
<Connector URIEndoding="UTF-8" connectionTime....

二. 利用 layer.jst 提示功能

login.jsp

<!-- 使用 layer提示功能 -->
    <script src="layer/layer.js"></script>


if(loginacct == ""){
            //alert("用户名为空");
            <!-- 使用 layer提示功能 -->
            layer.msg("用户登录账号不能为空,请输入", {time:2000, icon:5, shift:6}, function(){
                
            });
            return;
        }
        var userpswd = $("#userpswd").val();//loginacct 是 上面的id,唯一标识
        // 表单 value 值不会为null,所以非空校验不能简单的 判断 !=null,而是用空字符串 “”
        if(userpswd == ""){
            //alert("密码为空");
            <!-- 使用 layer提示功能 -->
            layer.msg("用户登录密码不能为空,请输入", {time:2000, icon:5, shift:6}, function(){
                
            });
            return;
        }

三. 错误回显(因为ajax线程都没有刷新,所以错误信息还在)

 // 提交表单
        //alert("提交表单");
        //$("#loginForm").submit();
        // 使用AJAX提交数据
        var loadingIndex = null;
        $.ajax({
            type : "POST",
            url  : "doAJAXLogin",
            data : {
                "loginacct" : loginacct,
                "userpswd"  : userpswd
            },
            beforeSend : function(){
                loadingIndex = layer.msg('处理中', {icon: 16});
            },
            success : function(result) {
                // 成功了就关闭loadin效果
                layer.close(loadingIndex);
                // 对象.属性
                if (result.success) {
                    // 登录成功,跳转到主页面
                    window.location.href = "main";
                } else {
                    layer.msg("用户登录账号或密码不正确,请重新输入", {time:2000, icon:5, shift:6}, function(){
                        
                    });
                }
            }
        });
        

DIspatchContrller

   /**
    * 使用 ajax 解决回显和闪烁
    * @param user
    * @param session
    * @return
    */
   @ResponseBody // 对象无法在网路中传递,转换成字符串
   @RequestMapping("/doAJAXLogin")
   public Object doAJAXLogin(User user, HttpSession session) {
       
       AJAXResult result = new AJAXResult();
       
       User dbUser = userService.query4login(user);
       if ( dbUser != null ) {
           result.setSuccess(true);
       } else {
           result.setSuccess(false);
       }
       
       return result;
   }
   /**
    * 主页面
    * @return
    */
   @RequestMapping("/main")
   public String main() {
       return "main";
   }
   

封装 AJAXResult结果,方便调用

package com.lsy.crowdfunding.bean;

public class AJAXResult {

    private boolean success;
    private Object data;

    public boolean isSuccess() {
        return success;
    }

    public void setSuccess(boolean success) {
        this.success = success;
    }

    public Object getData() {
        return data;
    }

    public void setData(Object data) {
        this.data = data;
    }
    
}

至此,解决了页面美化提示,用户错误信息不刷新(方便看用户名错没错),跳转没有黑屏三个问题

四、理解 JSON、

<script>
    // JSON : JavaScript Object Notation
    function Student() {
        //this.sname = "zhangsan";
        //this.age = 20;
    }
    
    // JS支持给对象动态添加属性
    var s = new Student();
    s.sname = "lisi";
    
    var s1 = new Student();
    
    
    // 声明JSON对象
    var obj = {name:"lisi", age:20};
    var array = [{}, {}];
    //obj.name = "zhangsan";
    
    //alert(array.length);
    // JSON 字符串 : 将后台对象按照JSON格式转换为字符串输出到浏览器中,让JS当成对象来处理
    
    
    
    
</script>

五、js资源等路径问题

绝对路径:不可改变的路径
    本地绝对路径:增加盘符的路径(e:/test/test.html)
    网络绝对路径:增加协议,IP地址,端口号的路径(http://localhost:8080/test/test.html)
相对路径:可以改变的路径,但是以基准路径为参考,查找其他路径
    默认情况下,相对路径的基准路径是以当前资源的访问路径为基准

路径以斜杠开头,表示的特殊的相对路径,在不同的场景中,相对的位置会发生变化。

    url : http://localhost:8080/atcrowdfunding-web/test/test.html

    前台路径:<a href=”/sssss”><img src=””>
        相对服务器的根 : http://localhost:8080/sssss
    后台路径:forward(”/user.jsp”), xml
        相对web应用的根:http://localhost:8080/atcrowdfunding-web/user.jsp

使用监听器来解决路径

直接的方法:获取项目的名称路径,在资源前加上
pageContext.request.contextPath

在项目启动时候,用户使用之前,利用监听器获取到路径APP_PATH,然后放在资源签
第一步:新建监听器类

package com.lsy.atcrowdfunding.web;

import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

public class ServerStartupListener implements ServletContextListener {

    public void contextInitialized(ServletContextEvent sce) {
        // web 应用初始化时候会被监听到
        System.out.println("// web 应用初始化时候会被监听到");
        // 将web应用名称(路径)保存到application范围中
        ServletContext application = sce.getServletContext();
        String path = application.getContextPath();
        application.setAttribute("APP_PATH", path);
    }

    public void contextDestroyed(ServletContextEvent sce) {
        // TODO Auto-generated method stub

    }
}

第二步:在 web.xml中注册监听器

<!--  使用自定义监听器 -->
    <listener>
        <listener-class>com.lsy.atcrowdfunding.web.ServerStartupListener</listener-class>
    </listener>

第三步:在页面引入 APP_PATH(监听器自己命名的,可以随意修改,建议)

    <link rel="stylesheet" href="${APP_PATH}/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="${APP_PATH}/css/font-awesome.min.css">
    <link rel="stylesheet" href="${APP_PATH}/css/main.css">
...
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,585评论 18 139
  • Spring Web MVC Spring Web MVC 是包含在 Spring 框架中的 Web 框架,建立于...
    Hsinwong阅读 22,300评论 1 92
  • 书名:零秒工作(100%) 作者:[日] 赤羽雄二 001凡事探究真相,不断询问直到建立起自己的理解 不经过自己思...
    视觉笔记找文莹阅读 285评论 0 3
  • Single is simple,double is trouble. (单身简单,相爱麻烦) 国庆期间,身边朋友...
    白羽墨画阅读 476评论 0 0
  • 想起昨晚的梦,以及梦中的情景,忍不住哭了。而且越哭越伤心,哭声把女儿引了过来。 她好奇地问我哭什么...
    回首明月阅读 225评论 0 1