Smart2.0开发指南——入门

孤者浪人 提交于 2019-11-30 23:16:16

说明:本文为《Smart2.0开发指南》系类文章

第一步:创建一个基于Servlet3.0的Maven Webapp工程

   打开Eclipse,点击File>New>Maven Project 选择项目保存位置,默认为Workspace目录,点击Next, Archetype选择maven-archetype-webapp,点击Next,填写项目信息如图2-1,点击Finish完成创建。

标准的Maven Webapp目录结构如下:

--src
  |--main
    |--java
    |--resources
    |--webapp
  |--test
    |--java
    |--resources

而这里使用Eclipse 的Maven插件创建的目录并不完整,需要我们手动创建src/main/java、src/test/java、src/test/resources三个目录,创建后的项目目录结构如图2-2。

 

   这里Maven Webapp的Webapp版本为2.3,也就是Servlet2.3,由于Smart 是基于Servlet3.0的,所以需要将Webapp的版本改为3.0。在workspace中找到HelloSmart项目,用文本编辑器打开HelloSmart/.settings/org.eclipse.wst.common.project.facet.core.xml ,将<installed facet="java" version="1.5"/> 、<installed facet="jst.web" version="2.3"/>改为<installed facet="java" version="1.7"/> 、<installed facet="jst.web" version="3.0"/>。然后删掉src/main/webapp/WEB-INF/web.xml文件,或将其内容改为如下代码:

  <?xml version="1.0" encoding="UTF-8"?>
  <web-app xmlns="http://java.sun.com/xml/ns/javaee"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
           http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
           version="3.0">
    <display-name>HelloSmart</display-name>
  </web-app>

在Eclipse中打开项目的pom.xml文件,在<build>节点下添加如下配置:

  <plugins>
  	   <plugin>
  	    <artifactId>maven-compiler-plugin</artifactId>
  	    <version>3.0</version>
  	    <configuration>
  	     <source>1.7</source>
  	     <target>1.7</target>
  	    </configuration>
  	   </plugin>
  </plugins>
选择HelloSmart项目,右键选择Maven>Update Project更新项目,到这里,一个基于Servlet3.0的Manve Webapp创建完成。

第二步:引入Smart Framework支持

  我们是基于Smart Framework开发应用,那么这里就需要引入Smart Framework的支持了。因为使用Maven构建项目,那么Maven会根据pom.xml文件自动下载Smart 的JAR包,而这里我们只需要在pom中添加相应的依赖配置即可。依赖配置如下:

    <properties>
         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
         <smart.version>2.0</smart.version>
    </properties>
    <dependencies>
      	<!-- JUnit -->
          <dependency>
              <groupId>junit</groupId>
              <artifactId>junit</artifactId>
              <version>4.11</version>
              <scope>test</scope>
          </dependency>
          <!-- Servlet -->
          <dependency>
              <groupId>javax.servlet</groupId>
              <artifactId>javax.servlet-api</artifactId>
              <version>3.0.1</version>
              <scope>provided</scope>
          </dependency>
           <!-- JSTL -->
          <dependency>
              <groupId>javax.servlet</groupId>
              <artifactId>jstl</artifactId>
              <version>1.2</version>
              <scope>runtime</scope>
          </dependency>
           <!-- MySQL -->
          <dependency>
              <groupId>mysql</groupId>
              <artifactId>mysql-connector-java</artifactId>
              <version>5.1.25</version>
              <scope>runtime</scope>
          </dependency>
          <!-- Smart -->
          <dependency>
              <groupId>com.smart</groupId>
              <artifactId>smart-framework</artifactId>
              <version>${smart.version}</version>
          </dependency>
    </dependencies>

  接下来需要添加Smart的配置文件,在src/main/resources下创建config.properties,文件中添加如下配置内容:

  #应用名称
  app.name=HelloSmart
  app.package=com.smart.app.hellosmart
  #项目静态资源目录
  app.www_path=/www/
  #jsp文件目录
  app.jsp_path=/WEB-INF/jsp/
  #应用首页
  app.home_page=/index
  
  jdbc.driver=com.mysql.jdbc.Driver
  jdbc.url=jdbc:mysql://localhost:3306/smart
  jdbc.username=root
  jdbc.password=root
  jdbc.max.active=10
  jdbc.max.idle=10
  #i启用18n,这里暂不开启
  i18n.reloadable=false


  最后还需要配置log4j,在src/main/resources下创建log4j.properties,文件中添加如下配置内容:

  log4j.rootLogger=INFO,console,file
  
  log4j.appender.console=org.apache.log4j.ConsoleAppender
  log4j.appender.console.Target=System.out
  log4j.appender.console.layout=org.apache.log4j.PatternLayout
  log4j.appender.console.layout.ConversionPattern=%m%n
  
  log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
  log4j.appender.file.File=${catalina.base}/logs/smart-bootstrap/log
  log4j.appender.file.DatePattern='_'yyyyMMdd
  log4j.appender.file.encoding=UTF-8
  log4j.appender.file.layout=org.apache.log4j.PatternLayout
  log4j.appender.file.layout.ConversionPattern=%d{HH:mm:ss,SSS} %p %c (%L) - %m%n
  
  log4j.logger.com.smart.framework=DEBUG
  log4j.logger.com.smart.plugin=DEBUG
  log4j.logger.com.smart.sample=DEBUG

  以上是Smart的最简单的配置。

