**1. 依賴包**
```xml
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.1.2</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.1.2</version>
</dependency>
```
**2. 基本的word編寫**
```java
public void write01() throws IOException {
//創建word文檔對象
XWPFDocument docx = new XWPFDocument();
//創建段落
XWPFParagraph title = docx.createParagraph();
//設置段落水平居中
title.setAlignment(ParagraphAlignment.CENTER);
//創建段落文本
XWPFRun titleRun = title.createRun();
//字體顏色
titleRun.setColor("000000");
//字體大小
titleRun.setFontSize(25);
//字體名稱
titleRun.setFontFamily("仿宋");
//true字體加粗
titleRun.setBold(true);
//段落文本
titleRun.setText("主標題");
//換行
titleRun.addBreak();
//添加段落
XWPFParagraph firstTitle = docx.createParagraph();
firstTitle.setAlignment(ParagraphAlignment.LEFT);
XWPFRun firstTitleRun = firstTitle.createRun();
firstTitleRun.setColor("000000");
firstTitleRun.setFontSize(13);
firstTitleRun.setFontFamily("楷體");
firstTitleRun.setBold(true);
firstTitleRun.setText("1.1 秋天美景");
firstTitleRun.addBreak();
//添加段落
XWPFParagraph firstParagraph = docx.createParagraph();
firstParagraph.setAlignment(ParagraphAlignment.LEFT);
XWPFRun firstRun = firstTitle.createRun();
firstRun.setColor("000000");
firstRun.setFontSize(12);
firstRun.setFontFamily("楷體");
firstRun.setBold(false);
//縮進
firstRun.addTab();
firstRun.setText("金秋,天氣越來越冷,樹葉漸漸的變成黃色和紅色的了。蘋果樹長了很多蘋果。棗樹長了很多棗。許多的樹林都在金秋變成果園。");
firstRun.addBreak();
//縮進
firstRun.addTab();
firstRun.setText("秋風一閃,萬樹都會報以熱烈的掌聲和優美的舞姿,那個場面隆重盛大,不亞于盛大晚會的熱鬧場面,滿天飛舞著蝶一般的落葉。");
firstRun.addBreak();
//word文檔到磁盤
OutputStream out = new FileOutputStream("e:/upload/001.docx");
docx.write(out);
out.flush();
out.close();
docx.close();
}
```

- 跨域問題
- 跨域是什么
- 跨域解決方案
- 從后端解決
- nginx反向代理
- WebSocket
- websocket是什么
- websocket協議
- 使用場景
- 實現方式
- 注解與html5原生方式
- websocketAPI
- 實現步驟
- 文件上傳
- 文件下載
- 廣播通信
- 定時推送
- 編程與socketjs方式
- socketjs與stompjs框架
- 實現步驟
- 重載目的地
- SimpMessagingTemplate
- 定時向前端推送數據
- 5種監聽事件
- 點對點通信
- 攔截器
- HandshakeInterceptor
- ChannelInterceptor
- poi之excel表格
- 表格版本
- POI常用類
- POI依賴
- 寫表格
- 編寫表格過程
- 單元格邊框樣式
- 單元格背景色
- 凍結行或列
- 單元格合并
- 單元格內換行
- 文檔內跳轉
- 讀表格
- Web中的Excel操作
- 導出表格
- 讀取表格
- poi之word文檔
- word版本
- 寫word
- 基本使用
- 標題樣式
- 添加圖片
- EasyExcel表格
- EasyExcel是什么
- 與其他Excel工具對比
- EasyExcel依賴
- 讀Excel
- 簡單讀取
- 指定列位置
- 讀取多個sheet
- 格式轉換
- 多行表頭
- 同步讀
- 寫Excel
- 簡單寫入
- 單元格樣式
- 攔截器
- 列寬
- 凍結行或列
- 合并單元格
- 填充Excel
- SpringSecurity
- SpringSecurity是什么
- 同類型產品對比
- 環境搭建
- 相關概念
- 密碼加密
- Web權限控制
- UserDetailsService接口
- 登錄認證
- 自定義登錄頁
- 未授權跳轉登錄頁
- 權限控制
- 自定義403頁面
- 權限注解
- 記住我功能
- 注銷功能
- CSRF
- CSRF是什么
- CSRF保護演示
- 前后端分離權限控制
- 環境搭建
- 認證實現
- 會話管理
- 動態權限管理
- 微服務權限控制
- 權限控制方案
- SpringBoot整合RabbitMQ
- 整合步驟
- Fanout交換機演示
- Direct交換機演示
- Topic交換機演示
- @RabbitListener方法
- JWT認證與授權
- 環境搭建
- 密碼加密
- 認證與授權