关键字:mavenm2eclipseJSONStruts2Log4j2tomcatjdk7Config Browser Plugin

Created by Bob 20131031

l 开发准备工作

一、开发所需工具及相关组件介绍

Eclipse IDE for Java EE Developers, 247 MB

http://www.eclipse.org/downloads/

apache-tomcat-7.0.42-windows

http://www.apache.org/dist/tomcat/tomcat-7/v7.0.42/bin/

Java SE Development Kit 7u45

http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads-1880260.html

apache-maven-3.1.0-bin

http://maven.apache.org/download.cgi

二、搭建开发环境参考文档

JDK安装及配置

http://xiaoxing598.diandian.com/post/2012-05-06/17031020

Maven安装及配置

http://blog.csdn.net/yuguiyang1990/article/details/8775046

安装m2eclipse插件

http://blog.csdn.net/yuguiyang1990/article/details/8796410

Tomcat安装及配置

http://jingyan.baidu.com/article/8065f87fcc0f182330249841.html

SVN安装及配置

http://www.tech-juice.org/2012/05/01/how-to-add-a-new-eclipse-project-to-an-svn-repository/

ConfigBrowser插件

http://struts.apache.org/release/2.2.x/docs/config-browser-plugin.html

l 第一个开发实践

通过Struts2返回第一个JSON对象的源码下载:

http://bobproject.googlecode.com/svn/tags/tag_ReportWebApp_source_v1.0

一、通过maven的pom.xml引入相关组件

1、struts2的dependency

http://mvnrepository.com/artifact/org.apache.struts/struts2-core/2.3.15.2

2、json的dependency

<dependency>

<groupId>net.sf.json-lib</groupId>

<artifactId>json-lib</artifactId>

<version>2.4</version>

<classifier>jdk15</classifier>

</dependency>

3、javax.servlet的dependency

<dependency>

<groupId>org.eclipse.jetty.orbit</groupId>

<artifactId>javax.servlet</artifactId>

<version>3.0.0.v201112011016</version>

</dependency>

4、log4j2的dependency http://logging.apache.org/log4j/2.x/maven-artifacts.html

<dependency>

<groupId>org.apache.logging.log4j</groupId>

<artifactId>log4j-api</artifactId>

<version>2.0-beta9</version>

</dependency>

<dependency>

<groupId>org.apache.logging.log4j</groupId>

<artifactId>log4j-core</artifactId>

<version>2.0-beta9</version>

</dependency>

5、ConfigBrowser插件

<dependency>

<groupId>org.apache.struts</groupId>

<artifactId>struts2-config-browser-plugin</artifactId>

<version>2.3.15.2</version>

</dependency>

 

二、搭建struts2程序框架

1、创建ReportAction.java

创建public void doAction() throws IOException;

2、创建struts.xml配置文件

<!DOCTYPE struts PUBLIC

"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"

"http://struts.apache.org/dtds/struts-2.3.dtd">

<struts>

<package name="default" extends="struts-default" namespace="/">

<action name="testJSONFromActionByGeneral" class="com.tuoming.iqa.action.ReportAction"

method="doAction">

</action>

</package>

</struts>

3、web.xml中添加struts2配置代码

<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.5"

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_2_5.xsd">

<welcome-file-list>

<welcome-file>index.jsp</welcome-file>

</welcome-file-list>

<filter>

<filter-name>struts2</filter-name>

<filter-class>

org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter

</filter-class>

</filter>

<filter-mapping>

<filter-name>struts2</filter-name>

<url-pattern>*.action</url-pattern>

</filter-mapping>

</web-app>

4、index.jsp中添加客户端代码

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<%

String path = request.getContextPath();

String basePath = request.getScheme() + "://"

+ request.getServerName() + ":" + request.getServerPort()

+ path + "/";

%>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<metahttp-equiv="Content-Type"content="text/html; charset=UTF-8">

<title>Struts2与JSON测试</title>

