打造一款属于本身的web服务器——最后的一点完善

    上一篇咱们经过反射实现了动态加载多个controller,就功能上来讲整个项目已经基本上完成了,可是目前咱们仍然还有一些问题,例如模板支持很差、不少配置信息硬编码很差修改。此外,咱们预期的目标是实现一个可嵌入的jar,以实现web服务,而就目前而言明显是不行的。那么咱们如今就来解决这些问题。 css

1、使用velocity拓展模板
    想要实现一套完善的模板仍是比较麻烦的,因此目前咱们考虑使用java支持的模板来实现,目前比较经常使用的有Freemaker,Velocity等,由于比较熟悉velocity,因此就选择这一款了。相关资料
    首先,咱们在src/main/resources(放配置文件)目录下添加velocity配置文件:
html

resource.loader=class
class.resource.loader.class=org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    这里配置了模板加载方式和对应加载器,这里咱们使用类加载,并经过路径。接下来咱们在ViewHandler中添加处理代码,仍是比较简单的:
/**
	 * 处理Velocity模板
	 * @param resultInfo
	 * @return
	 * @throws IOException
	 */
	public String processVelocityView(ResultInfo resultInfo) throws IOException {
		if (StringUtil.isEmpty(resultInfo.getView())) {
			return "";
		}

		// 获取路径
		String path = analysisVelocityViewPath(resultInfo.getView());
		String content = VelocityUtil.mergeTemplate(path, resultInfo.getResultMap());
		
		if (StringUtil.isEmpty(content)) {
			return "";
		}

		return content;
	}
    这样一来,咱们就能使用velocity渲染数据了。

2、完善配置文件
    对于不少参数,咱们每每须要常常变更,所以须要经过配置文件来配置。这里咱们只是用简单的properties。完善后的配置文件以下: java

#包前缀
PACKAGE_PREFIX=org.eh.web

#模板页面根路径(相对classes文件夹,项目src/main/view下)
VIEW_BASE_PATH=page

#静态资源路劲(相对classes文件夹,项目src/main/view下)
STATIC_RESOURCE_PATH=static

#端口
httpserver.port=8888

#controller包路径,配置后可经过annocation直接配置
controller.package=com.gj.web.controller

#url与controller类对应关系
#url/list=com.gj.web.controller.MyController

#session超时时间(分钟)
session_timeout = 10
    这里还要注意的是,该配置文件只在本项目内生效,当引入其余项目时,须要从新配置。下边咱们来实现配置文件加载:
/**
 * 
 * @author guojing
 * @date 2014-3-3
 */
public class Constants {
	private static final Log log = LogFactory.getLog(Constants.class);

	/* 配置信息 */
	public static String PACKAGE_PREFIX = "org.eh.web."; // 包前缀
	public static String VIEW_BASE_PATH = ""; // 路径
	public static String STATIC_RESOURCE_PATH = ""; // 静态文件路径
	public static String CLASS_PATH = "";//classes文件夹路径

	public static Map<String, String> UrlClassMap = new HashMap<String, String>(); // url与class映射
	public static Map<String, String> OTHER_CONFIG_INFO = new HashMap<String, String>(); // 其余配置信息
	public static List<String> STATIC_SUFFIXS = new ArrayList<String>(Arrays.asList(".css", ".js",
			".jpg", ".png", ".gif", ".html")); // 静态文件后缀

	/* 常量值 */
	public static String PROPERTIES_NAME = "web.properties"; // 配置文件名
	public static String PROPERTIES_VELOCITY_NAME = "velocity.properties"; // 配置文件名
	public static String PROPERTIES_CONTROLLER_PACKAGE = "controller.package"; // controller配置文件中属性名
	public static String PROPERTIES_HPPTSERVER_PORT = "httpserver.port"; // 服务端口名
	public static String SESSION_TIMEOUT = "session_timeout"; // 服务端口名

	public static void loadFromProp(String path) {
		Map<String, String> map = new HashMap<String, String>();
		try {
			map = PropertyUtil.analysisProperties(path);
		} catch (Exception e) {
			log.error("配置文件不存在!", e);
		}

		for (String key : map.keySet()) {
			if (key.equals("PACKAGE_PREFIX")) {
				PACKAGE_PREFIX = map.get(key).toString();
			} else if (key.equals("VIEW_BASE_PATH")) {
				VIEW_BASE_PATH = map.get(key).toString();
			} else if (key.startsWith("url")) {
				UrlClassMap.put(key.replace("url", ""), map.get(key).toString());
			} else {
				OTHER_CONFIG_INFO.put(key, map.get(key).toString());
			}
		}
	}
}
    这样一来,在项目启动的时候就能加载左右配置信息。

3、项目打包
    若是想引入其余项目,咱们首先须要把项目打成jar,而后引入。因为咱们使用maven,那么就容易多了。咱们只须要配置好pom文件便可,以下: linux

<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>org.eh.http</groupId>
	<artifactId>easy-httpserver</artifactId>
	<version>0.0.1</version>
	<packaging>jar</packaging>

	<name>easy-httpserver</name>
	<url>http://maven.apache.org</url>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	</properties>

	<dependencies>
		<dependency>
			<groupId>commons-logging</groupId>
			<artifactId>commons-logging</artifactId>
			<version>1.1.3</version>
		</dependency>
		<dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity</artifactId>
            <version>1.7</version>
        </dependency>
        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-tools</artifactId>
            <version>2.0</version>
        </dependency>
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
			<version>4.10</version>
		</dependency>
	</dependencies>

	<build>
		<finalName>easy-httpserver</finalName>
		<resources>
			<resource>
				<directory>${basedir}/src/main/resources</directory>
			</resource>
		</resources>
	</build>
</project>
    如今咱们build项目以后,就能够在target生成jar了。

3、示例项目
    事实上想要使用生成的jar也并非很方便,须要配置很多东西,所以为了方便期间,咱们来实现一个示例项目,咱们想要实现本身的项目时只须要修改示例项目便可。示例项目实现如下功能: git

  • win/linux下的启动脚本
  • 示例controller
  • 示例模板
  • 示例配置文件
    这些功能其实都很好实现,这里就再也不详述,仍是本身还代码吧~_~。

4、结束语
    此次这个小项目就到此为止了,以后可能主要仍是接着写jvm相关的,或者一些工做中遇到的问题,若是有比较有意思的项目,也会与你们分享的。
    完成项目:源码,示例项目:源码github

相关文章
相关标签/搜索