用IDEA Intellij,本来创建的是SpringMVC项目,但是下载的时候,太慢了。所以还是用的Maven项目。

选择Maven 项目->Archetype->Web application. 本来需要增加参数-DarchetypeCatalog=internal,

但是发现也不用了,应该是已经下载了。

首先将webapp->WEBINF->web.xml,改一下:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2.  
  3. <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  4. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  5. xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
  6. version="3.1">
  7. <display-name>Archetype Created Web Application</display-name>
  8.  
  9. <servlet>
  10. <servlet-name>main-dispatcher</servlet-name>
  11. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  12. <load-on-startup>1</load-on-startup>
  13. </servlet>
  14.  
  15. <servlet-mapping>
  16. <servlet-name>main-dispatcher</servlet-name>
  17. <url-pattern>/</url-pattern>
  18. </servlet-mapping>
  19. </web-app>

注意其中的servlet和servlet-mapping。但是发现servlet-class显示的是红字。判断原因是需要在pom.xml中加上引用库。

改好的pom.xml如下:

  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  3. <modelVersion>4.0.0</modelVersion>
  4. <groupId>com.webapp</groupId>
  5. <artifactId>hellospringmvc</artifactId>
  6. <packaging>war</packaging>
  7. <version>1.0-SNAPSHOT</version>
  8. <name>hellospringmvc Maven Webapp</name>
  9. <url>http://maven.apache.org</url>
  10.  
  11. <properties>
  12. <spring.version>4.2.6.RELEASE</spring.version>
  13. </properties>
  14.  
  15. <dependencies>
  16. <dependency>
  17. <groupId>junit</groupId>
  18. <artifactId>junit</artifactId>
  19. <version>3.8.1</version>
  20. <scope>test</scope>
  21. </dependency>
  22.  
  23. <dependency>
  24. <groupId>org.springframework</groupId>
  25. <artifactId>spring-webmvc</artifactId>
  26. <version>${spring.version}</version>
  27. </dependency>
  28.  
  29. <dependency>
  30. <groupId>org.springframework.data</groupId>
  31. <artifactId>spring-data-jpa</artifactId>
  32. <version>1.10.1.RELEASE</version>
  33. </dependency>
  34.  
  35. <dependency>
  36. <groupId>javax.servlet</groupId>
  37. <artifactId>jstl</artifactId>
  38. <version>1.2</version>
  39. </dependency>
  40.  
  41. </dependencies>
  42. <build>
  43. <finalName>hellospringmvc</finalName>
  44.  
  45. <plugins>
  46. <plugin>
  47. <groupId>org.apache.maven.plugins</groupId>
  48. <artifactId>maven-compiler-plugin</artifactId>
  49. <configuration>
  50. <source>1.8</source>
  51. <target>1.8</target>
  52. </configuration>
  53. </plugin>
  54. </plugins>
  55.  
  56. </build>
  57. </project>

然后打开file - project structure,加上java目录,并标记为Source目录。

做完上面几步,再看web.xml,就没有红字报错了。

然后配置启动环境,Run->Edit-Configuration,

里面把Tomcat的端口改一下,我这里改的是8010,然后把chrome的启动url也改成8010. 在Deploy tab加上artifact,选默认的就行。

然后不用写代码,直接Run 就能看到 localhost:8010 能够打开"Hello World!" 页面。

