首页 > 其他分享 >Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三

时间:2023-08-05 23:32:40浏览次数:47  
标签:wiki 10 -- Spring oss process 文档 image

文档内容的显示:

在上一次Spring Boot&Vue3前后端分离实战wiki知识库系统<十>--文档管理功能开发二文档管理模块还差文档的显示木有完成,所以接下来先将这块模块给收尾了。

增加单独获取内容的接口:

概述:

在前端页面文档查询时,只查询了文档的基本信息,其中文档的富文本内容是木有带出来的:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_02

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_03

当然也不可能在列表中把富文本的内容给查出来,因为这是大文本,在列表中带出它来会占用我们的带宽流量,且影响数据库性能,在查看文档时才会去加载文档的富文本的内容, 所以此时我们需要增加一个查文档内容的接口了。

实现:

这个接口的定义比较简单,贴出来如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_04

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_05

前端获得html字符串后显示在富文本框中:

接下来咱们就可以调用查询文档内容的接口将保存的文档内容显示在富文本框中了。

1、发起接口请求:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_06

接下来咱们则在点击编辑时调用它:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_07

2、运行:

接下来咱们运行看一下效果:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_08

内容成功展示。

3、bug修复:

接下来演示一个bug:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_09

也就是之有回显的富文本的内容,在点击新增时没有清空,所以咱们处理一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_10

再运行就正常了。

文档页面功能开发:

概述:

文档的编辑功能已经开发好了之后,接下来则需要让读者可以进行文档的阅读了,所以接下来会开发如下两个功能,一个是在编辑时增加一个文档的预览功能:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_11

点击它之后,则会弹出预览界面:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_12

另外一个功能就是在首页中点击某一门电子书可以进到对应的文档查看界面,具体交互如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_13

增加文档页面:

首先咱们来实现点击首页的电子书能跳到一个文档页面,也就是:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_14

1、新建文档页面:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_15

里面的内容先弄个文本占个位:

<template>
  <a-layout>
    <a-layout-content
        :style="{ background: '#fff', padding: '24px', margin: 0, minHeight: '280px' }"
    >
    </a-layout-content>
    <div class="doc">
      <h1>欢迎来到文档页面</h1>
    </div>
  </a-layout>
</template>

2、配置页面路由:

此时则需要回到这块进行路由的配置:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_16

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_17

3、修改电子书的跳转:

接下来在点击电子书时跳转到该文档页面:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_18

将它改为:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_19

4、运行:

此时运行看一下效果:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_20

呃,欢迎的提示语位置不太对:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_21

布局写错了,改一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_22

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_23

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_24

左边显示文档树:

概述:

接下来则来构建这个文档页面的细节了,先来将所有的文档树显示在左侧,效果如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_25

下面则来具体实现一下。

实现:

1、将内容划分为左右区域:

内容左右划分这块在之前已经用过了,使用它:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_26

所以修改如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_27

此时预览效果:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_28

 

2、左侧显示文档树:

接下来将文档树显示在左侧的菜单中,这个其实效果跟文档管理差不多:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_29

只不过这里就木有对于文档树的编辑操作了,所以,逻辑可以参考文档管理的,先来将文档树形菜单的查询逻辑拷过来,这块就不过多说明了:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_30

这里采用ant design vue的一个新组件:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_31

然后其中level1则是文档的树形结构的数据,整个代码如下:

<template>
  <a-layout>
    <a-layout-content
        :style="{ background: '#fff', padding: '24px', margin: 0, minHeight: '280px' }"
    >
      <a-row>
        <a-col :span="6">
          <a-tree
              v-if="level1.length > 0"
              :tree-data="level1"
              :replaceFields="{title: 'name', key: 'id', value: 'id'}"
              :defaultExpandAll="true"
          >
          </a-tree>
        </a-col>
        <a-col :span="18">
          <div>右侧内容</div>
        </a-col>
      </a-row>
    </a-layout-content>
  </a-layout>
</template>
<script lang="ts">
import {defineComponent, onMounted, ref} from 'vue';
import axios from 'axios';
import {message} from 'ant-design-vue';
import {Tool} from "@/util/tool";

