本文原創地址,jsbintask的博客(食用效果最佳),轉載請註明出處!php
分享一個SSM的實戰項目,一個使用springmvc
,mybatis
,jequery
,bootstrap
,ueditor
打造的論壇系統,主要包含論壇主體,後臺管理兩個部分。 git地址以下:
github.com/jsbintask22…html
該系統主要使用服務端主要使用spring,mybatis進行搭建,前端主要爲bootstrap,jquery編寫的jsp頁面,而且集成百度ueditor進行富文本編輯,功能實現,技術點以下: 用戶註冊
:用戶如若要進行發帖,回帖等操做,必須先註冊帳號。註冊帳號使用郵箱進行註冊(郵件發送),使用ajax驗證郵箱,用戶名惟一性。 用戶登陸
: 用戶登陸需輸入驗證碼,驗證碼爲請求登錄頁面時後臺生成圖片,記錄到session中。 權限驗證
:系統中某些行爲必須進行登錄方可操做,因此必須提供贊成權限驗證,此係統主要使用攔截器(Interceptor)進行用戶的權限驗證。 用戶發帖
:已登錄的用戶能夠進行發帖,回帖。提供直接圖片,文件上傳功能,此處前端使用UEDITOR配合後端文件上傳實現。 用戶回帖
:用戶能夠回覆某一帖子,而且能夠引用。因此此處設計數據庫設計 樹狀結構的表設計。 帖子收藏
:用戶能夠收藏喜歡的帖子,而且在我的中心中找到。 用戶關注
:用戶能夠關注其餘用戶。 我的信息
:用戶能夠查看我的信息,修改維護我的信息,而且設置頭像。 帖子管理
:後臺主要功能爲對帖子進行維護,能夠及時刪除,恢復已經存在的帖子。前端
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.jsbintask</groupId>
<artifactId>jsbintask-bbs</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<name>jsbintask-bbs Maven Webapp</name>
<url>http://jsbintask.cn</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<maven.compiler.encoding>UTF-8</maven.compiler.encoding>
<org.springframework.version>4.3.10.RELEASE</org.springframework.version>
<org.mybatis.version>3.4.1</org.mybatis.version>
<org.mybatis.spring.version>1.3.0</org.mybatis.spring.version>
</properties>
<developers>
<developer>
<email>jsbintask@gmail.com</email>
<name>jsbintask</name>
<url>https://jsbintask.cn</url>
<roles>
<role>developer</role>
</roles>
</developer>
</developers>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.tomcat/tomcat-servlet-api -->
<dependency>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-servlet-api</artifactId>
<scope>provided</scope>
<version>8.5.11</version>
</dependency>
<!--spring-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${org.springframework.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-oxm</artifactId>
<version>${org.springframework.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${org.springframework.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>${org.springframework.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${org.springframework.version}</version>
</dependency>
<!-- hibernate驗證jar-->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>4.2.0.Final</version>
</dependency>
<!--aop實現-->
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.7.3</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>1.6.11</version>
</dependency>
<!--mybatisjar-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>${org.mybatis.spring.version}</version>
</dependency>
<!-- https://mvnrepository.com/artifact/jstl/jstl -->
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>${org.mybatis.version}</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.7.4</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.7.4</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.13</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.7.4</version>
</dependency>
<dependency>
<groupId>commons-dbcp</groupId>
<artifactId>commons-dbcp</artifactId>
<version>1.4</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
<!-- https://mvnrepository.com/artifact/log4j/log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.0.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.2.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.baidu</groupId>
<artifactId>ueditor-mini</artifactId>
<version>1.0</version>
<scope>system</scope>
<systemPath>${project.basedir}/lib/ueditor-mini.jar</systemPath>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-fileupload/commons-fileupload -->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>com.sun.mail</groupId>
<artifactId>javax.mail</artifactId>
<version>1.6.2</version>
</dependency>
</dependencies>
<build>
<finalName>jsbintask-bbs</finalName>
<pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
<plugins>
<plugin>
<artifactId>maven-clean-plugin</artifactId>
<version>3.1.0</version>
</plugin>
<!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->
<plugin>
<artifactId>maven-resources-plugin</artifactId>
<version>3.0.2</version>
</plugin>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.0</version>
</plugin>
<plugin>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.22.1</version>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>3.2.2</version>
</plugin>
<plugin>
<artifactId>maven-install-plugin</artifactId>
<version>2.5.2</version>
</plugin>
<plugin>
<artifactId>maven-deploy-plugin</artifactId>
<version>2.8.2</version>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
複製代碼
此處值得注意的是,因爲百度ueditor未在中央倉庫中提供相關jar文件,因此此處爲引用本地jar(見項目結構)java
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" version="3.1">
<display-name>bbs</display-name>
<!--配置一個首頁-->
<welcome-file-list>
<welcome-file>/WEB-INF/jsp/article/index.html</welcome-file>
</welcome-file-list>
<!--配置一個參數-->
<context-param>
<param-name>path</param-name>
<param-value>E:/WorkSpaces/Idea workspace/jsbintask-bbs/bbs_imgs/heads</param-value>
</context-param>
<context-param>
<param-name>pageSize</param-name>
<param-value>10</param-value>
</context-param>
<!-- 配置監聽器,啓動全部配置文件 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:config/spring/applicationContext-*.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 配置過濾器防止亂碼 -->
<filter>
<filter-name>CharacterEncodingFilter</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>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!--配置一個servlet,攔截全部的請求 -->
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:config/spring/springmvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--配置一個首頁-->
<!--<servlet-mapping> <servlet-name>SpringMVC</servlet-name> <url-pattern>/topic/all</url-pattern> </servlet-mapping>-->
<!--配置一個404的頁面 -->
<error-page>
<error-code>404</error-code>
<location>/WEB-INF/jsp/article/404.htm</location>
</error-page>
<error-page>
<error-code>500</error-code>
<location>/WEB-INF/jsp/article/404.htm</location>
</error-page>
</web-app>
複製代碼
此處值得注意的是,咱們配置了一個<context-param>
參數,主要用於定義用戶上傳頭像的文件夾mysql
/* Navicat Premium Data Transfer Source Server : company_localhsot_root Source Server Type : MySQL Source Server Version : 50724 Source Host : localhost:3306 Source Schema : acm_bbs Target Server Type : MySQL Target Server Version : 50724 File Encoding : 65001 Date: 15/01/2019 09:41:14 */
CREATE DATABASE /*!32312 IF NOT EXISTS*/`jsbintask_bbs` /*!40100 DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci */;
USE `jsbintask_bbs`;
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for admin
-- ----------------------------
DROP TABLE IF EXISTS `admin`;
CREATE TABLE `admin` (
`id` int NOT NULL,
`account` varchar(15) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`password` varchar(15) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of admin
-- ----------------------------
INSERT INTO `admin` VALUES (1, 'admin', '123456');
-- ----------------------------
-- Table structure for article
-- ----------------------------
DROP TABLE IF EXISTS `article`;
CREATE TABLE `article` (
`id` int NOT NULL AUTO_INCREMENT,
`topic_id` int NOT NULL COMMENT '主題帖的id',
`content` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '回覆的內容',
`reply_time` datetime NOT NULL COMMENT '回覆的時間',
`user_id` int NOT NULL COMMENT 'userid爲該帖子是誰發的',
`puser_id` int NULL DEFAULT NULL COMMENT '被回覆的人的id, 只有當該帖子是引用別人的纔有',
`arefid` int NULL DEFAULT NULL COMMENT '若是該條帖子爲引用別人的話,則不爲空,而且顯示被引用的回覆的id',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 44 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of article
-- ----------------------------
INSERT INTO `article` VALUES (1, 1, '<p>test</p>', '2017-06-10 10:59:54', 2, 1, NULL);
INSERT INTO `article` VALUES (2, 1, '<p>test</p>', '2017-06-10 11:00:55', 1, 2, 1);
INSERT INTO `article` VALUES (3, 2, '<p>test</p>', '2017-06-28 11:02:24', 3, 2, NULL);
INSERT INTO `article` VALUES (4, 1, '<p>在此寫上您的回帖<img src=\"http://img.baidu.com/hi/jx2/j_0002.gif\"/></p>', '2017-06-13 14:36:22', 1, 1, NULL);
INSERT INTO `article` VALUES (5, 1, '<p>在此寫上您的回帖</p>', '2017-06-13 14:38:01', 1, 1, NULL);
INSERT INTO `article` VALUES (6, 1, '<p>在此寫上您的回帖</p>', '2017-06-13 14:49:32', 1, 1, NULL);
INSERT INTO `article` VALUES (7, 1, '<p>在此寫上您的回帖sfgsd</p>', '2017-06-13 14:50:57', 1, 1, NULL);
INSERT INTO `article` VALUES (8, 1, '<p>在此寫上您的回帖hhh</p>', '2017-06-13 14:54:55', 1, 1, NULL);
INSERT INTO `article` VALUES (9, 1, '<p>在此寫上您的回帖</p>', '2017-06-13 14:58:54', 5, 1, 8);
INSERT INTO `article` VALUES (10, 1, '<p>這是個人回帖<img src=\"http://localhost:8080/umeditor/jsp/upload/20170613/64251497359650753.png\" style=\"width: 652.4px; height: 164.4px;\"/><img src=\"http://img.baidu.com/hi/tsj/t_0003.gif\"/></p>', '2017-06-13 21:14:55', 1, 1, NULL);
INSERT INTO `article` VALUES (11, 2, '<p>在此寫上您的回帖<img src=\"http://img.baidu.com/hi/face/i_f18.gif\"/></p>', '2017-06-15 10:27:50', 1, 1, NULL);
INSERT INTO `article` VALUES (12, 6, '<p>在此寫上您的回帖<img src=\"http://img.baidu.com/hi/face/i_f14.gif\"/></p>', '2017-06-15 10:45:26', 1, 1, NULL);
INSERT INTO `article` VALUES (13, 6, '<p>在此寫上您的回帖<img src=\"http://img.baidu.com/hi/jx2/j_0026.gif\"/></p>', '2017-06-15 10:45:58', 1, 1, NULL);
INSERT INTO `article` VALUES (14, 5, '<p>在此寫上您的回帖<img src=\"http://img.baidu.com/hi/jx2/j_0014.gif\"/></p>', '2017-06-15 10:48:36', 1, 1, NULL);
INSERT INTO `article` VALUES (15, 1, '<p>在此寫上您的回帖<img src=\"http://img.baidu.com/hi/bobo/B_0015.gif\"/><img src=\"http://localhost:8080/umeditor/jsp/upload/20170615/85481497500764167.png\"/></p>', '2017-06-15 12:26:06', 1, 1, NULL);
INSERT INTO `article` VALUES (16, 5, '<p style=\"text-align: left;\">在此寫上您的回帖<img src=\"http://img.baidu.com/hi/jx2/j_0002.gif\"/><img src=\"http://localhost:8080/umeditor/jsp/upload/20170616/26781497600431431.png\"/><span class=\"mathquill-embedded-latex\" style=\"width: 24px; height: 33px;\">x^{ }</span></p>', '2017-06-16 16:08:38', 1, 1, NULL);
INSERT INTO `article` VALUES (17, 1, '<p>你們早上好,明天就考試了呢!<img src=\"http://img.baidu.com/hi/bobo/B_0006.gif\"/></p>', '2017-06-18 09:40:12', 5, 1, 15);
INSERT INTO `article` VALUES (18, 6, '<p>test</p>', '2017-06-18 10:15:23', 1, 1, 13);
INSERT INTO `article` VALUES (19, 6, '<p> Hello</p>', '2017-06-18 10:19:54', 1, 1, NULL);
INSERT INTO `article` VALUES (20, 6, '<p>你好啊,一樓</p>', '2017-06-18 11:00:49', 1, 1, 12);
INSERT INTO `article` VALUES (21, 6, '<p>在此寫上您的回帖<img src=\"http://img.baidu.com/hi/face/i_f29.gif\"/></p>', '2017-06-18 11:08:59', 1, 1, 20);
INSERT INTO `article` VALUES (22, 3, '<p>在此寫上您的回帖<img src=\"http://img.baidu.com/hi/jx2/j_0069.gif\"/></p>', '2017-06-18 12:08:38', 3, 3, NULL);
INSERT INTO `article` VALUES (23, 1, ' Hello<img src=\"http://img.baidu.com/hi/jx2/j_0013.gif\"/><p><br/></p>', '2017-06-18 17:04:22', 1, 2, 1);
INSERT INTO `article` VALUES (24, 1, '<p><img src=\"http://localhost:8080/umeditor/jsp/upload/20170618/21841497776701354.png\" style=\"width: 448.4px; height: 213.4px;\"/></p><p>這個不錯</p>', '2017-06-18 17:05:42', 1, 1, NULL);
INSERT INTO `article` VALUES (25, 5, '。。。。<img src=\"http://localhost:8080/umeditor/jsp/upload/20170618/98751497778168424.jpg\" width=\"886\" height=\"435\"/><p><br/></p>', '2017-06-18 17:29:36', 1, 1, NULL);
INSERT INTO `article` VALUES (26, 5, '<img src=\"http://localhost:8080/umeditor/jsp/upload/20170618/40371497778647806.png\"/><p><br/></p>', '2017-06-18 17:37:29', 1, 1, NULL);
INSERT INTO `article` VALUES (27, 5, '<p> <br/></p><p></p>', '2017-06-18 17:44:06', 1, 1, NULL);
INSERT INTO `article` VALUES (28, 10, '<img src=\"http://img.baidu.com/hi/jx2/j_0067.gif\"/><p>大家好</p><p><img src=\"http://localhost:8080/umeditor/jsp/upload/20170620/81441497953824484.png\"/></p><p></p>', '2017-06-20 18:17:08', 9, 9, NULL);
INSERT INTO `article` VALUES (29, 10, '<p>sssssss<br/></p>', '2017-06-20 18:17:50', 9, 9, 28);
INSERT INTO `article` VALUES (30, 10, 'hhhh<img src=\"http://img.baidu.com/hi/jx2/j_0058.gif\"/><p><img src=\"http://localhost:8080/umeditor/jsp/upload/20170621/75931498030185101.png\"/></p>', '2017-06-21 15:29:48', 10, 9, NULL);
INSERT INTO `article` VALUES (31, 6, 'sfsfds<img src=\"http://img.baidu.com/hi/jx2/j_0025.gif\"/><p><br/></p>', '2017-06-21 15:30:19', 10, 1, 19);
INSERT INTO `article` VALUES (32, 12, '<img src=\"http://www.yc5301.cn:8888/umeditor/jsp/upload/20170806/12401501981604981.jpg\"/><p><br/></p>', '2017-08-06 09:06:51', 11, 11, NULL);
INSERT INTO `article` VALUES (33, 12, '<p>test</p>', '2017-08-06 09:07:11', 11, 11, NULL);
INSERT INTO `article` VALUES (34, 12, '<p>test</p>', '2017-08-06 09:07:28', 11, 11, 33);
INSERT INTO `article` VALUES (35, 12, '<img src=\"http://img.baidu.com/hi/jx2/j_0069.gif\"/><p><br/></p>', '2017-08-06 09:37:27', 1, 11, NULL);
INSERT INTO `article` VALUES (36, 12, '<p>test</p>', '2017-08-06 10:05:57', 13, 11, NULL);
INSERT INTO `article` VALUES (37, 12, '<p>test</p>', '2017-08-06 10:06:56', 13, 11, NULL);
INSERT INTO `article` VALUES (38, 12, '<p>test</p>', '2017-08-06 10:07:19', 13, 11, NULL);
INSERT INTO `article` VALUES (39, 12, '<p><img src=\"http://img.baidu.com/hi/jx2/j_0002.gif\"/></p><p><img src=\"http://www.yc5301.cn:8888/umeditor/jsp/upload/20170823/14321503478764152.png\"/></p><p>gsdgsdg</p><p>sdgksdmg</p><p>fdhdf</p>', '2017-08-23 17:00:14', 1, 11, NULL);
INSERT INTO `article` VALUES (40, 12, 'sdfsdf<img src=\"http://img.baidu.com/hi/jx2/j_0037.gif\"/><p><br/></p>', '2017-10-17 19:17:25', 1, 11, NULL);
INSERT INTO `article` VALUES (41, 10, 'sfads<img src=\"http://img.baidu.com/hi/ldw/w_0015.gif\"/><p><img src=\"http://www.yc5301.cn:8888/umeditor/jsp/upload/20171018/56581508337015800.jpg\"/></p>', '2017-10-18 22:30:19', 1, 10, 30);
INSERT INTO `article` VALUES (42, 1, '<img src=\"http://img.baidu.com/hi/jx2/j_0003.gif\"/><p><br/></p>', '2017-10-30 08:36:53', 1, 1, NULL);
INSERT INTO `article` VALUES (43, 12, 'dsv<img src=\"http://img.baidu.com/hi/bobo/B_0026.gif\"/><p><br/></p>', '2017-12-03 15:41:18', 1, 11, NULL);
-- ----------------------------
-- Table structure for attention
-- ----------------------------
DROP TABLE IF EXISTS `attention`;
CREATE TABLE `attention` (
`user_id` int NOT NULL COMMENT '關注的用戶的id',
`puser_id` int NOT NULL COMMENT '被關注的用戶的id',
`create_time` datetime NULL DEFAULT NULL,
PRIMARY KEY (`user_id`, `puser_id`) USING BTREE,
INDEX `attention_id_pid`(`user_id`, `puser_id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of attention
-- ----------------------------
INSERT INTO `attention` VALUES (1, 3, '2017-06-21 12:05:50');
INSERT INTO `attention` VALUES (1, 9, '2017-06-21 15:33:55');
-- ----------------------------
-- Table structure for collect
-- ----------------------------
DROP TABLE IF EXISTS `collect`;
CREATE TABLE `collect` (
`user_id` int NOT NULL COMMENT '用戶id',
`topic_id` int NOT NULL COMMENT '帖子id',
`create_time` datetime NULL DEFAULT NULL,
PRIMARY KEY (`user_id`, `topic_id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of collect
-- ----------------------------
INSERT INTO `collect` VALUES (1, 1, '2017-06-30 17:00:21');
INSERT INTO `collect` VALUES (1, 3, '2017-06-23 17:00:30');
INSERT INTO `collect` VALUES (1, 9, '2017-06-18 17:06:04');
INSERT INTO `collect` VALUES (4, 2, '2017-06-01 17:00:49');
INSERT INTO `collect` VALUES (8, 1, '2017-06-01 17:00:39');
-- ----------------------------
-- Table structure for topic
-- ----------------------------
DROP TABLE IF EXISTS `topic`;
CREATE TABLE `topic` (
`id` int NOT NULL AUTO_INCREMENT COMMENT '帖子id',
`user_id` int NOT NULL COMMENT '發帖人的id',
`reply_number` int(5) NULL DEFAULT 0 COMMENT '回覆的數量',
`topic` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '帖子主題',
`content` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '帖子的內容',
`create_time` datetime NOT NULL COMMENT '發帖的時間',
`flag` int(1) NOT NULL DEFAULT 1 COMMENT '帖子的狀態,1表示正常,0表示已被刪除',
`isindex` int(1) NULL DEFAULT 0 COMMENT '精品帖子,1表示精品,0表示默認',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 14 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of topic
-- ----------------------------
INSERT INTO `topic` VALUES (1, 1, 14, '騎士得到總冠軍', '2017騎士逆轉勇士得到總冠軍', '2017-06-10 10:57:49', 1, 1);
INSERT INTO `topic` VALUES (2, 1, 1, 'Spring最新源碼解析', '深刻解析Spring源碼及原理', '2017-06-01 10:58:58', 1, 1);
INSERT INTO `topic` VALUES (3, 3, 1, '無話可說', '哈哈', '2017-06-01 12:07:06', 1, 0);
INSERT INTO `topic` VALUES (4, 1, 0, 'saf', '<p>在此寫上您的回帖<img src=\"http://localhost:8080/umeditor/jsp/upload/20170612/39591497268654983.png\"/><img src=\"http://img.baidu.com/hi/jx2/j_0002.gif\"/></p>', '2017-06-12 19:57:39', 1, 0);
INSERT INTO `topic` VALUES (5, 1, 5, 'Spring徹底源碼解析之AOP', '<p style=\"text-align: left;\">詳情請參考個人博客!<img src=\"http://img.baidu.com/hi/bobo/B_0003.gif\"/></p><p style=\"text-align: left;\"><img src=\"http://localhost:8080/umeditor/jsp/upload/20170613/1301497339765182.png\"/></p>', '2017-06-13 15:42:48', 1, 1);
INSERT INTO `topic` VALUES (6, 1, 7, '這是一條測試帖子', '<p style=\"text-align: center;\">Hello from jsbintask@gmail.com。<img src=\"http://img.baidu.com/hi/babycat/C_0016.gif\"/></p>', '2017-06-13 21:16:07', 1, 1);
INSERT INTO `topic` VALUES (7, 1, 0, 'safds', '<p style=\"text-align: center;\">在此寫上您的回帖<img src=\"http://img.baidu.com/hi/jx2/j_0058.gif\"/></p>', '2017-06-15 12:26:59', 1, 0);
INSERT INTO `topic` VALUES (8, 5, 0, 'Mybatis3.0後的一個小Bug', '<p>加入po中有一個名字是屬於符合屬性的,mybatis會按照反射機制,先把屬性都轉化爲小寫,而後找到對應的get和set方法,所以打字方法找不到!<img src=\"http://img.baidu.com/hi/jx2/j_0070.gif\"/></p>', '2017-06-18 09:42:18', 1, 0);
INSERT INTO `topic` VALUES (9, 8, 0, 'Hello,歡迎大家', '<p>在此寫上您的內容<img src=\"http://img.baidu.com/hi/jx2/j_0068.gif\"/></p>', '2017-06-18 14:08:31', 1, 0);
INSERT INTO `topic` VALUES (10, 9, 4, 'Hello,jsbintask', '<p><img src=\"http://img.baidu.com/hi/jx2/j_0060.gif\"/>, <img src=\"http://localhost:8080/umeditor/jsp/upload/20170620/71161497953710481.jpg\" width=\"405\" height=\"391\"/></p>', '2017-06-20 18:15:24', 1, 0);
INSERT INTO `topic` VALUES (11, 1, 0, 'safsf', '<p>在此寫上您的內容<img src=\"http://img.baidu.com/hi/jx2/j_0047.gif\"/></p>', '2017-06-21 15:31:07', 0, 0);
INSERT INTO `topic` VALUES (12, 11, 10, '《鬼谷子-捭闔策》', '<p>《鬼谷子</p><p>捭闔第一</p><p>【題解:《易·繫辭上》:「是故闔戶謂之坤,闢戶謂之乾」。捭:開。闔,閉。經過對本文的理解發現,捭闔不只僅是遊說的一種方法,更重要是捭闔已是一種世界觀、哲學觀(捭闔者,天地之道。捭闔者,以變更陰陽,四時開閉,以化萬物,縱橫反出、反覆反忤,必由此矣。)。】</p><p>粵若稽古,聖人之在天地間也,爲衆生之先。觀陰陽之開闔以名命物,知存亡之門戶,籌策萬類之終始,達人心之理,見變化之朕焉,而守司其門戶。故聖人之在天下也,自古及今,其道一也。【第一句以聖人立論,古人寫做慣用手法,如《黃帝內經》、《太公陰符》等中的黃帝、太公。第二句回答了聖人爲什麼爲衆人之先;故:是一因果關係詞,強調了聖人持道爲衆生之先的方法更古至今都是一致的。】</p><p>變化多端,各有所歸。或陰或陽,或柔或剛;或開或閉,或弛或張。是故聖人一守司其門戶,審察其所前後,度權量能,校其伎巧短長。【「變化多端,各有所歸」強調「各」和「歸」,各,有多種多樣之意,強調世界的變幻無窮,歸:歸宿,結果,強調變幻無窮的世界終究是有其歸宿點;第二句是對第一句的舉例;第三句說明現實狀況變幻無窮,聖人是如何作的。】</p><p>夫賢不肖、智愚、勇怯有差,乃可捭,乃可闔;乃可進,乃可退;乃可賤,乃難得,無爲以牧之。審定有無與其實虛,隨其嗜慾以見其志意。微排其所言而捭反之,以求其實,貴得其指;闔而捭之,以求其利。【第一句指出人的秉性各有不一樣,正是這種差異才能夠捭闔,也指出了有差、無爲是捭闔的關鍵,無爲以牧之是指順事物秉性來駕馭事物;第2、三句從總體上提出瞭如何求其實、求其利,實虛:有無,也可指真假;排:一、排斥, 二、排查;反:反詰、反問、反駁;指:同旨,主旨,目的。無爲做爲道家的一種哲學觀,能夠有兩種理解:一、順應客觀世界的規律;二、有所做爲和有所不做爲,可是有所不做爲並非消極的徹底的不做爲,而是主動的積極的根據具體狀況的不做爲,總結起來:順天之時,隨地之性,因人之心。】</p><p>或開而示之,或闔而閉之。開而示之者,同其情也;闔而閉之者,異其誠也。可與不可,審明其計謀,以原其同異。離合有守,先從其志。即欲捭之貴周,即欲闔之貴密。周密之貴微,而與道相追。【第一二句指出了示之、閉之的兩種狀況,結合下一句的「可與不可」來理解,第二句應該理解爲對方與己情同則開而示之,對方不以實相告則闔而閉之。第三句的「可與不可」指是否採起示之、閉之取決於後半句,「原」:察。第四句的守指等待,指是離是合須要等待時機。第五句強調捭闔須要作到周詳、隱祕。】</p><p>捭之者,料其情也;闔之者,結其誠也。皆見其權衡輕重,乃爲之度數。聖人於是爲之慮。其不中權衡度數,聖人於是自爲之慮。【第一句中的「料」:忖(cun)度,估量;結:系,固結;誠:實。第二句、第三句強調聖人進則爲他人謀,退則爲己謀;自爲之慮:爲之自慮。】</p><p>故捭者,或捭而出之,或捭而內之。闔者,或闔而取之,或闔而去之。捭闔者,天地之道。捭闔者,以變更陰陽,四時開閉,以化萬物,縱橫反出、反覆反忤,必由此矣。【第一二句應該是相對的,第一句中的出應該理解爲使對方說出,內理解爲使對方採納。第二句取指使本身獲取,去指使本身躲過(禍患),由於前面說過自爲之慮。第三句做者將捭闔之道是天地之道,把捭闔的重要性體現出來了。第四句以陰陽立論,指出捭闔這種方法,可以變更陰陽,順應季節變化,化育各類事物,而人世中的或合縱或連橫,或返或出,或反或覆,或反或忤,也都是由捭闔產生的。】</p><p>捭闔者,道之大化,說之變也,必豫審其變化。吉凶大命系焉。口者,心之門戶也;心者,神之主也。志意、喜欲、思慮、智謀,此皆由門戶出入。故關之以捭闔,制之以出入。【第一句中的「道之大化,說之變也」指的是捭闔這種方法是陰陽規律的無限變化,遊說應變的關鍵,因此做者提出須要事先對各類變化有所準備,由於這關係到吉凶大命。豫:事先有所準備。第3、四句指出了口的重要性。因此,做者在第五句提出以捭闔關之,以出入制之(關之以捭闔,制之以出入:用捭闔之法駕馭說話、實情出入)。固然這「口」是不是做者以前提到的「存亡之門戶」還有待考量。】</p><p>捭之者,開也,言也,陽也;闔之者,閉也,默也,陰也。陰陽其和,終始其義。故言長生、安樂、富貴、尊榮、顯名、愛好、財利、得意、喜欲,爲陽,曰「始」。故言死亡、憂患、貧賤、苦辱、棄損、亡利、失意、有害、刑戮、誅罰,爲陰,曰「終」。諸言法陽之類者,皆曰「始」,言善以始其事。諸言法陰之類者,皆曰「終」,言惡以終其謀。【第一句是對遊說中的捭闔(做者前面提到捭闔是天地之道,天然不只僅包含遊說之道,故此處指遊說中的捭闔之道)下定義,進行解釋。第二句須要結合上下句來理解,陰陽相互調和,從開始到結束的整個過程都要符合捭闔的規律、要理。故,因果關係詞,第3、四句中的故是承接第二句而言,說明爲什麼要將法陽之類爲始,法陰之類爲終。第5、六句是承接在第四句的基礎上論述的,因此在理解第5、六句時,須要在每一句中體現因果關係。第五六句理解爲:凡是遊說中說到 「陽」一類的,咱們都稱其爲「始」,由於從事物好的一面遊說,誘導對方行動,促進遊說成功;反之,遊說中說到 「陰」一類的,咱們都稱之爲「終」,由於從事物有害的一面遊說,勸阻對方行動,終止對方謀略實施。】</p><p>捭闔之道,以陰陽試之。故與陽言者,依崇高;與陰言者,依卑小。如下求小,以高求大。由此言之,無所不出,無所不入,無所不言可。能夠說人,能夠說家,能夠說國,能夠說天下。爲小無內,爲大無外。益損、去就、倍反,皆以陰陽御其事。【第一句回到了捭闔之道乃天地之道,陰陽之道的根本性世界觀上,理解:捭闔的方法就是用陰陽的規律反覆地進行試探。試,用。第二句,以「故」這一因果關係詞進行舉例說明對待陽言者、陰言者的不一樣方法。第三句是在第二句的基礎上進行類比性的演繹,進而得出了第4、5、6、七句的總結性論點。第六句:泛指捭闔的方法無所不包,也能夠說捭闔的方法具備廣泛適用性。「由此言之中」的「此」就是指第2、三句中所採用的方法。御:治理、統治,引伸爲用陰陽的規律駕馭遊說中的益損、去就、倍反。爲小無內,爲大無外:小到事物內部再無東西,大到事物外部再無東西,泛指包含一切事物,無所不包。】</p><p>陽動而行,陰止而藏,陽動而出,陰隱而入。陽還終始,陰極反陽。以陽動者,德相生也;以陰靜者,形相成也。以陽求陰,苞以德也;以陰結陽,施以力也。陰陽相求,由捭闔也。此天地陰陽之道,而說人之法也。爲萬事之先,是謂「圓方」之門戶。【第一二句是闡述陰陽理論的,後面幾句都是以該理論展開論述。第三四句應當結合起來理解,德與形相對,德與力相對,故此處德應該指德行、品德,形指刑罰,方與「力」相關,此兩句說的是以陰陽御刑德,故整句理解:陽動則德行產生了,陰靜則刑戮造成了,用陽求陰須要用德行包容對方,用陰固結陽則須要向對方施加力量。第五句指陰陽相互依賴都是由捭闔之道決定的。第六句中的此指第五句,指的是捭闔之道系天地、陰陽之道,遊說的法則,是萬事的根本,天地的門戶。不知此處之門戶是否就是存亡之門戶?存亡之門戶還有待考量。】</p>', '2017-08-06 09:00:33', 1, 0);
INSERT INTO `topic` VALUES (13, 13, 0, 'test', '<p>在此寫上您的內容</p>', '2017-08-06 09:45:31', 0, 0);
-- ----------------------------
-- Table structure for user
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`user_id` int NOT NULL AUTO_INCREMENT,
`sno` varchar(11) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`sex` char(2) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '性別,只有男和女',
`username` varchar(25) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`register_date` date NULL DEFAULT NULL,
`password` varchar(16) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`sign` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '我的格言,簽名之類的',
`imgUrl` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '圖片上傳地址',
`email` varchar(25) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`phone` varchar(15) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`sdept` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`clazz` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`article_num` int NOT NULL DEFAULT 0 COMMENT '該用戶發帖數',
`status` int(1) NOT NULL DEFAULT 1 COMMENT '1爲可發言, 0表示被禁言',
`islock` tinyint(1) NOT NULL DEFAULT 0 COMMENT '0表示未鎖定,能夠被其餘用戶查看',
`reply_num` int NOT NULL DEFAULT 0,
PRIMARY KEY (`user_id`) USING BTREE,
UNIQUE INDEX `uemail`(`email`) USING BTREE,
UNIQUE INDEX `sno`(`sno`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 14 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES (1, '14144501413', '男', 'jsbintask', '2017-06-06', '123456', '微信公衆號:jsbintask', '6.jpg', 'jsbintask@gmail.com', '15576030460', '計算機', '1406', 7, 1, 1, 28);
INSERT INTO `user` VALUES (2, '14144501415', '女', 'test1', '2017-06-02', '123456', '。。。', '1.jpg', '123@qq.com', '110', '計算機', '1405', 0, 1, 1, 1);
INSERT INTO `user` VALUES (3, '14144501417', '男', 'test2', '2017-06-01', '123456', '嗨。', '2.jpg', '110@qq.com', '15576030460', '物電', '1406', 1, 1, 0, 2);
INSERT INTO `user` VALUES (4, '14144501419', '男', 'test3', '2017-06-12', '123456', 'Hello', 'defaultHead.png', '124@qq.com', NULL, NULL, NULL, 0, 1, 0, 0);
INSERT INTO `user` VALUES (5, '14144501421', '男', 'test4', '2017-05-16', '123456', 'hi.', 'defaultHead.png', '112@qq.com', NULL, NULL, NULL, 1, 1, 0, 2);
INSERT INTO `user` VALUES (7, '14144501425', '男', 'test5', NULL, '123456', NULL, 'defaultHead.png', '1111@qq.com', NULL, NULL, NULL, 0, 1, 0, 0);
INSERT INTO `user` VALUES (8, '14144501377', '男', 'test11', NULL, '123456', 'test', '3.jpg', '1362761867@qq.com', '15576030460', '計算機學院', '網絡二班', 1, 1, 0, 0);
INSERT INTO `user` VALUES (9, '14144501379', '男', 'test6', NULL, '123456', '。。。', '4.jpg', '727971401@qq.com', '15173007554', '計算機學院', '1406', 1, 1, 0, 2);
INSERT INTO `user` VALUES (10, '14144501489', '男', 'test7', NULL, '123456', '。。。', '5.jpg', '1484432123@qq.com', '15576030460', '計算機學院', '1406', 0, 1, 0, 2);
INSERT INTO `user` VALUES (11, '14144501381', '男', 'test8', NULL, '123456', 'null', 'defaultHead.png', '1397744240@qq.com', NULL, '計算機學院', '網絡14-2BF', 1, 1, 0, 3);
INSERT INTO `user` VALUES (12, '14144501356', '男', 'test9', NULL, 'a2145265', NULL, 'defaultHead.png', '791392383@qq.com', NULL, NULL, NULL, 0, 1, 0, 0);
INSERT INTO `user` VALUES (13, '14141501381', '男', 'test10', NULL, '123456', NULL, 'defaultHead.png', 'ss@a.com', NULL, NULL, NULL, 1, 1, 0, 3);
SET FOREIGN_KEY_CHECKS = 1;
複製代碼
文件上傳主要爲配合百度ueditor上傳文件使用:jquery
package com.baidu.um;
import org.apache.commons.fileupload.FileItemIterator;
import org.apache.commons.fileupload.FileItemStream;
import org.apache.commons.fileupload.FileUploadBase.InvalidContentTypeException;
import org.apache.commons.fileupload.FileUploadBase.SizeLimitExceededException;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.apache.commons.fileupload.util.Streams;
import sun.misc.BASE64Decoder;
import javax.servlet.http.HttpServletRequest;
import java.io.*;
import java.text.SimpleDateFormat;
import java.util.*;
/** * UEditor文件上傳輔助類 * */
public class Uploader {
// 輸出文件地址
private String url = "";
// 上傳文件名
private String fileName = "";
// 狀態
private String state = "";
// 文件類型
private String type = "";
// 原始文件名
private String originalName = "";
// 文件大小
private long size = 0;
private HttpServletRequest request = null;
private String title = "";
// 保存路徑
private String savePath = "upload";
// 文件容許格式
private String[] allowFiles = { ".rar", ".doc", ".docx", ".zip", ".pdf",".txt", ".swf", ".wmv", ".gif", ".png", ".jpg", ".jpeg", ".bmp" };
// 文件大小限制,單位KB
private int maxSize = 10000;
private HashMap<String, String> errorInfo = new HashMap<String, String>();
public Uploader(HttpServletRequest request) {
this.request = request;
HashMap<String, String> tmp = this.errorInfo;
tmp.put("SUCCESS", "SUCCESS"); //默認成功
tmp.put("NOFILE", "未包含文件上傳域");
tmp.put("TYPE", "不容許的文件格式");
tmp.put("SIZE", "文件大小超出限制");
tmp.put("ENTYPE", "請求類型ENTYPE錯誤");
tmp.put("REQUEST", "上傳請求異常");
tmp.put("IO", "IO異常");
tmp.put("DIR", "目錄建立失敗");
tmp.put("UNKNOWN", "未知錯誤");
}
public void upload() throws Exception {
boolean isMultipart = ServletFileUpload.isMultipartContent(this.request);
if (!isMultipart) {
this.state = this.errorInfo.get("NOFILE");
return;
}
DiskFileItemFactory dff = new DiskFileItemFactory();
String savePath = this.getFolder(this.savePath);
dff.setRepository(new File(savePath));
try {
ServletFileUpload sfu = new ServletFileUpload(dff);
sfu.setSizeMax(this.maxSize * 1024);
sfu.setHeaderEncoding("utf-8");
FileItemIterator fii = sfu.getItemIterator(this.request);
while (fii.hasNext()) {
FileItemStream fis = fii.next();
if (!fis.isFormField()) {
this.originalName = fis.getName().substring(fis.getName().lastIndexOf(System.getProperty("file.separator")) + 1);
if (!this.checkFileType(this.originalName)) {
this.state = this.errorInfo.get("TYPE");
continue;
}
this.fileName = this.getName(this.originalName);
this.type = this.getFileExt(this.fileName);
this.url = savePath + "/" + this.fileName;
BufferedInputStream in = new BufferedInputStream(fis.openStream());
File file = new File(this.getPhysicalPath(this.url));
FileOutputStream out = new FileOutputStream( file );
BufferedOutputStream output = new BufferedOutputStream(out);
Streams.copy(in, output, true);
this.state=this.errorInfo.get("SUCCESS");
this.size = file.length();
//UE中只會處理單張上傳,完成後即退出
break;
} else {
String fname = fis.getFieldName();
//只處理title,其他表單請自行處理
if(!fname.equals("pictitle")){
continue;
}
BufferedInputStream in = new BufferedInputStream(fis.openStream());
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
StringBuffer result = new StringBuffer();
while (reader.ready()) {
result.append((char)reader.read());
}
this.title = new String(result.toString().getBytes(),"utf-8");
reader.close();
}
}
} catch (SizeLimitExceededException e) {
this.state = this.errorInfo.get("SIZE");
} catch (InvalidContentTypeException e) {
this.state = this.errorInfo.get("ENTYPE");
} catch (FileUploadException e) {
this.state = this.errorInfo.get("REQUEST");
} catch (Exception e) {
this.state = this.errorInfo.get("UNKNOWN");
}
}
/** * 接受並保存以base64格式上傳的文件 * @param fieldName */
public void uploadBase64(String fieldName){
String savePath = this.getFolder(this.savePath);
String base64Data = this.request.getParameter(fieldName);
this.fileName = this.getName("test.png");
this.url = savePath + "/" + this.fileName;
BASE64Decoder decoder = new BASE64Decoder();
try {
File outFile = new File(this.getPhysicalPath(this.url));
OutputStream ro = new FileOutputStream(outFile);
byte[] b = decoder.decodeBuffer(base64Data);
for (int i = 0; i < b.length; ++i) {
if (b[i] < 0) {
b[i] += 256;
}
}
ro.write(b);
ro.flush();
ro.close();
this.state=this.errorInfo.get("SUCCESS");
} catch (Exception e) {
this.state = this.errorInfo.get("IO");
}
}
/** * 文件類型判斷 * * @param fileName * @return */
private boolean checkFileType(String fileName) {
Iterator<String> type = Arrays.asList(this.allowFiles).iterator();
while (type.hasNext()) {
String ext = type.next();
if (fileName.toLowerCase().endsWith(ext)) {
return true;
}
}
return false;
}
/** * 獲取文件擴展名 * * @return string */
private String getFileExt(String fileName) {
return fileName.substring(fileName.lastIndexOf("."));
}
/** * 依據原始文件名生成新文件名 * @return */
private String getName(String fileName) {
Random random = new Random();
return this.fileName = "" + random.nextInt(10000)
+ System.currentTimeMillis() + this.getFileExt(fileName);
}
/** * 根據字符串建立本地目錄 並按照日期創建子目錄返回 * @param path * @return */
private String getFolder(String path) {
SimpleDateFormat formater = new SimpleDateFormat("yyyyMMdd");
path += "/" + formater.format(new Date());
File dir = new File(this.getPhysicalPath(path));
if (!dir.exists()) {
try {
dir.mkdirs();
} catch (Exception e) {
this.state = this.errorInfo.get("DIR");
return "";
}
}
return path;
}
/** * 根據傳入的虛擬路徑獲取物理路徑 * * @param path * @return */
private String getPhysicalPath(String path) {
String servletPath = this.request.getServletPath();
String realPath = this.request.getSession().getServletContext()
.getRealPath(servletPath);
return new File(realPath).getParent() +"/" +path;
}
public void setSavePath(String savePath) {
this.savePath = savePath;
}
public void setAllowFiles(String[] allowFiles) {
this.allowFiles = allowFiles;
}
public void setMaxSize(int size) {
this.maxSize = size;
}
public long getSize() {
return this.size;
}
public String getUrl() {
return this.url;
}
public String getFileName() {
return this.fileName;
}
public String getState() {
return this.state;
}
public String getTitle() {
return this.title;
}
public String getType() {
return this.type;
}
public String getOriginalName() {
return this.originalName;
}
}
複製代碼
權限主要使用springmvc攔截器進行處理,攔截未登陸的用戶,發帖,回帖等信息:git
package cn.jsbintask.bbs.interceptor;
import cn.jsbintask.bbs.po.User;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//實現一個攔截器,進行用戶的權限控制
public class PostTopicInter implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
System.out.println("進入了攔截器頁面");
boolean flag = false;
User user = (User) httpServletRequest.getSession().getAttribute("user");
if(user!=null) {
if(user.getStatus()==0) {
httpServletRequest.setAttribute("message", "對不起,您已被管理員禁言,請聯繫管理員進行處理");
httpServletRequest.getRequestDispatcher("/topic/all").forward(httpServletRequest, httpServletResponse);
} else {
flag = true;
}
} else {
httpServletRequest.setAttribute("message", "請先登陸再進行操做");
httpServletRequest.getRequestDispatcher("/user/userLogin").forward(httpServletRequest, httpServletResponse);
}
return flag;
}
@Override
public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
}
}
複製代碼
相應配置文件以下:github
<!--定義攔截器-->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/topic/postTopic"/>
<mvc:mapping path="/article/postArticle" />
<mvc:mapping path="/topic/collectTopic"/>
<mvc:mapping path="/otherSpace/attentionUser"/>
<bean class="cn.jsbintask.bbs.interceptor.PostTopicInter" />
</mvc:interceptor>
<mvc:interceptor>
<mvc:mapping path="/admin/**"/>
<mvc:exclude-mapping path="/admin/login"/>
<!--因爲攔截器在controller以前執行,因此這個地址也要攔截掉才行-->
<mvc:exclude-mapping path="/admin/index"/>
<bean class="cn.jsbintask.bbs.interceptor.AdminInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
複製代碼
郵件發送爲註冊用戶時接受註冊驗證碼時使用,關鍵代碼以下:web
public static void sendMessage(String to, String code) throws Exception {
Properties props = new Properties();
String from = "Jsbintask@163.com";
String smtpUrl = "smtp." + from.split("@")[1];
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.host", smtpUrl);
Session session = Session.getInstance(props, new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication("Jsbintask@163.com", "xxxxxx");
}
});
Message message = new MimeMessage(session);
message.setFrom(new InternetAddress("Jsbintask@163.com"));
message.setRecipient(RecipientType.TO, new InternetAddress(to));
System.out.println("BBSCheckCode");
message.setSubject("激活碼");
message.setContent(
"<h1>您的驗證碼:<span style='color=red'>" + code + "</span></h1>",
"text/html;charset=UTF-8");
Transport.send(message);
}
複製代碼
注意此處郵箱,密碼修改成本身的。ajax
關注我,這裏只有乾貨!