java版云笔记(一)

云笔记项目
这个项目的sql文件,需求文档,需要的html文件,jar包都可以去下载,下载地址为:http://download.csdn.net/download/liveor_die/9985846

项目简介

笔记管理系统,用户可以管理笔记信息,可以查看
其他用户分享的笔记.

主要功能如下

  • 用户模块:登录、注册、修改密码、退出
  • 笔记本模块:创建、删除、更新、查看
  • 笔记模块:创建、删除、更新、查看、转移
  • 分享和收藏模块:分享、收藏、查看、搜索分享
  • 回收站模块:查看、彻底删除、恢复
  • 活动模块:查看活动、参加活动等

项目整体设计

使用的主要技术

jQuery、Ajax、SpringMVC、IOC、AOP、MyBatis
- jQuery:简化前端javascript和ajax编程
- Ajax:页面局部处理;提升用户体验和性能
- SpringMVC:负责接收请求,调用业务组件处理,
将结果生成JSON响应输出
- SpringIOC:负责管理Controller,Service,Dao;维护这些组件对象之间的关系
- MyBatis:负责实现数据库操作,实现Dao
- SpringAOP:负责事务和异常日志功能切入。
(不用修改原有组件代码,就可以追加功能)

项目整体规范

-所有请求采用Ajax方式交互
(使用$.ajax()函数)
-系统页面全部采用HTML
(替代JSP+JSTL+EL)
-所有请求服务器处理完返回的JSON结果格式
如下

{“status”:xx,”msg”:xxx,”data”:xxx}

  表现层–》控制层–》业务层–》持久层/数据访问层
  HTML(ajax)–>Controller–>Service–>Dao

响应流程

Ajax+SpringMVC+Spring(IOC/AOP)+MyBatis
Ajax–>SpringMVC–>返回JSON结果

JSP响应流程

**请求–>DispatcherServlet–> HandlerMapping–> Controller– 返回ModelAndView/String–> ViewResolver–> JSP –>响应
**

JSON响应流程

请求–>DispatcherServlet–> HandlerMapping–> Controller–> 返回数据对象(int,User,List,Map)–> 引入jackson包,在Controller方法前添加@ResponseBody标记–> JSON响应

搭建环境

创建mysql数据库,名字为:cloud_note,编码格式为utf-8

数据库文件下载地址:


mysql常用数据库语句

  • show databases;//查看有哪些库
  • use 库名;//使用某个库
  • show tables;//查看库里有哪些表
  • desc 表名;//查看表结构

- source sql文件;//导入sql文件

导入项目数据库步骤

-set names utf8;

-source D:\cloud_note.sql;

详细的关于mysql的sql可以看我的关于mysql的博客。

创建maven web项目

项目名字为:cloud_note

需要引入的包

  • spring-webmvc包
  • mybatis包
  • dbcp包+MySQL驱动包
  • jackson包
  • mybatis-spring.jar
  • junit包
<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>3.2.8.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.3.0</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.37</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>1.2.3</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-annotations</artifactId>
        <version>2.2.3</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
        <version>2.2.3</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.2.3</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>3.2.8.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>commons-codec</groupId>
        <artifactId>commons-codec</artifactId>
        <version>1.10</version>
    </dependency>
  </dependencies>