export default defineComponent({
  name: 'Doc',
  setup() {
    const docs = ref();

    /**
     * 一级文档树,children属性就是二级文档
     * [{
     *   id: "",
     *   name: "",
     *   children: [{
     *     id: "",
     *     name: "",
     *   }]
     * }]
     */
    const level1 = ref(); // 一级文档树,children属性就是二级文档
    level1.value = [];

    /**
     * 数据查询
     **/
    const handleQuery = () => {
      axios.get("/doc/all/").then((response) => {
        const data = response.data;
        if (data.success) {
          docs.value = data.content;

          level1.value = [];
          level1.value = Tool.array2Tree(docs.value, 0);
        } else {
          message.error(data.message);
        }
      });
    };

    onMounted(() => {
      handleQuery();
    });

    return {
      level1,
    }
  }
});
</script>

运行看一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_32

修复文档数据不是按某个电子书查询的bug:

概述:

对于这个文档树形菜单的功能显示其实是有问题的,先拿之前文档管理的页面来说:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_33

有木有发现每次查看某个电子书下的文档管理,其左侧文档树显示得都是一模一样的,很明显是不对的,其原因也很简单,是因为目前咱们对于文档树的查询就是每次查所有:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_34

应该查询只能查出某个电子书下的文档才行,所以对于文档查看页面也存在同样的问题,所以接下来咱们先来修复这些的一个Bug。 

修复:

1、后台接口修改:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_35

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_36

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_37

2、前端页面修改:

此时在前端页面上在发起此接口请求时就需要加上一个电子书id了,如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_38

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_39

3、运行:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_40

右边显示第一个节点的内容:

接下来咱们接着文档的内容显示继续编写,现在左侧的文档树已经显示出来了,接下来则需要在点击某个文档时,在右侧能够显示出该文档的内容。

1、右侧定义显示div:

当点击左侧的文档树时,则需要将该文档的html显示在右侧的区域,这里其实就是一个纯html的显示,所以定义一个div:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_41

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_42

其中这个html是一个响应式的变量:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_43

2、点击文档菜单查询html数据:

首先处理文档菜单的点击事件:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_44

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_45

此时咱们运行看一下效果:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_46

3、bug修复:

接下来咱们来演示一个Bug,为了看到这个Bug,咱们先来编辑一个带引用标题的文档:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_47

此时保存一下,然后再到首页查看一下此电子书下的这篇新编辑的文档,你会发现,带引号的样式木有了:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_48

这是为啥呢? 其实是由于我们所引用的wangEditor没有定义它默认的样式,关于这块可以上官网了解到:https://www.wangeditor.com/v4/pages/02-%E5%86%85%E5%AE%B9%E5%A4%84%E7%90%86/03-%E8%8E%B7%E5%8F%96html.html

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_49

言外之意就是说我们获取的html是不带样式的,要想有样式则可以使用官方提供的默认样式,咱们就按着官网的要求引入这么一个样式:

<style>
  /* wangeditor默认样式, 参照: http://www.wangeditor.com/doc/pages/02-%E5%86%85%E5%AE%B9%E5%A4%84%E7%90%86/03-%E8%8E%B7%E5%8F%96html.html */
  /* table 样式 */
  .wangeditor table {
    border-top: 1px solid #ccc;
    border-left: 1px solid #ccc;
  }

  .wangeditor table td,
  .wangeditor table th {
    border-bottom: 1px solid #ccc;
    border-right: 1px solid #ccc;
    padding: 3px 5px;
  }

  .wangeditor table th {
    border-bottom: 2px solid #ccc;
    text-align: center;
  }

  /* blockquote 样式 */
  .wangeditor blockquote {
    display: block;
    border-left: 8px solid #d0e5f2;
    padding: 5px 10px;
    margin: 10px 0;
    line-height: 1.4;
    font-size: 100%;
    background-color: #f1f1f1;
  }

  /* code 样式 */
  .wangeditor code {
    display: inline-block;
    *display: inline;
    *zoom: 1;
    background-color: #f1f1f1;
    border-radius: 3px;
    padding: 3px 5px;
    margin: 0 3px;
  }

  .wangeditor pre code {
    display: block;
  }

  /* ul ol 样式 */
  .wangeditor ul, ol {
    margin: 10px 0 10px 20px;
  }
