美文网首页Java学习笔记
项目维护小计-小知识点汇总

项目维护小计-小知识点汇总

作者: 风穆雷 | 来源:发表于2017-07-09 22:49 被阅读34次

    本篇记录项目维护过程中印象稍微深一些的点,算是一些知识点,有新发现,也有常规错误,略微记之。

    ajax跨域保留session

    Controller可使用@CrossOrigin注解允许跨域。默认情况下,浏览器ajax跨域请求不会保留session,即每一次请求都是一个新的session。保留session的方法如下:

    $.ajax(url, {
                type: "POST",
                data: data
                xhrFields: {
                    withCredentials: true
                },
                crossDomain: true
            })
    

    这不是一个彻底的解决方案,如果频繁的按照上述方式进行跨域请求,浏览器会报错。本项目中跨域且保留session本身就是为满足某个奇葩需求而妥协的解决方案,最好还是避免这种做法。

    jstl

    vue、angularJS的表达式某些思想、形式类似于jstl,但是重新拿起jstl还是有很大的痛苦。

    拼接构建字符串

    字符串变量是可以多次set的,每一次set与前一个值拼接即可

    <c:set var="str" value="''"/>
    <c:set var="str" value="${str}'a'"/>
    <c:set var="str" value="'${str}'b"/>
    <c:set var="str" value="'${str}'c"/>
    ${str} //str='abc'
    

    遍历对象属性

    以下示例读取对象obj的属性,并且拼接到objStr字符串中:

    <c:forEach var="field" items="${obj['class'].declaredFields}" varStatus="stat">
            <c:if test="${not empty obj[field.name]}">
                <c:set var="objStr"
                       value="${stat.first ? '' :objStr}&${field.name}=${obj[field.name]}"/>
            </c:if>
        </c:forEach>
    

    这种方式对处理pojo很有效,复杂的对象还存在隐患。

    jsp分页,轮子造起来

    无论字段命名多么别扭吧,分页对象这样了:

    public class PageDO implements Serializable {
        private int currentPage = 1;//当前页码   默认为1
        private int pageCount = 10;//每页显示数据条数    默认为10
        private int totalCount = 0;//总条数
        private int totalPage = 0;//总页数
        private int startIndex = 0;//开始条数
        private List<Integer> pages;
        ...省略get set
    }
    

    分页的代码单独放到一个jsp文件中,作为一个通用组件存在。分页基本信息为页面大小与页号,其他参数通过 condition 对象传入,conditionExt可以传入额外的查询条件,具体实现如下:

    <div id="pageGro" class="cb">
        <c:forEach var="field" items="${condition['class'].declaredFields}" varStatus="stat">
            <c:if test="${not empty condition[field.name]}">
                <c:set var="conditionStr"
                       value="${stat.first ? '' :conditionStr}&${field.name}=${condition[field.name]}"/>
            </c:if>
        </c:forEach>
        <c:if test="${page.currentPage !=1}">
            <div class="pageUp"><a disabled="true"
                                   href="?${conditionExt}${conditionStr}&currentPage=${page.currentPage-1}&pageCount=${page.pageCount}">上一页</a>
            </div>
        </c:if>
        <div class="pageList">
            <ul>
                <c:forEach items="${page.pages}" var="item">
                    <li>
                        <c:if test="${item == page.currentPage}">
                            ${item}
                        </c:if>
                        <c:if test="${item != page.currentPage}">
                            <a href="?${conditionExt}${conditionStr}&currentPage=${item}&pageCount=${page.pageCount}">${item}</a>
                        </c:if>
                    </li>
                </c:forEach>
            </ul>
        </div>
        <c:if test="${page.currentPage < page.totalPage}">
            <div class="pageDown">
                <a href="?${conditionExt}${conditionStr}&currentPage=${page.currentPage+1}&pageCount=${page.pageCount}">下一页 </a>
            </div>
        </c:if>
    </div>
    

    tomcat启动参数

    tomcat的启动参数可在 tomcat-path/bin/catalina.shtomcat-path/bin/satrtup.sh中配置(window配置相应的bat文件)。
    在文件第一行加入配置即可,如下示例在windows上配置启动参数 :

    set  "JAVA_OPTS=%JAVA_OPTS% -Dspring.profiles.active=test"
    

    增加启动内存也可以通过这种方式配置。

    编码问题

    使用UTF-8编码基本上已经成为开发共识,但是ide、tomcat却没有这样去默认UTF-8,这是乱码问题的根源之一。

    url乱码

    tomcat默认没有开启url的UTF-8编码,需在配置tomcat-path/conf/server.xml文件中配置:

    <Connector port="8080" protocol="HTTP/1.1"
                   connectionTimeout="20000"
                   URIEncoding="UTF-8"
                   redirectPort="8443" />
    

    日志文件乱码

    日志文件会出现中文乱码,需要在tomcat启动参数加编码配置:

    set  "JAVA_OPTS=%JAVA_OPTS% -Dfile.encoding=utf-8"
    

    结语

    本篇随笔记录了几个维护过程中用到的小“技巧”,也有些称不上技巧是因为实在是一些古老而又基础的东西,在学新技能的时候给忽略乃至遗忘了。

    相关文章

      网友评论

        本文标题:项目维护小计-小知识点汇总

        本文链接:https://www.haomeiwen.com/subject/ilyehxtx.html