然后,先在web.xml里面加上对于编码的处理,最后web.xml变成这样:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2.  
  3. <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  4. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  5. xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
  6. version="3.1">
  7. <display-name>Archetype Created Web Application</display-name>
  8.  
  9. <servlet>
  10. <servlet-name>main-dispatcher</servlet-name>
  11. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  12. <load-on-startup>1</load-on-startup>
  13. </servlet>
  14.  
  15. <servlet-mapping>
  16. <servlet-name>main-dispatcher</servlet-name>
  17. <url-pattern>/</url-pattern>
  18. </servlet-mapping>
  19.  
  20. <filter>
  21. <filter-name>encodingFilter</filter-name>
  22. <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  23. <init-param>
  24. <param-name>encoding</param-name>
  25. <param-value>UTF-8</param-value>
  26. </init-param>
  27. <init-param>
  28. <param-name>forceEncoding</param-name>
  29. <param-value>true</param-value>
  30. </init-param>
  31. </filter>
  32. <filter-mapping>
  33. <filter-name>encodingFilter</filter-name>
  34. <url-pattern>/*</url-pattern>
  35. </filter-mapping>
  36.  
  37. </web-app>

然后在java目录下建package com.webapp.hello,然后在其中建class, MainController,内容如下:

  1. package com.webapp.hello;
  2.  
  3. import org.springframework.stereotype.Controller;
  4. import org.springframework.web.bind.annotation.RequestMapping;
  5. import org.springframework.web.bind.annotation.RequestMethod;
  6.  
  7. /**
  8. * Created by baidu on 16/10/7.
  9. */
  10. @Controller
  11. public class HelloController {
  12.  
  13. @RequestMapping(value="/", method= RequestMethod.GET)
  14. public String index() {
  15. return "hello";
  16. }
  17. }

注意,return的是hello.

然后根据servlet名字,加上servlet的配置文件 main-dispatcher-servlet.xml,内容如下:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:contex="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
  7.  
  8. <contex:component-scan base-package="com.webapp.hello"/>
  9.  
  10. <mvc:default-servlet-handler/>
  11.  
  12. <mvc:annotation-driven/>
  13.  
  14. <bean id="jspViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  15. <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
  16. <property name="prefix" value="/"/>
  17. <property name="suffix" value=".jsp"/>
  18. </bean>
  19.  
  20. </beans>

然后在index.jsp的同级目录加一个hello.jsp如下:

  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  2. <!DOCTYPE html>
  3. <html lang="zh-CN">
  4. <head>
  5. <meta charset="utf-8">
  6. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  7. <meta name="viewport" content="width=device-width, initial-scale=1">
  8. <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
  9. <title>SpringMVC Demo 首页</title>
  10.  
  11. <!-- 新 Bootstrap 核心 CSS 文件 -->
  12. <link rel="stylesheet" href="//cdn.bootcss.com/bootstrap/3.3.5/css/bootstrap.min.css">
  13.  
  14. <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
  15. <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
  16. <!--[if lt IE 9]>
  17. <script src="//cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
  18. <script src="//cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
  19. <![endif]-->
  20. </head>
  21. <body>
  22. <h1>Hello World!</h1>
    <h3>成功自定义页面啦!</h3>
  1. <!-- jQuery文件。务必在bootstrap.min.js 之前引入 -->
    <script src="//cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>
  2.  
  3. <!-- 最新的 Bootstrap 核心 JavaScript 文件 -->
    <script src="//cdn.bootcss.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
    </body>
    </html>

然后在project名字的右键,第二个"Add framework support"点开,加上Spring support。(不确定是否需要加上这个)

然后点击运行。就能看到"Hello World"。但是遗憾地发现,还是index.jsp的内容。

然后把index.jsp删掉,发现才能够显示定制化的内容。原来开始是受index.jsp屏蔽了。

  1. Hello World!
  2. 成功自定义页面啦!

以下讲述,怎么向JSP页面传输变量。

将MainController.java更新为如下:

  1. package com.webapp.hello;
  2.  
  3. import org.springframework.stereotype.Controller;
  4. import org.springframework.ui.ModelMap;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.RequestMethod;
  7.  
  8. import java.util.LinkedList;
  9. import java.util.List;
  10.  
  11. /**
  12. * Created by baidu on 16/10/7.
  13. */
  14. @Controller
  15. public class HelloController {
  16.  
  17. @RequestMapping(value="/", method= RequestMethod.GET)
  18. public String index(ModelMap modelMap) {
  19. List userList = new LinkedList();
  20. userList.add("张三");
  21. userList.add("李四");
  22. modelMap.addAttribute("userList", userList);
  23. return "hello";
  24. }
  25. }