</style>

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_50

其中咱们需要给文档显示的标签增加一个class:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_51

此时运行再看一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_52

这是为啥呢?经过元素调试,可以发现:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_53

如果把margin-top:0这个样式给勾选掉貌似样式就正常了:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_54

这里咱们单独针对这个再重新定义一个更好看一点的样式,如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_55

再运行一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_56

功能优化:

接下来做一些功能上的优化。 

文档编辑页面增加内容预览:

1、文档编辑增加预览入口:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_57

其中定义一个点击事件:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_58

运行一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_59

 

2、点击展现抽屉效果:

接下来则需要处理“内容预览”的点击事件了,这里需要用到一个从右侧弹出来的抽屉效果的组件,如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_60

这效果也是比较常见的了:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_61

其中看一下它的基本使用:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_html_62

比较简单,下面咱们直接在文档管理页面中来定义一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_63

所以接下来定义这两个响应式的变量:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_64

然后在handlePreviewContent中这样处理:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_65

然后再处理一下关闭抽屉时的处理:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_66

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_67

此时运行看一下效果:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_68

知识点:样式scoped的作用

还记得在之前我们对于带标题栏样式是特意在这块进行了声明才解决样式不对的问题么?回忆一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_69

那问题来了,很明显我们没有在文档管理页面对wangeditor的样式进行定义呀:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_文档管理_70

那么为何在文档管理的“内容预览”看到的富文本的样式都没问题呢?这里就牵扯到一个样式生效范围的知识点了,回看一下在文档页面定义的wangeditor的样式:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_71

既然有全局样式,当然也有只限当前页面使用的非全局样式了,比如:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_72

打开文档页面时,默认选中第一个节点:

接下来再来优化一个细节,应该算是一个bug,这里先来演示一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_73

也就是查看某一个电子书下的文档时,得手动点击一下才能在右边看到文档的内容,这很明显是不合理的,应该默认选中第一个文档并将它的内容给展示出来,所以下面解决如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_74

在a-tree组件中,有一个默认选中的属性,它是一个数组,可以存在默认选中多个,不过我们这只支持默认选中一个,接下来定义一下这个响应式的变量:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_75

在查询文档树时,默认需要给这个响应式的变量设置成第一个文档,所以在查询这块需要处理一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_76

运行:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_77

增加无文档的提示:

接下来再来优化一个细节,先来演示一下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_78

可以看到,该电子书下木有任何文档数据,此时界面上没有任何提示,显示一片空白,用户体验不太好,接下来咱们针对这种情况来加一个提示,比较简单,在顶层上加一个标签既可:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_79

运行:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_80

修复文档管理新增报电子书为空的异常:

最后再来演示一个bug:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_81

这是为啥呢?其实是因为目前在点击文档管理页面对于电子书的id的初始化是需要在点击新增时才触发:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_springboot_82

而在定义doc时并未对电子书进行初始化:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_83

修复它的办法当然就是进这个编辑页面时就来初始化这个ebookId既可,如下:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_富文本_84

此时再运行:

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_85

结语:

本来还想开启下一个模块【用户管理&单点登录】的学习,发现目前篇幅已经不短了,所以下次再继续,这次其实没啥新的技术点,都是一些小细节的优化之类的,但是往往细节决定成败,所以也不容忽视,当然这里面只是粗略地优化了,还有很多问题,木关系,先按照节奏整体实现一遍,重点是操练Java后台的编码技能。





关注个人公众号,获得实时推送

Spring Boot&Vue3前后端分离实战wiki知识库系统<十一>--文档管理功能开发三_vue_86



标签:wiki,10,--,Spring,oss,process,文档,image
From: https://blog.51cto.com/u_15456329/6979079