第三步:编写代码让Smart飞一会

     首先创建一个欢迎页面,在app.jsp_path即 /WEB-INF/jsp/ 目录下创建一个名为index.jsp的文件,在页面输出一个“Hello Smart!”问候语。为该内容区域注册一个点击事件,当点击该区域后请求/hello资源,并将当前时间做为一个参数发送给Action处理。Index.jsp代码如下:

  <body>
  	<div id="content" >
  		  Hello Smart!
  	</div>
  <script type="text/javascript">
  	var content =  document.getElementById("content");
  	content.addEventListener("click",function (){
  		var date = new Date().getTime();
  		window.location.href = "<%=request.getContextPath()%>/hello?date=" +date;
  	} , false);
  </script>
  </body>

页面效果如图2-3。

  接下来编写一个Action处理来自HTTP GET的请求/hello,在src/main/java/ 创建com.smart.app.hellosmart.action包,然后创建一个名为HelloSmartAction的类,在类上使用 @action 注解标识该类为Action,然后创建一个prcoessHello()方法,处理/hello请求,最后将date参数格式化后返回给hello.jsp页面。HelloSmartAction.java 代码如下:

  @Action
  public class HelloSmartAction {
  	//请求映射,处理使用GET方法提交的 /hello 请求
  	@Request("GET:/hello") 
  	public Page prcoessHello(Map<String, Object> fieldMap){
  		//fieldMap中取出 date 参数,并使用框架提供的 CastUtil 将其转换为Long类型
  		Long date =  CastUtil.castLong(fieldMap.get("date"));
  		//使用框架的DateUtil格式化日期
  		String dateStr = DateUtil.formatDatetime(date);
  		//将处理结果返回到hello.jsp 页面,并携带名为message的数据
  		return new Page("hello.jsp").data("message", "GET:/hello " + dateStr);
  	}
  }

  在jsp目录下创建hello.jsp如下:

<body>
  	<div id="content">
  		 <%=request.getAttribute("message") %>
  	</div>
  </body>

  页面显示如图2-4。

  编写完以上代码后,将应用部署到Tomcat7中,启动Tomcat,访问http://localhost:8080/HelloSmart/ ,将会看到图2-3的页面,点击“Hello Smart”,将请求http://loalhost:8080/HelloSmart/hello,服务器响应如图2-4页面。
  一个最简单的基于Smart Framework的应用程序就运行起来了,让它再飞一会吧!

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!