然后将hello.jsp更新为如下:

  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  2.  
  3. <!DOCTYPE html>
  4. <html lang="zh-CN">
  5. <head>
  6. <meta charset="utf-8">
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  8. <meta name="viewport" content="width=device-width, initial-scale=1">
  9. <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
  10. <title>SpringMVC Demo 首页</title>
  11.  
  12. <!-- 新 Bootstrap 核心 CSS 文件 -->
  13. <link rel="stylesheet" href="//cdn.bootcss.com/bootstrap/3.3.5/css/bootstrap.min.css">
  14.  
  15. <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
  16. <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
  17. <!--[if lt IE 9]>
  18. <script src="//cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
  19. <script src="//cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
  20. <![endif]-->
  21. </head>
  22. <body>
  23. <h1>Hello World!</h1>
  24.  
  25. <h3>成功自定义页面啦!</h3>
  26.  
  27. <c:if test="${empty userList}">
  28. <div class="alert alert-warning" role="alert">
  29. <span class="glyphicon glyphicon-info-sign" aria-hidden="true"></span>
  30. 没有用户!
  31. </div>
  32. </c:if>
  33.  
  34. <c:if test="${!empty userList}">
  35. <c:forEach items="${userList}" var="user">
  36. <tr>
  37. <td>${user}</td>
  38. </tr>
  39. </c:forEach>
  40. </c:if>
  41.  
  42. <!-- jQuery文件。务必在bootstrap.min.js 之前引入 -->
  43. <script src="//cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>
  44.  
  45. <!-- 最新的 Bootstrap 核心 JavaScript 文件 -->
  46. <script src="//cdn.bootcss.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
  47. </body>
  48. </html>

运行,发现显示没有用户,不符合预期:

网上搜索,可能是没有加jstl,然后在第二行加上:

  1. <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

然后重新运行,可以显示用户啦:

至此,利用SpringMVC搭建基本的动态页面,基本完成。

以下,是来自简书某个页面的介绍,讲的比较浅显易懂:

http://www.jianshu.com/p/6b3d30b2fd18

Spring MVC请求处理流程

  1. Spring MVC的设计是围绕DispatcherServlet展开的,DispatcherServlet负责将请求派发到特定的handler。通过可配置的handler mappings、view resolution、locale以及theme resolution来处理请求并且转到对应的视图。Spring MVC请求处理的整体流程如图:

     
  2. 在web.xml中我们可以看到配置了一个DispatcherServlet,该Servlet拦截了 / 的所有请求

  3. 在mvc-dispatcher-servlet.xml中 component-scan 扫描指定的文件夹下的文件(这里指定了根目录)

  4. 当请求发起时,Spring MVC扫描文件发现HelloController 中的 @Controller和@RequestMapping("/")注解便由DispatcherServlet转向HelloController来处理 / 请求

  5. 当HelloController返回hello变由mvc-dispatcher-servlet.xml的配置默认加上前后缀成为/WEB-INF/pages/hello.jsp,最后将Hello World输出

     

更多SpringMVC的学习,参考我的另一篇博客:

http://www.cnblogs.com/charlesblc/p/5933555.html

 