相关文章

  • 【软考备战·四月模考】希赛网四月模考软件设计师上午题
    题目及解析来源:2023上半年软考-模考大赛一、成绩报告二、错题总结第一题解析:相联存储器的工作原理就是根据中央处理单元给出的一个相联关键字,然后据此完成后续的读取工作,所以相联存储器均是按关键字进行检索的。第二题解析:A项,海明码是一种利用奇偶性来检错和纠错的校验方法,A正......
  • Springboot中怎么选择性使用thymeleaf进行渲染?
    SpringBoot默认支持多种模板引擎,包括Thymeleaf。如果你想选择性地使用Thymeleaf进行渲染,这基本上取决于你的Controller的实现。以下是一个基本示例:首先,确保你的SpringBoot项目已经添加了Thymeleaf的依赖。在你的pom.xml文件中,你应该看到类似以下的内容<dependency>......
  • C语言分支与循环(18) --- 编写一个关机程序
    一.编写一个程序,要求程序运行后电脑一分钟内自动关机,若用户输入:no则取消关机示例代码:#define_CRT_SECURE_NO_WARNINGS1#include<stdio.h>#include<windows.h>intmain(void){ printf("您的电脑将在一分钟内关机,若需要取消关机请输入no\n"); system("shutdown-s-t60");R......
  • 【无需格式化硬盘即可C盘扩容以及新建磁盘】
    (无需格式化硬盘即可C盘扩容以及新建磁盘)简介DiskGenius是一款硬盘分区及数据恢复软件。它是在最初的DOS版的基础上开发而成的,Windows版本的DiskGenius软件,除了继承并增强了DOS版的大部分功能外,还增加了许多新的功能。如:已删除文件恢复、分区复制、分区备份、硬盘复制等功能。......
  • 讨厌的百度网盘,nas下载困难,傻人傻办法
    特定的使用环境需要用到百度网盘的视频分享给家人看。在尝试过很多办法:1、alist挂载,可以挂载,但是条件苛刻太难了。 挂载条件,想看视频起码得是会员,还不一定保证可用。 2、挂载cloud,与百度无缘! 3、傻人傻办法,装上win10 挂远程桌面 虚拟机下挂nas目录 设置下载到......
  • C++_函数模板
    函数模板》是不进行编译的,因为类型还不知道模板的实例化》函数调用点进行实例化:在函数调用点,编译器用用户指定的类型,从原模板实例化一份函数代码出来模板函数》才是要被编译器所编译的模板类型参数typename/class模板非类型参数模板的实参推演》可以根据用户传......
  • 关于jQuery的attr给input赋值遇到遇到的问题
    前段时间因为公司有个下拉框的需求(固定前几列不动,后面几个可以话滑动的多选下拉框)由于在网上找了几次插件发现都不满足,于是决定开始手写一个下拉多选   html部分:1<divclass="input-group">2<divstyle="position:relative;">3......
  • R语言随机搜索变量选择SSVS估计贝叶斯向量自回归(BVAR)模型|附代码数据
    原文链接:http://tecdat.cn/?p=9390原文出处:拓端数据部落公众号 最近我们被客户要求撰写关于贝叶斯向量自回归(BVAR)的研究报告,包括一些图形和统计输出。介绍向量自回归(VAR)模型的一般缺点是,估计系数的数量与滞后的数量成比例地增加。因此,随着滞后次数的增加,每个参数可用的信息......
  • 机器学习框架的基本组成
    编程接口:一般用Python作为给用户的接口,主要原因就是简单易用、生态好;计算图:计算图定义了用户的机器学习程序,比如有哪些op、有哪些输入、输入长什么样、计算序列如何等,对于不同的编译器后端,有时候需要用IR来做优化,在mlsys中计算图就相当于是IR;编译器前端:前端的工作主要......
  • Exercise: rot13Reader
    rot13是英文字母加密里面CaesarCipher(其实就是移位加密)的一种特殊形式,简单来说就是把字母前后部分对调,其中a和n对调,以此类推。针对性的简单来做就是直接判断字母所在范围,然后视情况+/-13即可。但是rot13也可以用CaesarCipher的通用形式来做,移位的公式其实很简单,见下面代码中rot1......