美文网首页
2020-01-08 从零开始用Spring Boot开发一个个

2020-01-08 从零开始用Spring Boot开发一个个

作者: NoelleMu | 来源:发表于2020-01-09 02:03 被阅读0次

    写在前面

    自从服务器和域名备案完成后,我就一直在开发自己的个人网站,争取让它可以在年前上线。本来已经完成了一部分功能,但是这几天学了一些关于设计模式的知识、看了一些开源博客框架(WordPress和Typecho)的源码之后,我越来越觉得自己的功力不足,写出来的代码也是一团糟,数据库、包和服务之间的划分也没有特别清楚、明白。而最近那个微服务项目的开发也遇到了阻碍(不知道应该如何划分服务和功能,对各种功能的实现也没有很好的办法),于是决定重构一遍个人网站,顺便做一下记录。

    需求分析

    我们要开发一个系统,首先需要明确需求,这样才能更好地划分各个模块的功能。

    作为一个个人网站系统,用户角色主要有我和访客两种。下面就从这两个角色出发来分析一下我们的需求:

    访客

    • 访客可以在网站注册
    • 访客可以查看文章数量最多的10个标签
    • 访客可以查看文章数量最多的5个分类
    • 访客可以查看所有的标签
    • 访客可以查看所有的分类
    • 访客可以以分页的形式查看所有的文章
    • 访客可以在登录后对文章进行评论
    • 访客可以查看一篇文章的全部内容
    • 访客可以以模糊查询的方式搜索文章
    • 访客可以以时间分类的方式查看所有文章
    • 访客可以查看我全部的友情链接
    • 访客可以查看“关于我”页面

    • 我可以发布新文章
    • 我可以以Markdown的形式写文章、编辑文章
    • 我可以对文章内容进行修改
    • 我可以删除文章
    • 我可以编辑文章内容
    • 我可以给文章打标签
    • 我可以给文章做分类
    • 我可以查看所有已发布的文章
    • 我可以根据标签、分类、模糊查询来搜索文章
    • 我可以新增一个分类
    • 我可以删除已有的分类
    • 我可以修改一个分类
    • 我可以根据分类查询文章
    • 我可以新增一个标签
    • 我可以删除一个标签
    • 我可以修改一个标签
    • 我可以根据标签查询文章
    • 我可以添加友情链接
    • 我可以修改友情链接
    • 我可以删除友情链接
    • 我可以查询友情链接

    有了需求之后,就比较好规划出功能了。这里我用思维导图的形式来展示一下我们需要做的功能(图是用Xmind画的):

    接下来我们就可以开始开发了。

    首页的编写

    考虑到以前我一直是先开发后端,再开发前端,这种模式有一个比较大的缺点——不方便测试,也不好看到效果。所以我们这次先开发前端界面。

    UI框架的选择

    从开始做开发到现在,我也使用了很多框架,比如Element UIHuiLayUIBootStrapMDUI等。本来我使用的是Hui,但是最后我还是选择了Bootstrap来完成重构。理由嘛,当然是因为它比较成熟啦。版本选用的是3.3.7,因为4的文档还不是特别成熟。

    目录结构

    我们用WebStorm新建一个空工程。因为这个工程最后需要整合到Spring Boot中,所以我们按照Spring Boot规定的目录结构建立工程。这样虽然最后需要改动一些代码,但是目录结构就不需要再作出变动了。

    正式开始!

    先上效果:

    忽然产生了一种自己的审美又回来了的错觉

    背景图片是临时找的,到最后会换掉。

    因为三栏布局会显得文章一栏非常窄,而一栏布局又会让过多的内容被挤到页脚上去,所以采用了两栏布局,将文章数量最多的五个分类和文章数量最多的十个标签放在了右侧,文章列表和分页放在了左侧。友情链接和一些信息(如联系方式等)放在了页脚。

    由于不懂设计,也不会做原型设计,更不懂色彩搭配和用户体验,所以只能按照自己喜欢的样子来,因为我实在不喜欢类似于MDUI那种花里胡哨、阴影渐变一大片的,想让页面看起来干净点,所以采用了一点极简主义的思想,为此也是在自己的CSS里对Bootstrap进行了一番大刀阔斧的修改(见下面的代码)。

    HTML代码,因为很多东西都是造出来充数的,所以很长(315行)。最后与Thymeleaf结合套成模板之后应该会短一些:

    <!DOCTYPE html>
    <html lang="zh-CN">
    <head>
        <meta charset="UTF-8">
        <title>WenDev</title>
    
        <!-- Start Bootstrap -->
        <link href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
        <script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>
        <script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>
        <!-- End Bootstrap -->
    
        <link rel="stylesheet" href="../static/css/wen.css">
    </head>
    <body>
    <!-- Head -->
    <div class="header">
        <h1>江文|WenDev</h1>
        <h4>不想当切图仔的接口仔不是好架构师</h4>
    </div>
    
    <!-- Start Navigation Bar -->
    <nav class="navbar navbar-default" style="position: absolute; top: 0; width: 100%">
        <div class="container-fluid">
            <!-- Brand and toggle get grouped for better mobile display -->
            <div class="navbar-header">
                <a class="navbar-brand" href="/">江文 | WenDev</a>
            </div>
    
            <!-- NavBar Body -->
            <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
    
                <!-- Drop Down Menu -->
                <ul class="nav navbar-nav">
                    <li class="dropdown">
                        <a href="#" class="dropdown-toggle" data-toggle="dropdown"
                           role="button" aria-haspopup="true" aria-expanded="false">
                            Article
                            <span class="caret"></span>
                        </a>
                        <ul class="dropdown-menu">
                            <li>
                                <a href="#">
                                    <span class="glyphicon glyphicon-list"
                                          style="margin: 5px"></span>
                                    Category
                                </a>
                            </li>
                            <li>
                                <a href="#">
                                    <span class="glyphicon glyphicon-tags"
                                          style="margin: 5px"></span>
                                    Tags
                                </a>
                            </li>
                            <li>
                                <a href="#">
                                    <span class="glyphicon glyphicon-folder-open"
                                          style="margin: 5px"></span>
                                    Archive
                                </a>
                            </li>
    
                            <li role="separator" class="divider"></li>
                            <li>
                                <a href="#">
                                    <span class="glyphicon glyphicon-link"
                                          style="margin: 5px"></span>
                                    Friends
                                </a>
                            </li>
                        </ul>
                    </li>
                </ul>
                <!-- End Drop Down Menu -->
    
                <ul class="nav navbar-nav navbar-right">
                    <li><a href="#" class="dropdown-toggle">About Me</a></li>
                </ul>
    
                <!-- NavBar Search -->
                <form class="navbar-form navbar-right">
                    <div class="form-group">
                        <label for="nav-search"></label>
                        <input type="text" id="nav-search" class="form-control" placeholder="Search">
                    </div>
                    <a type="submit" class="btn btn-default">
                        Submit
                    </a>
                </form>
                <!-- End NavBar Search -->
            </div>
            <!-- End NavBar Body -->
        </div>
    </nav>
    <!-- End Navigation Bar -->
    <!-- End Head -->
    
    <!-- Content -->
    <div class="container-fluid">
        <!-- Body -->
        <div class="container-fluid">
            <div class="container-fluid">
                <!-- Margin-Left -->
                <div class="col-md-1" style="background-color: transparent; height: 200px;"></div>
                <!-- End Margin-Left -->
    
                <!-- Articles -->
                <div class="col-md-8">
                    <div class="article">
                        <div>
                            <h1>2019-12-15 Spring Cloud微服务从入门到入土(2)使用Nacos进行服务注册与发现</h1>
                        </div>
                        <div>
                            <p>启动Nacos
                                官网:https://nacos.io/zh-cn/
                                下载地址:https://github.com/alibaba/nacos/releases
                                解压后使用以下命令启动:
                                sh nacos/bin/startup.sh -m standalone
                                其中standalone表示以单机模式运行,具体可以参考文档。
                                启动后访问127.0.0.1:8848,默认用户名和密码都是nacos,登录后就可以看到Nacos控制台了。
                            </p>
                        </div>
                        <div class="article-info">
                            <span class="glyphicon glyphicon-calendar"></span>
                            <span class="info-content">2020-1-1</span>
                            <span class="glyphicon glyphicon-th-list"></span>
                            <span class="info-content">Spring Cloud</span>
                            <span class="glyphicon glyphicon-tag"></span>
                            <span class="info-content">Java</span>
                            <span class="glyphicon glyphicon-eye-open"></span>
                            <span class="info-content">300</span>
                        </div>
                        <div>
                            <a class="btn btn-default pull-right">Read More</a>
                        </div>
                    </div>
                </div>
                <!-- End Articles -->
    
                <!-- Content-Right -->
                <div class="col-md-2">
                    <!-- Top Categories -->
                    <div>
                        <h4 class="right-info">Top 5 categories</h4>
                        <ul class="list-group">
                            <li class="list-group-item">
                                <span class="glyphicon glyphicon-arrow-right"></span>
                                <a href="#">Cras justo odio</a>
                                <span class="badge">14</span>
                            </li>
                            <li class="list-group-item">
                                <span class="glyphicon glyphicon-arrow-right"></span>
                                <a href="#">Cras justo odio</a>
                                <span class="badge">14</span>
                            </li>
                            <li class="list-group-item">
                                <span class="glyphicon glyphicon-arrow-right"></span>
                                <a href="#">Cras justo odio</a>
                                <span class="badge">14</span>
                            </li>
                            <li class="list-group-item">
                                <span class="glyphicon glyphicon-arrow-right"></span>
                                <a href="#">Cras justo odio</a>
                                <span class="badge">14</span>
                            </li>
                            <li class="list-group-item">
                                <span class="glyphicon glyphicon-arrow-right"></span>
                                <a href="#">Cras justo odio</a>
                                <span class="badge">14</span>
                            </li>
                        </ul>
                    </div>
                    <!-- End top categories -->
                    <!-- Top Tags -->
                    <div>
                        <h4 class="right-info">Top 10 tags</h4>
                        <div>
                            <span class="label label-default">
                                <strong>Java</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>微服务</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>C语言</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>Java Web安全</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>CTF</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>Web后端</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>算法</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>Java</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>Java</strong>
                                <span>10</span>
                            </span>
                            <span class="label label-default">
                                <strong>Java</strong>
                                <span>10</span>
                            </span>
                        </div>
                    </div>
                    <!-- End Top Tags -->
                </div>
                <!-- End Content-Right -->
    
                <!-- Margin-Right -->
                <div class="col-md-1" style="background-color: transparent; height: 200px;"></div>
                <!-- End Margin-Right -->
            </div>
        </div>
        <!-- End Body -->
    
        <!-- Pagination -->
        <nav aria-label="Page navigation" class="col-md-offset-4 col-lg-offset-4col-xl-offset-4">
            <ul class="pagination">
                <li class="disabled">
                    <span>
                        <span aria-hidden="true">&laquo;</span>
                    </span>
                </li>
                <li class="active">
                    <span>1</span>
                </li>
                <li><a href="#">2</a></li>
                <li><a href="#">3</a></li>
                <li><a href="#">4</a></li>
                <li><a href="#">5</a></li>
                <li>
                    <a href="#" aria-label="Next">
                        <span aria-hidden="true">&raquo;</span>
                    </a>
                </li>
            </ul>
        </nav>
        <!-- End Pagination -->
    
        <!-- Footer -->
        <div class="footer" style="position: relative">
            <div class="container">
                <div class="row footer-top">
                    <div class="col-sm-3 col-lg-3">
                        <h4>Contact</h4>
                        <p><strong>QQ</strong> 1686799346</p>
                        <p><strong>WeChat</strong> CV10236516</p>
                        <p><strong>E-mail</strong> wendev1024@icloud.com</p>
                    </div>
                    <div class="col-sm-3 col-lg-3">
                        <h4>Friends</h4>
                        <strong class="friends"><a href="#">JiangWen</a></strong>
                        <strong class="friends"><a href="#">JiangWen</a></strong>
                        <strong class="friends"><a href="#">JiangWen</a></strong>
                        <strong class="friends"><a href="#">JiangWen</a></strong>
                    </div>
                    <div class="col-sm-6  col-lg-5 col-lg-offset-1">
                        <div class="row about">
                            <div class="col-xs-3">
                                <h4>About</h4>
                                <ul class="list-unstyled">
                                    <li>
                                        <a href="#">About Me</a>
                                    </li>
                                    <li>
                                        <a href="https://github.com/WenDev/WenDev-Web">Source Code</a>
                                    </li>
                                </ul>
                            </div>
                            <div class="col-xs-3">
                                <h4>Other</h4>
                                <ul class="list-unstyled">
                                    <li>
                                        <a href="https://www.jianshu.com/u/dc63550214af">简书</a>
                                    </li>
                                    <li>
                                        <a href="https://github.com/WenDev">GitHub</a>
                                    </li>
                                </ul>
                            </div>
                        </div>
    
                    </div>
                </div>
                <hr>
                <div class="row footer-bottom">
                    <ul class="list-inline text-center">
                        <li>Powered by
                            <a href="https://spring.io/projects/spring-boot">Spring Boot</a>
                            Design/Developed by
                            <a href="http://wendev.site">江文</a>
                            &copy;2020 江文(WenDev)
                        </li>
                    </ul>
                </div>
            </div>
        </div>
        <!-- End Footer -->
    </div>
    <!-- End Content -->
    </body>
    </html>
    
    

    相应的CSS:

    /* 去除NavBar的背景颜色和边框颜色,达到极简主义的效果 */
    .navbar-default {
        background: none !important;
        border: none !important;
    }
    
    body {
        font-family: varela round, Arial, sans-serif;
    }
    
    h4 {
        font-weight: bolder;
    }
    
    .form-control:focus {
        border-color: #8b0000 !important;
        outline: 0;
        -webkit-box-shadow: none !important;
        box-shadow: none !important;
    }
    
    .navbar-default .navbar-brand {
        color: #8b0000 !important;
    }
    
    .navbar-default .navbar-brand:hover,
    .navbar-default .navbar-brand:focus {
        color: #000000 !important;
        background-color: transparent;
    }
    
    a {
        color: darkred;
        text-decoration: none;
    }
    
    a:hover,
    a:focus {
        color: black;
        text-decoration: underline;
    }
    
    .article {
        border-bottom: 1px solid #DDDDDD;
        padding: 10px 30px 50px 30px;
        margin: 10px 50px 10px 0;
    }
    
    .footer {
        margin-top: 50px;
    }
    
    .pagination > .active > a,
    .pagination > .active > a:focus,
    .pagination > .active > a:hover,
    .pagination > .active > span,
    .pagination > .active > span:focus,
    .pagination > .active > span:hover {
        background-color: darkred;
        border-color: darkred;
    }
    
    .pagination > li > a,
    .pagination > li > span {
        color: black;
    }
    
    .list-group {
        border-radius: 0;
        border-bottom: 1px solid #DDDDDD;
    }
    
    .list-group-item {
        border: none
    }
    
    li.list-group-item a {
        color: black;
    }
    
    span.label-default {
        font-size: 1.5rem;
        display: inline-block;
        margin: 5px;
        padding: 5px 6px;
    }
    
    .label-default {
        border: 1px solid #DDDDDD;
        background-color: transparent;
        color: #666666;
        font-weight: unset;
    }
    
    span.label-default strong {
        color: black;
    }
    
    div.article a.btn-default {
        border: none;
        color: white;
        background-color: darkred;
    }
    
    div.article a.btn-default:active {
        color: white;
        background-color: #5b0000;
    }
    
    div.article span.info-content {
        margin-right: 20px;
    }
    
    div.article span.glyphicon,
    div.article span.info-content {
        color: #666666;
    }
    
    div.article h1 {
        line-height: 5rem;
    }
    
    div.article p {
        margin-top: 20px;
        color: #666666;
    }
    
    .article-info {
        margin-top: 30px;
    }
    
    .right-info {
        margin-top: 40px;
    }
    
    .friends {
        margin-right: 7px;
    }
    
    .header {
        background: #EEE url(../../static/img/34844544_p0.jpg) no-repeat 0 -60px;
        background-size: 100% auto;
        height: 500px;
        top: 0;
        width: 100%;
        display: flex;
        z-index: -100;
        align-items: center;
        justify-content: center;
        flex-direction: column;
    }
    
    nav.navbar-default a.dropdown-toggle {
        color: white !important;
    }
    
    div.header h1 {
        color: white;
        font-size: 6rem;
    }
    
    div.header h4 {
        color: white;
    }
    
    

    对Bootstrap原有的样式进行了一番大刀阔斧的修改之后,终于满意了。

    首页写好了,接下来就应该开始写其他的页面了。

    相关文章

      网友评论

          本文标题:2020-01-08 从零开始用Spring Boot开发一个个

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