jfinal-hello world
jfinal确实是一个好的框架,很大程度的减少了代码量.下面的例子可以更加减少config的配置.下面是一个jfinal的helloworld.
工程结构:
代码如下:
index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>My JSP 'index.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body style="text-align: center;"> JFINAL<hr> Hello World! </body> </html>
这个页面只是简单的一个helloworld页面.
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_2_5.xsd" version="2.5"> <display-name>demo</display-name> <filter> <filter-name>jfinal</filter-name> <filter-class>com.jfinal.core.JFinalFilter</filter-class> <init-param> <param-name>configClass</param-name> <param-value>com.jp.demo.config.DemoConfig</param-value> </init-param> </filter> <filter-mapping> <filter-name>jfinal</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
这个是jfinal需要的唯一一个xml文件吧(其他的需要的是自己添加的,为了给自己再省事的就不在内),
下面是一个关键性的java class,能为你省去更多的代码了.
package com.jp.common.util; import java.lang.annotation.ElementType; import java.lang.annotation.Inherited; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; @Inherited @Retention(RetentionPolicy.RUNTIME) @Target({ ElementType.TYPE, ElementType.METHOD }) public @interface Path { String value(); }
这个文件的奥妙就在下面了,自己看吧.
下面就是一个config层:具体省代码之一就在这里了,不需要在configRoute(Routes me)方法里写很多的路径了,
package com.jp.demo.config; import com.jfinal.config.Constants; import com.jfinal.config.Handlers; import com.jfinal.config.Interceptors; import com.jfinal.config.JFinalConfig; import com.jfinal.config.Plugins; import com.jfinal.config.Routes; import com.jfinal.render.ViewType; import com.jp.demo.controller.MainController; public class DemoConfig extends JFinalConfig{ @Override public void configConstant(Constants me) { // 这是必须的,否则就会报错了 me.setDevMode(true); me.setViewType(ViewType.JSP); } @Override public void configRoute(Routes me) { me.add("/",MainController.class); } @Override public void configPlugin(Plugins me) { } @Override public void configInterceptor(Interceptors me) { } @Override public void configHandler(Handlers me) { } }
上面说了之一,当然就不是唯一的一处省代码的了,下面的也是MainController
package com.jp.demo.controller; import com.jfinal.core.Controller; import com.jp.common.util.Path; @Path("/") public class MainController extends Controller{ // 这里的index是在浏览器打开的localhost:8888/项目名/index // 在这里就不需要继续写注解了. public void index(){ render("/index.jsp"); } }
当然,这个我会在以后的博客上说明这样写的好处的,也会让大家有目共睹.
具体效果如下:(浏览器打开的页面)
好了,一个HelloWorld就实现了.
会在后续把代码上传上来,供初学者使用. 祝好!
下一篇: jfinal+SiteMesh整合
剧透一下: SiteMesh 是一个网页布局和修饰的框架,利用它可以将网页的内容和页面结构分离,以达到页面结构共享的目的。