<script type="text/javascript" src="js/jquery-1.4.2.min.js"></script>

<script type="text/javascript" src="js/index.js"></script>

</head>

<body>

<a href="<%=basePath%>testJSONFromActionByGeneral.action" title="测试从Action以常规方式获取JSON数据">测试从Action以常规方式获取JSON数据</a>

</body>

</html>

5、pom.xml中添加tomcat-maven-plugin的plugin

<plugin>

<groupId>org.codehaus.mojo</groupId>

<artifactId>tomcat-maven-plugin</artifactId>

<version>1.0-beta-1</version>

<configuration>

<url>http://localhost:8080/manager/text</url>

<path>/ ReportWebApp</path>

<server>tomcat</server>

<username>admin</username>

<password>password</password>

</configuration>

</plugin>

6、Right Click >> Run As >> Maven Build,在窗口中的Goals内输入:package tomcat:redeploy

三、采用Log4j2实现日志功能

1、指定目录下创建log4j2.xml,内容如下:

<?xml version="1.0" encoding="UTF-8"?>

<configuration>

<appenders>

<RollingFile name="outErrorFile" fileName="RWA_logs/exception.log"

filePattern="RWA_logs/$${date:yyyy-MM}/exception-%d{MM-dd-yyyy}-%i.log.gz">

<PatternLayout

pattern="%d{yyyy.MM.dd HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n" />

<SizeBasedTriggeringPolicy size="10MB" />

</RollingFile>

<RollingFile name="outDebugFile" fileName="RWA_logs/debug.log"

filePattern="RWA_logs/$${date:yyyy-MM}/exception-%d{MM-dd-yyyy}-%i.log.gz">

<PatternLayout

pattern="%d{yyyy.MM.dd HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n" />

<SizeBasedTriggeringPolicy size="10MB" />

</RollingFile>

<RollingFile name="outInfoFile" fileName="RWA_logs/info.log"

filePattern="RWA_logs/$${date:yyyy-MM}/exception-%d{MM-dd-yyyy}-%i.log.gz">

<PatternLayout

pattern="%d{yyyy.MM.dd HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n" />

<SizeBasedTriggeringPolicy size="10MB" />

</RollingFile>

<Console name="consolePrint" target="SYSTEM_OUT">

<PatternLayout

pattern="%d{yyyy.MM.dd HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n" />

</Console>

</appenders>

<loggers>

<root level="DEBUG">

<appender-ref level="DEBUG" ref="outDebugFile" />

<appender-ref level="ERROR" ref="outErrorFile" />

<appender-ref level="INFO" ref="outInfoFile" />

</root>

</loggers>

</configuration>

2、需打印日志的Class中添加成员变量代码

private static Logger log = LogManager.getLogger(ReportInfo.class.getName());

3、打印日志方法如下

log.debug("通过action是以传统方式返回JSON数据");

4C:\tomcat\bin\RWA_logs目录下查看日志是否生成