自建一个Java Spring MVC项目的更多相关文章

  1. Java Spring MVC项目搭建(二)——项目配置

    1.站点配置文件web.xml 每一个Spring MVC 项目都必须有一个站点配置文件web.xml,他的主要功能吗....有一位大哥已经整理的很好,我借来了,大家看看: 引用博客地址: http: ...

  2. Java Spring MVC项目搭建(一)——Spring MVC框架集成

    1.Java JDK及Tomcat安装 我这里安装的是JDK 1.8 及 Tomcat 8,安装步骤详见:http://www.cnblogs.com/eczhou/p/6285248.html 2. ...

  3. Java Spring MVC项目搭建(三)——“Hello World”

    在Spring 的配置文件里,我们定义了一个bean ,Spring 会在启动时候会生成对象. <bean id = "helloworld" class="com ...

  4. 在上已个Java Spring MVC项目基础上加MyBatis

    代码目录: /Users/baidu/Documents/Data/Work/Code/Self/HelloSpringMVC 1. 首先在resource目录加上jdbc.properties: d ...

  5. 在Mac系统下用STS搭建一个Spring MVC项目

    [本文出自天外归云的博客园] 从STS的下载到空项目的搭建 1. 下载STS,下载解压缩后点击sts-bundle文件夹中的STS文件启动ide: 2. 创建Spring MVC项目:File-> ...

  6. Spring MVC第一课:用IDEA构建一个基于Spring MVC, Hibernate, My SQL的Maven项目

    作为一个Spring MVC新手最基本的功夫就是学会如何使用开发工具创建一个完整的Spring MVC项目,本文站在一个新手的角度讲述如何一步一步创建一个基于Spring MVC, Hibernate ...

  7. 使用maven, myeclipse工具构建spring mvc项目

    一.使用myeclipse 创建一个新的 maven项目. (ps:1.在filter过滤的时候输入 webapp 选择"maven-archetype-webapp". 2.在m ...

  8. maven 纯注解一步一步搭建Spring Mvc项目(入门)

    初次接触spring MVC项目,通过一段时间的学习,本文介绍一种以纯注解的方法去配置spring MVC环境,让那些配置的.xml文件统统见鬼吧. 什么是Spring MVC Spring MVC属 ...

  9. 简单Spring MVC项目搭建

    1.新建Project 开发环境我使用的是IDEA,其实使用什么都是大同小异的,关键是自己用的顺手. 首先,左上角File→New→Project.在Project页面选择Maven,然后勾上图中所示 ...

随机推荐

  1. Python-函数总结

    把程序分解成较小的部分,主要有3种方法. 函数(function) 对象(object) 模块(module) 本节我们先学习函数.函数是带名字的代码块,可以把多个逻辑封装起来.这样就可以在程序中可以 ...

  2. 常见http错误码

    一些常见的状态码为: 200 - 服务器成功返回网页 404 - 请求的网页不存在 503 - 服务不可用 详细分解: 1xx(临时响应) 表示临时响应并需要请求者继续执行操作的状态代码. 代码 说明 ...

  3. Sublime Text的使用技巧

    来到腾讯之后,基本上整个团队都在使用Sublime Text这款编辑神器.虽说自己以前在写python的时候略有接触过,但只是把它当做简单的文本编辑器.来到这边后,才逐渐的体会到这款神作的牛逼之处. ...

  4. JMS 基本可靠性机制 和 事务机制

    4.3.1 基本可靠性机制4.3.1.1 控制消息的签收(Acknowledgment) 客户端成功接收一条消息的标志是这条消息被签收.成功接收一条消息一般包括如 下三个阶段:1.客户端接收消息:2. ...

  5. 矩阵乘法<简单总结>

    原理:矩阵相乘最重要的方法是一般矩阵乘积.它只有在第一个矩阵的 行数 和第二个矩阵的 列数 相同时才可进行.若A为m×n矩阵,B为n×p矩阵,则他们的乘积AB会是一个m×p矩阵. 若A=    a   ...

  6. 【BJOI2014】大融合【LCT】

    闲着没事写篇题解 传送门 LCT维护子树的模板题 树链剖分中,子树可以用dfs序维护.但LCT你总不可能动态维护dfs序啊 LCT之所以不能直接维护子树,是因为LCT只能维护它的重儿子.我们把这棵子树 ...

  7. Java并发(八):AbstractQueuedSynchronizer

    先做总结: 1.AbstractQueuedSynchronizer是什么? AbstractQueuedSynchronizer(AQS)这个抽象类,是Java并发包 java.util.concu ...

  8. python学习一月总结_汇总大牛们的思想_值得收藏

    ''' 下面是我汇总的我学习一个月python(version:3.3.2)的所有笔记 你可以访问:http://www.python.org获取更多信息 你也可以访问:http://www.cnbl ...

  9. python开发_gzip_压缩|解压缩gz文件_完整版_博主推荐

    ''' gzip -- 支持gzip文件 源文件:Lib/gzip.py 这个模块提供了一些简单的接口来对文件进行压缩和解压缩,类似于GNU项目的gzip和gunzip. 数据的压缩源于zlib模块的 ...

  10. hihocoder1320 160周 压缩字符串

    hihocoder1320 题目链接 思路: dp解法.用map[i][j]表示从第i个开始到第j个的字串的best压缩长度.(包括i,j,两端闭合). 用k表示i,j中的一点. 用zip()表示压缩 ...