配置web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">
  <display-name>cloud_note</display-name>
  <servlet>
    <servlet-name>springmvc</servlet-name>
    <servlet-class>
        org.springframework.web.servlet.DispatcherServlet
    </servlet-class>
    <!-- dispatcherServlet的初始化方法会启动
        spring容器,所以需要告诉它spring配置文件的位置

        注意:默认情况下,如果没有配置contextconfiglocation(既没有指定spring指定配置
        文件的位置则会查找web-inf/servletname-servlet.xml文件
     -->
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:conf/spring-*.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>springmvc</servlet-name>
    <url-pattern>*.do</url-pattern>
  </servlet-mapping>
</web-app>

配置spring配置文件

spring-mvc.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
    xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:jee="http://www.springframework.org/schema/jee"
    xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:util="http://www.springframework.org/schema/util"
    xmlns:jpa="http://www.springframework.org/schema/data/jpa"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd
        http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd
        http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.2.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
        http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.2.xsd">
    <!-- 配置handlermapping -->
    <mvc:annotation-driven/>
    <!-- 启动扫描controller -->
    <context:component-scan base-package="com.tedu.cloudnote"/>
</beans>

spring-mybatis.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:jdbc="http://www.springframework.org/schema/jdbc"
    xmlns:jee="http://www.springframework.org/schema/jee"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:util="http://www.springframework.org/schema/util"
    xmlns:jpa="http://www.springframework.org/schema/data/jpa"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd
        http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd
        http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.2.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
        http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.2.xsd">
    <!-- 配置dbcp组件DataSource -->

    <bean id="dbcp" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="username" value="root"></property>
        <property name="password" value="root"></property>
        <property name="driverClassName"
            value="com.mysql.jdbc.Driver">
        </property>
        <property name="url"
            value="jdbc:mysql://localhost:3306/cloud_note">
        </property>
    </bean>
    <bean id="ssf" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dbcp">

        </property>
        <property name="mapperLocations" value="classpath:mapper/*.xml"></property>
    </bean>
    <!-- 定义MapperScannerConfigurer -->
    <bean id="mapperScanner"
        class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.tedu.cloudnote.dao"></property>

        <!-- 可以省略不写 -->
        <property name="sqlSessionFactory" ref="ssf"></property>
    </bean>
</beans>

划分包结构

  • com.tedu.cloudnote.controller
    • com.tedu.cloudnote.controller.user
    • com.tedu.cloudnote.controller.book
    • com.tedu.cloudnote.controller.note
  • com.tedu.cloudnote.service
  • com.tedu.cloudnote.dao
  • com.tedu.cloudnote.entity
  • com.tedu.cloudnote.util

到这里项目的环境就算搭建好了。下一节开始写项目。

时间: 2024-08-30 16:50:02

java版云笔记(一)的相关文章

java版云笔记(九)之动态sql

SQL 首先,所谓SQL的动态和静态,是指SQL语句在何时被编译和执行,二者都是用在SQL嵌入式编程中的,这里所说的嵌入式是指将SQL语句嵌入在高级语言中,而不是针对于单片机的那种嵌入式编程. 静态SQL 静态SQL通常用于完成可以确定的任务.(即在编译阶段就可以确定数据库要做什么事情.) select * from t1 where c1>5 对于上述类似的DML语句在第一次运行时进行编译,而后续再次调用,则不再编译该过程.即一次编译,多次调用,使用的相同的执行计划.此种方式被称之为使用的是静

java版云笔记(二)

云笔记 基本的环境搭建好了,今天做些什么呢,第一是链接数据库(即搭建Spring-Batistas环境),第二是登录预注册. 注:这个项目的sql文件,需求文档,需要的html文件,jar包都可以去下载,下载地址为:http://download.csdn.net/download/liveor_die/9985846 搭建Spring-Batistas环境 搭建Spring-Batistas环境的基本流程如下图 jar包和配置文件上节课已经添加好了,所一下来我们要配置spring配置文件. 配

java版云笔记(六)之AOP

今天主要是利用aop技术追加service的响应时间的计算和异常的日志记录. AOP AOP(Aspect Oriented Programming),即面向切面编程,可以说是OOP(Object Oriented Programming,面向对象编程)的补充和完善.面向对象编程将程序分解成各个层次的对象,面向切面编程将程序运行过程分解成各个切面. AOP从程序运行角度考虑程序的结构,提取业务处理过程的切面,oop是静态的抽象,aop是动态的抽象, 是对应用执行过程中的步骤进行抽象,从而获得步骤

java版云笔记(八)之关联映射

Mybatis关联映射 通过数据库对象之间的关联关系,反映到到实体对象之间的引用. 加载多个表中的关联数据,封装到我们的实体对象中. 当业务对数据库进行关联查询. 关联 <association property="author" column="blog_author_id" javaType="Author"> <id property="id" column="author_id"/

java版云笔记(七)之事务管理

事务管理 事务:程序为了保证业务处理的完整性,执行的一条或多条SQL语句. 事务管理:对事务中的SQL语句进行提交或者回滚. 事物管理对于企业应用来说是至关重要的,好使出现异常情况,它也可以保证数据的一致性,不出现脏数据. Spring Framework对事务管理提供了一致的抽象,其特点如下: 为不同的事务API提供一致的编程模型,比如JTA(Java Transaction API), JDBC, Hibernate, JPA(Java Persistence API和JDO(Java Da

java版云笔记(三)

登录与注册写好了下来就是主页,今天写的是主页加载时笔记本列表的显示,ajax是固定的就不重点说了.主要说一下jQuery.data() 函数和jQuery.on() 函数. 注:这个项目的sql文件,需求文档,需要的html文件,jar包都可以去下载,下载地址为:http://download.csdn.net/download/liveor_die/9985846 笔记列表显示 发送Ajax请求 - 发送事件:笔记本li元素的单击 - 请求参数:笔记本ID - 请求地址:/note/loadn

java版云笔记(四)

页面的笔记本加载完成了,接下来就是点击笔记本显示将笔记显示,同时把笔记在右边的编辑器中,同时把编辑后的笔记更新. 注:这个项目的sql文件,需求文档,需要的html文件,jar包都可以去下载,下载地址为:http://download.csdn.net/download/liveor_die/9985846 笔记列表显示 前面我们把bookId通过下面的jq代码绑定在li上(笔记本的列表id=note_ul) $li.data("bookId",bookId);//将值与jQuery对

[开源]java版QQ机器人集成小黄鸡功能

      项目采用开源程序IQQ.内置webQQ协议.并且使用十分方便.直接调用即可.      项目采用webService接口调用可以不用重新登录QQ即可实现项目的修改.测试期间 多次登录QQ导致QQ被检测到异常还得手机解封.实现功能:一:实现天气预报的功能 用于输入#天气+你所在城市 目前只支持市区级查询.  二:实现QQ号码吉凶查询 输入#QQ+你的号码.  三:实现聊天功能.调用小黄鸡接口实现java版小黄鸡.  四:用户可以随意修改源码if判断加入自己的message.  五:其他

微信支付java版V3验证数据合法性(Deom)_java

1.1 解析微信回调数据 InputStream inStream = request.getInputStream(); ByteArrayOutputStream outSteam = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int len = 0; while ((len = inStream.read(buffer)) != -1) { outSteam.write(buffer, 0, len); } o