J2EE Web开发入门—通过action是以传统方式返回JSON数据的更多相关文章

  1. Web开发入门学习笔记

    公司web项目终于要启动了,本以为django学习可以在实战中进行,结果最终使用了Drupal框架,好吧,那我们就PHP走起,买了本<细说PHP>,先跟着过一遍Web开发入门. HTTP协 ...

  2. day04 Java Web 开发入门

    day04 Java Web 开发入门 1. web 开发相关介绍 2. web 服务器 3. Tomcat服务器启动的问题 4. Tomcat目录结构 5. Web应用程序(虚拟目录映射,缺省web ...

  3. java WEB开发入门

    WEB开发入门 1 进入web JAVASE:标准- standard   JAVA桌面程序 GUI    SOCKET JAVAEE:企业-浏览器控制  web 2 软件结构 C/S :client ...

  4. 【python】 web开发入门

    进入Web开发 现在你完成了Python忍者训练,准备深入Ptyhon的Web开发,但现在的问题是有很多的框架,从中选择最好的框架非常困难,但从初学者的角度出发,Flask基本Web框架将非常适合We ...

  5. Web开发入门经典:使用PHP6、Apache和MySQL 中文pdf扫描版​

    通过学习本书,读者很快就能明白为什么PHP.Apache和MySQL会迅速成为开发动态网站最流行的方式,本书将为读者理解这3个核心组件如何独立工作和协同工作奠定良好的基础,引导读者充分利用它们提供的各 ...

  6. PHP Web开发入门流程

    在学习WEB开发前,至少有一个对C或者计算机编程任何一种语言的基本学习,这会对你以后的开发有一定的启蒙作用. 一.Web开发入门 推荐学习网址: http://www.w3school.com.cn/ ...

  7. Web开发入门教程:Pycharm轻松创建Flask项目

    Web开发入门教程:Pycharm轻松创建Flask项目 打开Pycharm的file,选择创建新的项目,然后弹出对话框,我们可以看到里面有很多的案例,Flask.Django等等,我们选择生成Fla ...

  8. 【转载】salesforce 零基础开发入门学习(五)异步进程介绍与数据批处理Batchable

    salesforce 零基础开发入门学习(五)异步进程介绍与数据批处理Batchable   本篇知识参考:https://developer.salesforce.com/trailhead/for ...

  9. Web API返回JSON数据

    对Web API新手来说,不要忽略了ApiController 在web API中,方法的返回值如果是实体的话实际上是自动返回JSON数据的例如: 他的返回值就是这样的: { "Conten ...

随机推荐

  1. ntp -q 输出说明

    -bash-3.00# ntpq -p      remote           refid            st t when poll reach   delay   offset    ...

  2. 复利test

    因为上节课老师有给我们讲了单元测试的概念及其基本操作,我就对我之前的复利计算器进行了改进和测试.因为从控制台的简单输入输出对单元测试来说不够完善,便参考了其他同学的优秀编程又重新写了一个复利计算器的框 ...

  3. delphi XE5下 andriod 广告图片的demo

    试了一下,关于好几个广告界面,左右滚动的效果:用TabControl 加上定时器实现即可. 1.TTabControl外观 TTabControl的外观由属性TabPosition控制,可选项包括: ...

  4. Java 入门 代码2浮点数据类型

    /** * 基本数据类型之浮点类型 */ public class DataTypeDemo2 { public static void main(String[] args) { double d1 ...

  5. jQuery in action 3rd - Introducing jQuery

    2014 年 10 月, jQuery Foundation 的总裁 Dave Methvin 发布了一篇博客(http://blog.jquery.com/2014/10/29/jquery-3-0 ...

  6. horizon 修改local的logging 配置

    再部署完horizon的开发环境后,首先要做的就是修改下logging的输出. 我用的开发软件是pycharm, 所以,为了方便在 console里看到输出.需要在 /home/geiao/repo/ ...

  7. 产品中 configure/cross compile的一个bug

    在mac机上, 为iPhone版本编译产品. 运行./configure报错如下: configure:22793: error: cannot run test program while cros ...

  8. Visual Studio 2013 支持MVC3不完善,Razor智能提示不完整或者不提示

    以下只是针对MVC3. 前天试用Orchard 1.8,用VS2013新建C#类库项目(ClassLibrary project),然后新建Views文件夹,新建cshtml,然后引用MVC3的相关d ...

  9. CentOS6.5下Tomcat7 Nginx Redis配置步骤

    所有配置均在一台机器上完成,部署拓扑信息如下: 注意:由于Redis配置对jar包和tomcat版本比较严格,请务必使用tomcat7和本文中提供的jar包.下载地址: http://pan.baid ...

  10. 打包解决方案后,安装时提示只能在IIS5.1以上运行解决方法

    环境:vs2010 sp1,mvc4,WIN10 生成安装项目后进行安装提示: 此安装程序需要Internet Information Server 5.1或更高版本和Windows XP和更高的安装 ...